2009-06-09 00:35:39 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2009 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _EXPRESSION_H
|
|
|
|
#define _EXPRESSION_H
|
|
|
|
|
|
|
|
#define MAX_STRING_LEN 1024
|
|
|
|
|
|
|
|
typedef struct Expr Expr;
|
|
|
|
|
|
|
|
typedef char* (*Function)(const char* name, void* cookie,
|
|
|
|
int argc, Expr* argv[]);
|
|
|
|
|
|
|
|
struct Expr {
|
|
|
|
Function fn;
|
|
|
|
char* name;
|
|
|
|
int argc;
|
|
|
|
Expr** argv;
|
|
|
|
};
|
|
|
|
|
|
|
|
char* Evaluate(void* cookie, Expr* expr);
|
|
|
|
|
|
|
|
// Glue to make an Expr out of a literal.
|
|
|
|
char* Literal(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
|
|
|
|
// Functions corresponding to various syntactic sugar operators.
|
|
|
|
// ("concat" is also available as a builtin function, to concatenate
|
|
|
|
// more than two strings.)
|
|
|
|
char* ConcatFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* LogicalAndFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* LogicalOrFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* LogicalNotFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* SubstringFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* EqualityFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* InequalityFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* SequenceFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
|
|
|
|
// Convenience function for building expressions with a fixed number
|
|
|
|
// of arguments.
|
|
|
|
Expr* Build(Function fn, int count, ...);
|
|
|
|
|
|
|
|
// Global builtins, registered by RegisterBuiltins().
|
|
|
|
char* IfElseFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* AssertFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
char* AbortFn(const char* name, void* cookie, int argc, Expr* argv[]);
|
|
|
|
|
2009-06-10 21:11:53 +00:00
|
|
|
|
|
|
|
// For setting and getting the global error string (when returning
|
|
|
|
// NULL from a function).
|
|
|
|
void SetError(const char* message); // makes a copy
|
|
|
|
const char* GetError(); // retains ownership
|
|
|
|
void ClearError();
|
|
|
|
|
|
|
|
|
2009-06-09 00:35:39 +00:00
|
|
|
typedef struct {
|
|
|
|
const char* name;
|
|
|
|
Function fn;
|
|
|
|
} NamedFunction;
|
|
|
|
|
|
|
|
// Register a new function. The same Function may be registered under
|
|
|
|
// multiple names, but a given name should only be used once.
|
|
|
|
void RegisterFunction(const char* name, Function fn);
|
|
|
|
|
|
|
|
// Register all the builtins.
|
|
|
|
void RegisterBuiltins();
|
|
|
|
|
|
|
|
// Call this after all calls to RegisterFunction() but before parsing
|
|
|
|
// any scripts to finish building the function table.
|
|
|
|
void FinishRegistration();
|
|
|
|
|
|
|
|
// Find the Function for a given name; return NULL if no such function
|
|
|
|
// exists.
|
|
|
|
Function FindFunction(const char* name);
|
|
|
|
|
2009-06-10 21:11:53 +00:00
|
|
|
|
|
|
|
// --- convenience functions for use in functions ---
|
|
|
|
|
|
|
|
// Evaluate the expressions in argv, giving 'count' char* (the ... is
|
|
|
|
// zero or more char** to put them in). If any expression evaluates
|
|
|
|
// to NULL, free the rest and return -1. Return 0 on success.
|
|
|
|
int ReadArgs(void* cookie, Expr* argv[], int count, ...);
|
|
|
|
|
|
|
|
// Evaluate the expressions in argv, returning an array of char*
|
|
|
|
// results. If any evaluate to NULL, free the rest and return NULL.
|
|
|
|
// The caller is responsible for freeing the returned array and the
|
|
|
|
// strings it contains.
|
|
|
|
char** ReadVarArgs(void* cookie, int argc, Expr* argv[]);
|
|
|
|
|
|
|
|
|
2009-06-09 00:35:39 +00:00
|
|
|
#endif // _EXPRESSION_H
|