|
|
|
|
|
|
|
|
|
#ifndef PROGRAM_H |
#define PROGRAM_H |
|
#include <stdarg.h> |
#include "global.h" |
#include "pike_types.h" |
#include "pike_macros.h" |
#include "svalue.h" |
#include "time_stuff.h" |
|
|
#define STRUCT |
#include "compilation.h" |
|
#define EXTERN |
#include "compilation.h" |
|
|
PMOD_PROTO extern struct program_state * Pike_compiler; |
|
|
#ifdef PIKE_DEBUG |
#define PROGRAM_LINE_ARGS int line, char *file |
#else |
#define PROGRAM_LINE_ARGS void |
#endif |
|
extern struct pike_string *this_program_string; |
|
#define LFUN___INIT 0 |
#define LFUN_CREATE 1 |
#define LFUN_DESTROY 2 |
#define LFUN_ADD 3 |
#define LFUN_SUBTRACT 4 |
#define LFUN_AND 5 |
#define LFUN_OR 6 |
#define LFUN_XOR 7 |
#define LFUN_LSH 8 |
#define LFUN_RSH 9 |
#define LFUN_MULTIPLY 10 |
#define LFUN_DIVIDE 11 |
#define LFUN_MOD 12 |
#define LFUN_COMPL 13 |
#define LFUN_EQ 14 |
#define LFUN_LT 15 |
#define LFUN_GT 16 |
#define LFUN___HASH 17 |
#define LFUN_CAST 18 |
#define LFUN_NOT 19 |
#define LFUN_INDEX 20 |
#define LFUN_ASSIGN_INDEX 21 |
#define LFUN_ARROW 22 |
#define LFUN_ASSIGN_ARROW 23 |
#define LFUN__SIZEOF 24 |
#define LFUN__INDICES 25 |
#define LFUN__VALUES 26 |
#define LFUN_CALL 27 |
#define LFUN_RADD 28 |
#define LFUN_RSUBTRACT 29 |
#define LFUN_RAND 30 |
#define LFUN_ROR 31 |
#define LFUN_RXOR 32 |
#define LFUN_RLSH 33 |
#define LFUN_RRSH 34 |
#define LFUN_RMULTIPLY 35 |
#define LFUN_RDIVIDE 36 |
#define LFUN_RMOD 37 |
#define LFUN_ADD_EQ 38 |
#define LFUN__IS_TYPE 39 |
#define LFUN__SPRINTF 40 |
#define LFUN__EQUAL 41 |
|
#define NUM_LFUNS 42 |
|
extern char *lfun_names[]; |
|
#ifndef STRUCT_SVALUE_DECLARED |
#define STRUCT_SVALUE_DECLARED |
struct svalue; |
#endif |
|
#ifndef STRUCT_NODE_S_DECLARED |
#define STRUCT_NODE_S_DECLARED |
struct node_s; |
#endif |
|
#ifndef STRUCT_OBJECT_DECLARED |
#define STRUCT_OBJECT_DECLARED |
struct object; |
#endif |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
union idptr |
{ |
void (*c_fun)(INT32); |
ptrdiff_t offset; |
}; |
|
#define IDENTIFIER_PIKE_FUNCTION 1 |
#define IDENTIFIER_C_FUNCTION 2 |
#define IDENTIFIER_FUNCTION 3 |
#define IDENTIFIER_CONSTANT 4 |
#define IDENTIFIER_VARARGS 8 |
#define IDENTIFIER_PROTOTYPED 16 |
#define IDENTIFIER_SCOPED 32 /* This is used for local functions only */ |
#define IDENTIFIER_SCOPE_USED 64 /* contains scoped local functions */ |
|
#define IDENTIFIER_IS_FUNCTION(X) ((X) & IDENTIFIER_FUNCTION) |
#define IDENTIFIER_IS_PIKE_FUNCTION(X) ((X) & IDENTIFIER_PIKE_FUNCTION) |
#define IDENTIFIER_IS_CONSTANT(X) ((X) & IDENTIFIER_CONSTANT) |
#define IDENTIFIER_IS_VARIABLE(X) (!((X) & (IDENTIFIER_FUNCTION | IDENTIFIER_CONSTANT))) |
|
#define IDENTIFIER_MASK 127 |
|
struct identifier |
{ |
struct pike_string *name; |
struct pike_string *type; |
unsigned INT8 identifier_flags; |
unsigned INT8 run_time_type; |
unsigned INT16 opt_flags; |
#ifdef PROFILING |
unsigned INT32 num_calls; |
unsigned INT32 total_time; |
unsigned INT32 self_time; |
#endif /* PROFILING */ |
union idptr func; |
}; |
|
struct program_constant |
{ |
struct svalue sval; |
struct pike_string *name; |
}; |
|
|
|
|
|
|
|
|
#define ID_STATIC 0x01 /* Symbol is not visible by indexing */ |
#define ID_PRIVATE 0x02 /* Symbol is not visible by inherit */ |
#define ID_NOMASK 0x04 /* Symbol may not be overloaded */ |
#define ID_PUBLIC 0x08 |
#define ID_PROTECTED 0x10 |
#define ID_INLINE 0x20 |
#define ID_HIDDEN 0x40 /* needed? */ |
#define ID_INHERITED 0x80 |
#define ID_OPTIONAL 0x100 /* Symbol is not required by the interface */ |
#define ID_EXTERN 0x200 /* Symbol is defined later */ |
#define ID_VARIANT 0x400 /* Function is overloaded by argument. */ |
|
#define ID_MODIFIER_MASK 0x07ff |
|
#define ID_STRICT_TYPES 0x8000 /* #pragma strict_types */ |
|
struct reference |
{ |
unsigned INT16 inherit_offset; |
unsigned INT16 identifier_offset; |
INT16 id_flags; |
}; |
|
struct inherit |
{ |
INT16 inherit_level; |
INT16 identifier_level; |
INT16 parent_identifier; |
INT16 parent_offset; |
ptrdiff_t storage_offset; |
struct object *parent; |
struct program *prog; |
struct pike_string *name; |
}; |
|
struct pike_trampoline |
{ |
struct pike_frame *frame; |
INT32 func; |
}; |
|
|
|
#define PROGRAM_OPTIMIZED 1 |
|
|
|
|
#define PROGRAM_FIXED 2 |
|
|
#define PROGRAM_FINISHED 4 |
|
|
#define PROGRAM_PASS_1_DONE 8 |
|
|
|
|
#define PROGRAM_DESTRUCT_IMMEDIATE 16 |
|
|
#define PROGRAM_HAS_C_METHODS 32 |
|
|
#define PROGRAM_CONSTANT 64 |
|
|
#define PROGRAM_USES_PARENT 128 |
|
|
|
#define PROGRAM_NO_WEAK_FREE 256 |
|
|
#define PROGRAM_NO_EXPLICIT_DESTRUCT 512 |
|
|
#define PROGRAM_AVOID_CHECK 512 |
|
|
struct program |
{ |
INT32 refs; |
#ifdef PIKE_SECURITY |
struct object *prot; |
#endif |
INT32 id; |
INT32 parent_program_id; |
|
|
|
|
ptrdiff_t storage_needed; |
INT16 flags; |
unsigned INT8 alignment_needed; |
struct timeval timestamp; |
|
struct program *next; |
struct program *prev; |
|
void (*init)(struct object *); |
void (*exit)(struct object *); |
void (*gc_recurse_func)(struct object *); |
void (*gc_check_func)(struct object *); |
#ifdef PIKE_DEBUG |
unsigned INT32 checksum; |
#endif |
#ifdef PROFILING |
unsigned INT32 num_clones; |
#endif /* PROFILING */ |
|
size_t total_size; |
|
#define FOO(NUMTYPE,TYPE,NAME) TYPE * NAME ; |
#include "program_areas.h" |
|
#define FOO(NUMTYPE,TYPE,NAME) NUMTYPE PIKE_CONCAT(num_,NAME) ; |
#include "program_areas.h" |
|
INT16 lfuns[NUM_LFUNS]; |
}; |
|
#define INHERIT_FROM_PTR(P,X) (dmalloc_touch(struct program *,(P))->inherits + (X)->inherit_offset) |
#define PROG_FROM_PTR(P,X) (dmalloc_touch(struct program *,INHERIT_FROM_PTR(P,X)->prog)) |
#define ID_FROM_PTR(P,X) (PROG_FROM_PTR(P,X)->identifiers+(X)->identifier_offset) |
#define INHERIT_FROM_INT(P,X) INHERIT_FROM_PTR(P,(P)->identifier_references+(X)) |
#define PROG_FROM_INT(P,X) PROG_FROM_PTR(P,(P)->identifier_references+(X)) |
#define ID_FROM_INT(P,X) ID_FROM_PTR(P,(P)->identifier_references+(X)) |
|
#define FIND_LFUN(P,N) ( dmalloc_touch(struct program *,(P))->flags & PROGRAM_FIXED?((P)->lfuns[(N)]):low_find_lfun((P), (N)) ) |
|
#define free_program(p) do{ struct program *_=(p); debug_malloc_touch(_); if(!--_->refs) really_free_program(_); }while(0) |
|
|
extern struct object *error_handler; |
|
extern struct program *first_program; |
extern struct program *pike_trampoline_program; |
extern struct program *gc_internal_program; |
|
extern int compilation_depth; |
|
|
#define SEE_STATIC 1 |
#define SEE_PRIVATE 2 |
|
|
#define COMPILER_IN_CATCH 1 |
|
#define ADD_STORAGE(X) low_add_storage(sizeof(X), ALIGNOF(X),0) |
#define STORAGE_NEEDED(X) ((X)->storage_needed - (X)->inherits[0].storage_offset) |
|
#define FOO(NUMTYPE,TYPE,NAME) void PIKE_CONCAT(add_to_,NAME(TYPE ARG)); |
#include "program_areas.h" |
|
|
void ins_int(INT32 i, void (*func)(char tmp)); |
void ins_short(INT16 i, void (*func)(char tmp)); |
void use_module(struct svalue *s); |
void unuse_modules(INT32 howmany); |
struct node_s *find_module_identifier(struct pike_string *ident, |
int see_inherit); |
struct program *parent_compilation(int level); |
struct program *id_to_program(INT32 id); |
void optimize_program(struct program *p); |
int program_function_index_compare(const void *a,const void *b); |
char *find_program_name(struct program *p, INT32 *line); |
void fixate_program(void); |
struct program *low_allocate_program(void); |
void low_start_new_program(struct program *p, |
struct pike_string *name, |
int flags, |
int *idp); |
PMOD_EXPORT void debug_start_new_program(PROGRAM_LINE_ARGS); |
PMOD_EXPORT void really_free_program(struct program *p); |
void dump_program_desc(struct program *p); |
int sizeof_variable(int run_time_type); |
void check_program(struct program *p); |
struct program *end_first_pass(int finish); |
PMOD_EXPORT struct program *debug_end_program(void); |
PMOD_EXPORT size_t low_add_storage(size_t size, size_t alignment, |
ptrdiff_t modulo_orig); |
PMOD_EXPORT void set_init_callback(void (*init)(struct object *)); |
PMOD_EXPORT void set_exit_callback(void (*exit)(struct object *)); |
PMOD_EXPORT void set_gc_recurse_callback(void (*m)(struct object *)); |
PMOD_EXPORT void set_gc_check_callback(void (*m)(struct object *)); |
int low_reference_inherited_identifier(struct program_state *q, |
int e, |
struct pike_string *name, |
int flags); |
int find_inherit(struct program *p, struct pike_string *name); |
node *reference_inherited_identifier(struct pike_string *super_name, |
struct pike_string *function_name); |
void rename_last_inherit(struct pike_string *n); |
void low_inherit(struct program *p, |
struct object *parent, |
int parent_identifier, |
int parent_offset, |
INT32 flags, |
struct pike_string *name); |
PMOD_EXPORT void do_inherit(struct svalue *s, |
INT32 flags, |
struct pike_string *name); |
void compiler_do_inherit(node *n, |
INT32 flags, |
struct pike_string *name); |
void simple_do_inherit(struct pike_string *s, |
INT32 flags, |
struct pike_string *name); |
int isidentifier(struct pike_string *s); |
int low_define_variable(struct pike_string *name, |
struct pike_string *type, |
INT32 flags, |
size_t offset, |
INT32 run_time_type); |
PMOD_EXPORT int map_variable(char *name, |
char *type, |
INT32 flags, |
size_t offset, |
INT32 run_time_type); |
PMOD_EXPORT int quick_map_variable(char *name, |
int name_length, |
size_t offset, |
char *type, |
int type_length, |
INT32 run_time_type, |
INT32 flags); |
int define_variable(struct pike_string *name, |
struct pike_string *type, |
INT32 flags); |
PMOD_EXPORT int simple_add_variable(char *name, |
char *type, |
INT32 flags); |
PMOD_EXPORT int add_constant(struct pike_string *name, |
struct svalue *c, |
INT32 flags); |
PMOD_EXPORT int simple_add_constant(char *name, |
struct svalue *c, |
INT32 flags); |
PMOD_EXPORT int add_integer_constant(char *name, |
INT32 i, |
INT32 flags); |
PMOD_EXPORT int quick_add_integer_constant(char *name, |
int name_length, |
INT32 i, |
INT32 flags); |
PMOD_EXPORT int add_float_constant(char *name, |
double f, |
INT32 flags); |
PMOD_EXPORT int add_string_constant(char *name, |
char *str, |
INT32 flags); |
PMOD_EXPORT int add_program_constant(char *name, |
struct program *p, |
INT32 flags); |
PMOD_EXPORT int add_object_constant(char *name, |
struct object *o, |
INT32 flags); |
PMOD_EXPORT int add_function_constant(char *name, void (*cfun)(INT32), char * type, INT16 flags); |
PMOD_EXPORT int debug_end_class(char *name, ptrdiff_t namelen, INT32 flags); |
INT32 define_function(struct pike_string *name, |
struct pike_string *type, |
unsigned INT8 flags, |
unsigned INT8 function_flags, |
union idptr *func, |
unsigned INT16 opt_flags); |
int really_low_find_shared_string_identifier(struct pike_string *name, |
struct program *prog, |
int flags); |
int low_find_lfun(struct program *p, ptrdiff_t lfun); |
int low_find_shared_string_identifier(struct pike_string *name, |
struct program *prog); |
struct ff_hash; |
int find_shared_string_identifier(struct pike_string *name, |
struct program *prog); |
PMOD_EXPORT int find_identifier(char *name,struct program *prog); |
int store_prog_string(struct pike_string *str); |
int store_constant(struct svalue *foo, |
int equal, |
struct pike_string *constant_name); |
struct array *program_indices(struct program *p); |
struct array *program_values(struct program *p); |
void program_index_no_free(struct svalue *to, struct program *p, |
struct svalue *ind); |
int get_small_number(char **q); |
void start_line_numbering(void); |
void store_linenumber(INT32 current_line, struct pike_string *current_file); |
PMOD_EXPORT char *get_line(unsigned char *pc,struct program *prog,INT32 *linep); |
void my_yyerror(char *fmt,...) ATTRIBUTE((format(printf,1,2))); |
struct program *compile(struct pike_string *prog, |
struct object *handler, |
int major, |
int minor); |
PMOD_EXPORT int pike_add_function2(char *name, void (*cfun)(INT32), |
char *type, unsigned INT8 flags, |
unsigned INT16 opt_flags); |
PMOD_EXPORT int quick_add_function(char *name, |
int name_length, |
void (*cfun)(INT32), |
char *type, |
int type_length, |
unsigned INT8 flags, |
unsigned INT16 opt_flags); |
void check_all_programs(void); |
void init_program(void); |
void cleanup_program(void); |
void gc_mark_program_as_referenced(struct program *p); |
void real_gc_cycle_check_program(struct program *p, int weak); |
unsigned gc_touch_all_programs(void); |
void gc_check_all_programs(void); |
void gc_mark_all_programs(void); |
void gc_cycle_check_all_programs(void); |
void gc_zap_ext_weak_refs_in_programs(void); |
void gc_free_all_unreferenced_programs(void); |
void count_memory_in_programs(INT32 *num_, INT32 *size_); |
void push_compiler_frame(int lexical_scope); |
void pop_local_variables(int level); |
void pop_compiler_frame(void); |
ptrdiff_t low_get_storage(struct program *o, struct program *p); |
PMOD_EXPORT char *get_storage(struct object *o, struct program *p); |
struct program *low_program_from_function(struct program *p, |
INT32 i); |
PMOD_EXPORT struct program *program_from_function(struct svalue *f); |
PMOD_EXPORT struct program *program_from_svalue(struct svalue *s); |
struct find_child_cache_s; |
int find_child(struct program *parent, struct program *child); |
void yywarning(char *fmt, ...) ATTRIBUTE((format(printf,1,2))); |
struct implements_cache_s; |
PMOD_EXPORT int implements(struct program *a, struct program *b); |
PMOD_EXPORT int is_compatible(struct program *a, struct program *b); |
int yyexplain_not_implements(struct program *a, struct program *b, int flags); |
PMOD_EXPORT void *parent_storage(int depth); |
PMOD_EXPORT void change_compiler_compatibility(int major, int minor); |
|
|
#define ADD_FUNCTION(NAME, FUNC, TYPE, FLAGS) \ |
quick_add_function(NAME, CONSTANT_STRLEN(NAME), FUNC, TYPE,\ |
CONSTANT_STRLEN(TYPE), FLAGS, \ |
OPT_SIDE_EFFECT|OPT_EXTERNAL_DEPEND) |
|
#define ADD_PROTOTYPE(NAME, TYPE, FLAGS) \ |
ADD_FUNCTION(NAME, 0, TYPE, FLAGS) |
|
#define ADD_FUNCTION2(NAME, FUNC, TYPE, FLAGS, OPT_FLAGS) \ |
quick_add_function(NAME, CONSTANT_STRLEN(NAME), FUNC, TYPE,\ |
CONSTANT_STRLEN(TYPE), FLAGS, OPT_FLAGS) |
|
#define ADD_PROTOTYPE2(NAME, TYPE, FLAGS, OPT_FLAGS) \ |
ADD_FUNCTION2(NAME, 0, TYPE, FLAGS, OPT_FLAGS) |
|
#define ADD_INT_CONSTANT(NAME, CONST, FLAGS) \ |
quick_add_integer_constant(NAME, CONSTANT_STRLEN(NAME), CONST, FLAGS) |
|
#define PIKE_MAP_VARIABLE(NAME, OFFSET, TYPE, RTTYPE, FLAGS) \ |
quick_map_variable(NAME, CONSTANT_STRLEN(NAME), OFFSET, \ |
TYPE, CONSTANT_STRLEN(TYPE), RTTYPE, FLAGS) |
|
#define ADD_FUNCTION_DTYPE(NAME,FUN,DTYPE,FLAGS) do { \ |
DTYPE_START; \ |
{DTYPE} \ |
{ \ |
struct pike_string *_t; \ |
DTYPE_END(_t); \ |
quick_add_function(NAME, CONSTANT_STRLEN(NAME), FUN, \ |
_t->str, _t->len, FLAGS, \ |
OPT_SIDE_EFFECT|OPT_EXTERNAL_DEPEND); \ |
free_string(_t); \ |
} \ |
} while (0) |
|
#define pike_add_function(NAME, CFUN, TYPE, FLAGS) \ |
pike_add_function2(NAME, CFUN, TYPE, FLAGS, \ |
OPT_SIDE_EFFECT|OPT_EXTERNAL_DEPEND) |
|
#ifndef NO_PIKE_SHORTHAND |
#define add_function pike_add_function |
#endif |
|
#define START_NEW_PROGRAM_ID(ID) do { \ |
start_new_program(); \ |
Pike_compiler->new_program->id=PIKE_CONCAT3(PROG_,ID,_ID); \ |
}while(0) |
|
#ifdef DEBUG_MALLOC |
#define end_program() ((struct program *)debug_malloc_pass(debug_end_program())) |
#define end_class(NAME, FLAGS) (debug_malloc_touch(Pike_compiler->new_program), debug_end_class(NAME, CONSTANT_STRLEN(NAME), FLAGS)) |
#else |
#define end_class(NAME,FLAGS) debug_end_class(NAME, CONSTANT_STRLEN(NAME), FLAGS) |
#define end_program debug_end_program |
#endif |
|
|
#ifdef PIKE_DEBUG |
#define start_new_program() debug_start_new_program(__LINE__,__FILE__) |
#else |
#define start_new_program() debug_start_new_program() |
#endif |
|
#define gc_cycle_check_program(X, WEAK) \ |
gc_cycle_enqueue((gc_cycle_check_cb *) real_gc_cycle_check_program, (X), (WEAK)) |
|
|
|
|
|
#define Pike_new_program Pike_compiler->new_program |
|
|
|
#define TEST_COMPAT(MAJOR,MINOR) \ |
(Pike_compiler->compat_major < (MAJOR) || \ |
(Pike_compiler->compat_major == (MAJOR) && \ |
Pike_compiler->compat_minor <= (MINOR))) |
|
#endif /* PROGRAM_H */ |
|
|
#ifndef LAS_H |
|
* Maybe they should be moved here, since las.h includes this file anyway? |
*/ |
#include "las.h" |
#endif /* !LAS_H */ |
|
|