f6f02d | 1995-10-16 | Fredrik Hübinette (Hubbe) | | |
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | ||| This file a part of Pike, and is copyright by Fredrik Hubinette
||| Pike is distributed as GPL (General Public License)
|
f6f02d | 1995-10-16 | Fredrik Hübinette (Hubbe) | | ||| See the files COPYING and DISCLAIMER for more information.
\*/
|
acbf0a | 1999-02-20 | Henrik Grubbström (Grubba) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "global.h"
|
fbef2a | 1999-09-15 | Fredrik Hübinette (Hubbe) | | RCSID("$Id: program.c,v 1.143 1999/09/16 03:52:33 hubbe Exp $");
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "program.h"
#include "object.h"
#include "dynamic_buffer.h"
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | #include "pike_types.h"
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "stralloc.h"
#include "las.h"
#include "language.h"
#include "lex.h"
|
bb55f8 | 1997-03-16 | Fredrik Hübinette (Hubbe) | | #include "pike_macros.h"
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "fsort.h"
#include "error.h"
#include "docode.h"
#include "interpret.h"
#include "hashtable.h"
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #include "main.h"
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | #include "gc.h"
|
07513e | 1996-10-04 | Fredrik Hübinette (Hubbe) | | #include "threads.h"
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | #include "constants.h"
|
9c6f7d | 1997-04-15 | Fredrik Hübinette (Hubbe) | | #include "operators.h"
|
3eb19a | 1998-01-30 | Henrik Grubbström (Grubba) | | #include "builtin_functions.h"
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | #include "stuff.h"
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | #include "mapping.h"
#include "cyclic.h"
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | #include "security.h"
|
8aeeb2 | 1996-11-19 | Fredrik Hübinette (Hubbe) | |
#include <errno.h>
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include <fcntl.h>
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
#undef ATTRIBUTE
#define ATTRIBUTE(X)
|
1549c6 | 1999-07-02 | Henrik Grubbström (Grubba) | |
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | |
#ifdef COMPILER_DEBUG
#define CDFPRINTF(X) fprintf X
#else /* !COMPILER_DEBUG */
#define CDFPRINTF(X)
#endif /* COMPILER_DEBUG */
|
189fd0 | 1997-01-28 | Fredrik Hübinette (Hubbe) | |
#define FIND_FUNCTION_HASHSIZE 4711
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #define STRUCT
#include "compilation.h"
#define DECLARE
#include "compilation.h"
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | |
char *lfun_names[] = {
"__INIT",
"create",
"destroy",
"`+",
"`-",
"`&",
"`|",
"`^",
"`<<",
"`>>",
"`*",
"`/",
"`%",
"`~",
"`==",
"`<",
"`>",
"__hash",
"cast",
"`!",
|
774b06 | 1996-08-03 | Fredrik Hübinette (Hubbe) | | "`[]",
"`[]=",
|
dffa01 | 1997-01-15 | Fredrik Hübinette (Hubbe) | | "`->",
"`->=",
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | "_sizeof",
"_indices",
"_values",
"`()",
|
1b89ad | 1997-10-10 | Fredrik Hübinette (Hubbe) | | "``+",
"``-",
"``&",
"``|",
"``^",
"``<<",
"``>>",
"``*",
"``/",
"``%",
|
ee3780 | 1999-02-09 | Fredrik Hübinette (Hubbe) | | "`+=",
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | | };
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct program *first_program = 0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | static int current_program_id=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *new_program=0;
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | struct object *fake_object=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *malloc_size_program=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int compiler_pass;
int compilation_depth;
|
48cffa | 1998-01-22 | Henrik Grubbström (Grubba) | | long local_class_counter;
|
964949 | 1998-02-27 | Fredrik Hübinette (Hubbe) | | int catch_level;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct compiler_frame *compiler_frame=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | static INT32 last_line = 0;
static INT32 last_pc = 0;
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | static struct pike_string *last_file = 0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | dynamic_buffer used_modules;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | INT32 num_used_modules;
static struct mapping *resolve_cache=0;
static struct mapping *module_index_cache=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #define CHECK_FOO(NUMTYPE,TYPE,NAME) \
if(malloc_size_program-> PIKE_CONCAT(num_,NAME) < new_program-> PIKE_CONCAT(num_,NAME)) \
fatal("new_program->num_" #NAME " is out of order\n"); \
if(new_program->flags & PROGRAM_OPTIMIZED) \
fatal("Tried to reallocate fixed program.\n")
#else
#define CHECK_FOO(NUMTYPE,TYPE,NAME)
#endif
#define FOO(NUMTYPE,TYPE,NAME) \
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | void PIKE_CONCAT(add_to_,NAME) (TYPE ARG) { \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | CHECK_FOO(NUMTYPE,TYPE,NAME); \
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | if(malloc_size_program->PIKE_CONCAT(num_,NAME) == \
new_program->PIKE_CONCAT(num_,NAME)) { \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void *tmp; \
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | malloc_size_program->PIKE_CONCAT(num_,NAME) *= 2; \
malloc_size_program->PIKE_CONCAT(num_,NAME)++; \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | tmp=realloc((char *)new_program->NAME, \
sizeof(TYPE) * \
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | malloc_size_program->PIKE_CONCAT(num_,NAME)); \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!tmp) fatal("Out of memory.\n"); \
new_program->NAME=tmp; \
} \
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | new_program->NAME[new_program->PIKE_CONCAT(num_,NAME)++]=(ARG); \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
#include "program_areas.h"
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | #define FOO(NUMTYPE,TYPE,NAME) \
void PIKE_CONCAT(low_add_to_,NAME) (struct program_state *state, \
TYPE ARG) { \
if(state->malloc_size_program->PIKE_CONCAT(num_,NAME) == \
state->new_program->PIKE_CONCAT(num_,NAME)) { \
void *tmp; \
state->malloc_size_program->PIKE_CONCAT(num_,NAME) *= 2; \
state->malloc_size_program->PIKE_CONCAT(num_,NAME)++; \
tmp=realloc((char *)state->new_program->NAME, \
sizeof(TYPE) * \
state->malloc_size_program->PIKE_CONCAT(num_,NAME)); \
if(!tmp) fatal("Out of memory.\n"); \
state->new_program->NAME=tmp; \
} \
state->new_program->NAME[state->new_program->PIKE_CONCAT(num_,NAME)++]=(ARG); \
}
#include "program_areas.h"
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void ins_int(INT32 i, void (*func)(char tmp))
{
int e;
for(e=0;e<(long)sizeof(i);e++) func(EXTRACT_UCHAR(((char *)&i)+e));
}
void ins_short(INT16 i, void (*func)(char tmp))
{
int e;
for(e=0;e<(long)sizeof(i);e++) func(EXTRACT_UCHAR(((char *)&i)+e));
}
|
5f8eb7 | 1997-02-18 | Fredrik Hübinette (Hubbe) | |
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | void use_module(struct svalue *s)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
a1e882 | 1998-11-05 | Fredrik Hübinette (Hubbe) | | if( (1<<s->type) & (BIT_MAPPING | BIT_OBJECT | BIT_PROGRAM))
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | num_used_modules++;
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | assign_svalue_no_free((struct svalue *)
low_make_buf_space(sizeof(struct svalue),
&used_modules), s);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(module_index_cache)
{
free_mapping(module_index_cache);
module_index_cache=0;
}
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | }else{
yyerror("Module is neither mapping nor object");
}
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | void unuse_modules(INT32 howmany)
{
if(!howmany) return;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(howmany *sizeof(struct svalue) > used_modules.s.len)
fatal("Unusing too many modules.\n");
#endif
num_used_modules-=howmany;
low_make_buf_space(-sizeof(struct svalue)*howmany, &used_modules);
free_svalues((struct svalue *)low_make_buf_space(0, &used_modules),
howmany,
|
a1e882 | 1998-11-05 | Fredrik Hübinette (Hubbe) | | BIT_MAPPING | BIT_OBJECT | BIT_PROGRAM);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(module_index_cache)
{
free_mapping(module_index_cache);
module_index_cache=0;
}
}
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int low_find_shared_string_identifier(struct pike_string *name,
struct program *prog);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | static struct node_s *index_modules(struct pike_string *ident)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | struct node_s *ret;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | JMP_BUF tmp;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
if(module_index_cache)
{
struct svalue *tmp=low_mapping_string_lookup(module_index_cache,ident);
if(tmp)
{
if(!(IS_ZERO(tmp) && tmp->subtype==1))
return mksvaluenode(tmp);
return 0;
}
}
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(SETJMP(tmp))
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
ONERROR tmp;
SET_ONERROR(tmp,exit_on_error,"Error in handle_error in master object!");
assign_svalue_no_free(sp++, & throw_value);
APPLY_MASTER("handle_error", 1);
pop_stack();
UNSET_ONERROR(tmp);
yyerror("Couldn't index module.");
}else{
struct svalue *modules=(struct svalue *)used_modules.s.str;
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | int e=used_modules.s.len / sizeof(struct svalue);
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
while(--e>=0)
{
push_svalue(modules+e);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | ref_push_string(ident);
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | f_index(2);
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | if(!IS_UNDEFINED(sp-1))
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
UNSETJMP(tmp);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(!module_index_cache)
module_index_cache=allocate_mapping(10);
mapping_string_insert(module_index_cache, ident, sp-1);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | ret=mksvaluenode(sp-1);
pop_stack();
return ret;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | pop_stack();
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
}
UNSETJMP(tmp);
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | return 0;
}
struct node_s *find_module_identifier(struct pike_string *ident)
{
struct node_s *ret;
if((ret=index_modules(ident))) return ret;
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program_state *p=previous_program_state;
int n;
for(n=0;n<compilation_depth;n++,p=p->previous)
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | int i=really_low_find_shared_string_identifier(ident,
p->new_program,
SEE_STATIC);
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | if(i!=-1)
{
struct identifier *id;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | id=ID_FROM_INT(p->new_program, i);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | return mkexternalnode(n, i, id);
}
}
}
if(resolve_cache)
{
struct svalue *tmp=low_mapping_string_lookup(resolve_cache,ident);
if(tmp)
{
if(!(IS_ZERO(tmp) && tmp->subtype==1))
return mkconstantsvaluenode(tmp);
return 0;
}
}
if(!num_parse_error && get_master())
{
DECLARE_CYCLIC();
node *ret=0;
if(BEGIN_CYCLIC(ident, lex.current_file))
{
my_yyerror("Recursive module dependency in %s.",
ident->str);
}else{
SET_CYCLIC_RET(1);
ref_push_string(ident);
ref_push_string(lex.current_file);
SAFE_APPLY_MASTER("resolv", 2);
if(throw_value.type == T_STRING)
{
if(compiler_pass==2)
my_yyerror("%s",throw_value.u.string->str);
}
else
{
if(!resolve_cache)
resolve_cache=allocate_mapping(10);
mapping_string_insert(resolve_cache,ident,sp-1);
if(!(IS_ZERO(sp-1) && sp[-1].subtype==1))
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | ret=mkconstantsvaluenode(sp-1);
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
}
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | pop_stack();
END_CYCLIC();
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(ret) return ret;
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | return 0;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *parent_compilation(int level)
{
int n;
struct program_state *p=previous_program_state;
for(n=0;n<level;n++)
{
if(n>=compilation_depth) return 0;
p=p->previous;
if(!p) return 0;
}
return p->new_program;
}
#define ID_TO_PROGRAM_CACHE_SIZE 512
struct program *id_to_program_cache[ID_TO_PROGRAM_CACHE_SIZE];
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | struct program *id_to_program(INT32 id)
{
struct program *p;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | INT32 h;
if(!id) return 0;
h=id & (ID_TO_PROGRAM_CACHE_SIZE-1);
if((p=id_to_program_cache[h]))
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | if(p->id==id)
return p;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | if(id)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
for(p=first_program;p;p=p->next)
{
if(id==p->id)
{
id_to_program_cache[h]=p;
return p;
}
}
}
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | return 0;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | |
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | */
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void optimize_program(struct program *p)
{
SIZE_T size=0;
char *data;
if(p->flags & PROGRAM_OPTIMIZED) return;
#define FOO(NUMTYPE,TYPE,NAME) \
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | size=DO_ALIGN(size, ALIGNOF(TYPE)); \
size+=p->PIKE_CONCAT(num_,NAME)*sizeof(p->NAME[0]);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
data=malloc(size);
if(!data) return;
size=0;
#define FOO(NUMTYPE,TYPE,NAME) \
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | size=DO_ALIGN(size, ALIGNOF(TYPE)); \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | MEMCPY(data+size,p->NAME,p->PIKE_CONCAT(num_,NAME)*sizeof(p->NAME[0])); \
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree((char *)p->NAME); \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | p->NAME=(TYPE *)(data+size); \
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | size+=p->PIKE_CONCAT(num_,NAME)*sizeof(p->NAME[0]);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
p->total_size=size + sizeof(struct program);
p->flags |= PROGRAM_OPTIMIZED;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | int program_function_index_compare(const void *a,const void *b)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
return
my_order_strcmp(ID_FROM_INT(new_program, *(unsigned short *)a)->name,
ID_FROM_INT(new_program, *(unsigned short *)b)->name);
}
void fixate_program(void)
{
INT32 i,e,t;
if(new_program->flags & PROGRAM_FIXED) return;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->flags & PROGRAM_OPTIMIZED)
fatal("Cannot fixate optimized program\n");
#endif
for(e=i=0;i<(int)new_program->num_identifier_references;i++)
{
struct reference *funp;
struct identifier *fun;
funp=new_program->identifier_references+i;
if(funp->id_flags & (ID_HIDDEN|ID_STATIC)) continue;
if(funp->id_flags & ID_INHERITED)
{
if(funp->id_flags & ID_PRIVATE) continue;
fun=ID_FROM_PTR(new_program, funp);
for(t=i+1;t>=0 && t<(int)new_program->num_identifier_references;t++)
{
struct reference *funpb;
struct identifier *funb;
funpb=new_program->identifier_references+t;
if(funpb->id_flags & (ID_HIDDEN|ID_STATIC)) continue;
funb=ID_FROM_PTR(new_program,funpb);
if(fun->name==funb->name) t=-10;
}
if(t<0) continue;
}
add_to_identifier_index(i);
}
fsort((void *)new_program->identifier_index,
new_program->num_identifier_index,
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | sizeof(unsigned short),(fsortfun)program_function_index_compare);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | |
|
2c1709 | 1999-06-22 | Fredrik Hübinette (Hubbe) | | for(i=1;i<3;i++)
{
struct pike_string *tmp=findstring(lfun_names[i]);
if(tmp)
{
new_program->lfuns[i]=really_low_find_shared_string_identifier(
tmp,
new_program,
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | SEE_STATIC);
|
2c1709 | 1999-06-22 | Fredrik Hübinette (Hubbe) | | }else{
new_program->lfuns[i]=-1;
}
}
for(;i<NUM_LFUNS;i++)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program->lfuns[i]=find_identifier(lfun_names[i],new_program);
new_program->flags |= PROGRAM_FIXED;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | struct program *low_allocate_program(void)
{
struct program *p;
p=ALLOC_STRUCT(program);
MEMSET(p, 0, sizeof(struct program));
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | p->alignment_needed=1;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
GC_ALLOC();
p->refs=1;
p->id=++current_program_id;
if((p->next=first_program)) first_program->prev=p;
first_program=p;
GETTIMEOFDAY(& p->timestamp);
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | INITIALIZE_PROT(p);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | return p;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void low_start_new_program(struct program *p,
struct pike_string *name,
int flags)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | int e,id=0;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
58544f | 1998-07-17 | Henrik Grubbström (Grubba) | |
low_init_threads_disable();
|
a91ca0 | 1998-07-10 | Henrik Grubbström (Grubba) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compilation_depth++;
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | CDFPRINTF((stderr, "th(%ld) low_start_new_program() pass=%d: compilation_depth:%d\n",
(long)th_self(),compilation_depth,compiler_pass));
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!p)
{
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | p=low_allocate_program();
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }else{
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(p);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
if(name)
{
struct svalue s;
s.type=T_PROGRAM;
s.u.program=p;
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | id=add_constant(name, &s, flags);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
fb2f66 | 1998-11-05 | Fredrik Hübinette (Hubbe) | | init_type_stack();
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #define PUSH
#include "compilation.h"
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | num_used_modules=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(p && (p->flags & PROGRAM_FINISHED))
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | yyerror("Pass2: Program already done");
p=0;
}
malloc_size_program = ALLOC_STRUCT(program);
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | fake_object=(struct object *)xalloc(sizeof(struct object) + 256*sizeof(struct svalue));
MEMSET(fake_object,0x55,sizeof(struct object) + 256*sizeof(struct svalue));
#else
fake_object=ALLOC_STRUCT(object);
#endif
|
a3c6ad | 1998-01-29 | Fredrik Hübinette (Hubbe) | | GC_ALLOC();
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | |
fake_object->next=fake_object;
fake_object->prev=fake_object;
fake_object->refs=1;
fake_object->parent=0;
fake_object->parent_identifier=0;
fake_object->prog=p;
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_SECURITY
fake_object->prot=0;
#endif
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(p);
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | |
if(name)
{
if((fake_object->parent=previous_program_state->fake_object))
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(fake_object->parent);
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | fake_object->parent_identifier=id;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program=p;
if(new_program->program)
{
#define FOO(NUMTYPE,TYPE,NAME) \
malloc_size_program->PIKE_CONCAT(num_,NAME)=new_program->PIKE_CONCAT(num_,NAME);
#include "program_areas.h"
}else{
static struct pike_string *s;
struct inherit i;
#define START_SIZE 64
#define FOO(NUMTYPE,TYPE,NAME) \
malloc_size_program->PIKE_CONCAT(num_,NAME)=START_SIZE; \
new_program->NAME=(TYPE *)xalloc(sizeof(TYPE) * START_SIZE);
#include "program_areas.h"
i.prog=new_program;
i.identifier_level=0;
i.storage_offset=0;
i.inherit_level=0;
i.parent=0;
i.parent_identifier=0;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | i.parent_offset=1;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | i.name=0;
add_to_inherits(i);
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | }
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | init_node=0;
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | num_parse_error=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | push_compiler_frame(0);
|
73406b | 1999-02-14 | Fredrik Hübinette (Hubbe) | | add_ref(compiler_frame->current_return_type=void_type_string);
|
45f993 | 1998-04-28 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
45f993 | 1998-04-28 | Fredrik Hübinette (Hubbe) | | #endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
bcd574 | 1999-03-17 | Fredrik Hübinette (Hubbe) | | void debug_start_new_program(PROGRAM_LINE_ARGS)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | | CDFPRINTF((stderr,
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | "th(%ld) start_new_program(): threads_disabled:%d, compilation_depth:%d\n",
(long)th_self(),threads_disabled, compilation_depth));
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | low_start_new_program(0,0,0);
|
bcd574 | 1999-03-17 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
{
struct pike_string *s=make_shared_string(file);
store_linenumber(line,s);
free_string(s);
}
#endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
void really_free_program(struct program *p)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | unsigned INT16 e;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
if(id_to_program_cache[p->id & (ID_TO_PROGRAM_CACHE_SIZE-1)]==p)
id_to_program_cache[p->id & (ID_TO_PROGRAM_CACHE_SIZE-1)]=0;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->strings)
for(e=0; e<p->num_strings; e++)
if(p->strings[e])
free_string(p->strings[e]);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->identifiers)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | for(e=0; e<p->num_identifiers; e++)
{
if(p->identifiers[e].name)
free_string(p->identifiers[e].name);
if(p->identifiers[e].type)
free_string(p->identifiers[e].type);
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->constants)
free_svalues(p->constants, p->num_constants, BIT_MIXED);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->inherits)
for(e=0; e<p->num_inherits; e++)
|
3c0c28 | 1998-01-26 | Fredrik Hübinette (Hubbe) | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e].name)
free_string(p->inherits[e].name);
if(e)
{
if(p->inherits[e].prog)
free_program(p->inherits[e].prog);
}
if(p->inherits[e].parent)
free_object(p->inherits[e].parent);
|
3c0c28 | 1998-01-26 | Fredrik Hübinette (Hubbe) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
if(p->prev)
p->prev->next=p->next;
else
first_program=p->next;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(p->next)
p->next->prev=p->prev;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_OPTIMIZED)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
if(p->program)
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree(p->program);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #define FOO(NUMTYPE,TYPE,NAME) p->NAME=0;
#include "program_areas.h"
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }else{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #define FOO(NUMTYPE,TYPE,NAME) \
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | if(p->NAME) { dmfree((char *)p->NAME); p->NAME=0; }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | FREE_PROT(p);
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree((char *)p);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | GC_FREE();
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | void dump_program_desc(struct program *p)
{
int e,d,q;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"All identifiers:\n");
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_identifier_references;e++)
{
fprintf(stderr,"%3d:",e);
for(d=0;d<INHERIT_FROM_INT(p,e)->inherit_level;d++) fprintf(stderr," ");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"%s;\n",ID_FROM_INT(p,e)->name->str);
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | }
fprintf(stderr,"All sorted identifiers:\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(q=0;q<(int)p->num_identifier_index;q++)
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | {
e=p->identifier_index[q];
fprintf(stderr,"%3d (%3d):",e,q);
for(d=0;d<INHERIT_FROM_INT(p,e)->inherit_level;d++) fprintf(stderr," ");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"%s;\n", ID_FROM_INT(p,e)->name->str);
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | }
}
#endif
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | static void toss_compilation_resources(void)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
a3c6ad | 1998-01-29 | Fredrik Hübinette (Hubbe) | | if(fake_object)
{
free_program(fake_object->prog);
fake_object->prog=0;
free_object(fake_object);
fake_object=0;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | free_program(new_program);
new_program=0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(malloc_size_program)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree((char *)malloc_size_program);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | malloc_size_program=0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
if(module_index_cache)
{
free_mapping(module_index_cache);
module_index_cache=0;
}
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | while(compiler_frame)
pop_compiler_frame();
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
if(last_file)
{
free_string(last_file);
last_file=0;
}
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | unuse_modules(num_used_modules);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | int sizeof_variable(int run_time_type)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | {
switch(run_time_type)
{
case T_FUNCTION:
case T_MIXED: return sizeof(struct svalue);
case T_INT: return sizeof(INT_TYPE);
case T_FLOAT: return sizeof(FLOAT_TYPE);
default: return sizeof(char *);
}
}
static int alignof_variable(int run_time_type)
{
switch(run_time_type)
{
case T_FUNCTION:
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | case T_MIXED: return ALIGNOF(struct svalue);
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | case T_INT: return ALIGNOF(INT_TYPE);
case T_FLOAT: return ALIGNOF(FLOAT_TYPE);
default: return ALIGNOF(char *);
}
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | void check_program(struct program *p)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
INT32 size,e;
unsigned INT32 checksum;
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | int variable_positions[1024];
for(e=0;e<NELEM(variable_positions);e++)
variable_positions[e]=-1;
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
|
636e47 | 1998-04-15 | Fredrik Hübinette (Hubbe) | | if(p->id > current_program_id)
fatal("Program id is out of sync! (p->id=%d, current_program_id=%d)\n",p->id,current_program_id);
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | if(p->refs <=0)
fatal("Program has zero refs.\n");
if(p->next && p->next->prev != p)
fatal("Program ->next->prev != program.\n");
if(p->prev)
{
if(p->prev->next != p)
fatal("Program ->prev->next != program.\n");
}else{
if(first_program != p)
fatal("Program ->prev == 0 but first_program != program.\n");
}
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(p->id > current_program_id || p->id <= 0)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | fatal("Program id is wrong.\n");
if(p->storage_needed < 0)
fatal("Program->storage_needed < 0.\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(p->num_identifier_index > p->num_identifier_references)
fatal("Too many identifier index entries in program!\n");
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_constants;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | check_svalue(p->constants + e);
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_strings;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | check_string(p->strings[e]);
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_inherits;e++)
{
if(p->inherits[e].storage_offset < 0)
fatal("Inherit->storage_offset is wrong.\n");
if(e)
{
if(p->inherits[e-1].storage_offset >
p->inherits[e].storage_offset)
fatal("Overlapping inherits! (1)\n");
if(p->inherits[e-1].prog &&
p->inherits[e-1].inherit_level >= p->inherits[e].inherit_level &&
p->inherits[e-1].storage_offset +
p->inherits[e-1].prog->storage_needed > p->inherits[e].storage_offset)
fatal("Overlapping inherits!\n");
}
}
|
7066e1 | 1999-09-14 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_FINISHED)
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_identifiers;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
check_string(p->identifiers[e].name);
check_string(p->identifiers[e].type);
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if(p->identifiers[e].identifier_flags & ~15)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | fatal("Unknown flags in identifier flag field.\n");
if(p->identifiers[e].run_time_type!=T_MIXED)
check_type(p->identifiers[e].run_time_type);
|
2f1b9e | 1998-04-06 | Fredrik Hübinette (Hubbe) | |
if(IDENTIFIER_IS_VARIABLE(p->identifiers[e].identifier_flags))
{
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | if( (p->identifiers[e].func.offset + OFFSETOF(object,storage)) &
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | (alignof_variable(p->identifiers[e].run_time_type)-1))
|
2f1b9e | 1998-04-06 | Fredrik Hübinette (Hubbe) | | {
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | fatal("Variable %s offset is not properly aligned (%d).\n",p->identifiers[e].name->str,p->identifiers[e].func.offset);
|
2f1b9e | 1998-04-06 | Fredrik Hübinette (Hubbe) | | }
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_identifier_references;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | struct identifier *i;
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | if(p->identifier_references[e].inherit_offset > p->num_inherits)
fatal("Inherit offset is wrong!\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
513ece | 1999-09-09 | Fredrik Hübinette (Hubbe) | | if(!p->inherits[p->identifier_references[e].inherit_offset].prog)
{
if(!(p->flags & PROGRAM_FINISHED))
continue;
fatal("p->inherit[%d].prog = NULL!\n",p->identifier_references[e].inherit_offset);
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | if(p->identifier_references[e].identifier_offset >
p->inherits[p->identifier_references[e].inherit_offset].prog->num_identifiers)
fatal("Identifier offset is wrong!\n");
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
i=ID_FROM_INT(p, e);
if( !(i->identifier_flags & (IDENTIFIER_FUNCTION | IDENTIFIER_CONSTANT)))
{
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | int q, size;
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
int offset = INHERIT_FROM_INT(p, e)->storage_offset+i->func.offset;
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | size=sizeof_variable(i->run_time_type);
if(offset+size > p->storage_needed || offset<0)
fatal("Variable outside storage! (%s)\n",i->name->str);
for(q=0;q<size;q++)
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | {
if(offset+q >= NELEM(variable_positions)) break;
if(variable_positions[offset+q] != -1)
{
if(ID_FROM_INT(p,variable_positions[offset+q])->run_time_type !=
i->run_time_type)
{
fatal("Variable '%s' and '%s' overlap\n",
ID_FROM_INT(p,variable_positions[offset+q])->name->str,
i->name->str);
}
}
variable_positions[offset+q]=e;
}
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_identifier_index;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
if(p->identifier_index[e] > p->num_identifier_references)
fatal("Program->identifier_indexes[%ld] is wrong\n",(long)e);
}
}
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *end_first_pass(int finish)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int e;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct program *prog;
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct pike_string *s;
MAKE_CONSTANT_SHARED_STRING(s,"__INIT");
|
ae7ee5 | 1998-04-10 | Henrik Grubbström (Grubba) | | for(e=new_program->num_inherits-1;e;e--)
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
int id;
if(new_program->inherits[e].inherit_level!=1) continue;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | id=low_reference_inherited_identifier(0, e, s, SEE_STATIC);
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(id!=-1)
{
init_node=mknode(F_ARG_LIST,
mkcastnode(void_type_string,
|
87c9d2 | 1998-04-09 | Fredrik Hübinette (Hubbe) | | mkapplynode(mkidentifiernode(id),0)),
init_node);
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(init_node)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
union idptr tmp;
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | e=dooptcode(s,
mknode(F_ARG_LIST,
init_node,mknode(F_RETURN,mkintnode(0),0)),
function_type_string,
ID_STATIC);
|
a8ef6e | 1996-12-03 | Fredrik Hübinette (Hubbe) | | init_node=0;
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | }else{
e=-1;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | new_program->lfuns[LFUN___INIT]=e;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | free_string(s);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | pop_compiler_frame();
if(num_parse_error > 0)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
prog=0;
}else{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | prog=new_program;
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(prog);
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | check_program(prog);
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | if(l_flag)
dump_program_desc(prog);
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | #endif
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program->flags |= PROGRAM_PASS_1_DONE;
if(finish)
{
fixate_program();
optimize_program(new_program);
new_program->flags |= PROGRAM_FINISHED;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | toss_compilation_resources();
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #define POP
#include "compilation.h"
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
fb2f66 | 1998-11-05 | Fredrik Hübinette (Hubbe) | | exit_type_stack();
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compilation_depth--;
|
a91ca0 | 1998-07-10 | Henrik Grubbström (Grubba) | |
exit_threads_disable(NULL);
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | |
|
f06a82 | 1999-07-02 | Henrik Grubbström (Grubba) | | CDFPRINTF((stderr,
"th(%ld),end_first_pass(): compilation_depth:%d, compiler_pass:%d\n",
(long)th_self(), compilation_depth, compiler_pass));
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | |
|
a8ef6e | 1996-12-03 | Fredrik Hübinette (Hubbe) | | free_all_nodes();
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(!compiler_frame && compiler_pass==2 && resolve_cache)
{
free_mapping(resolve_cache);
resolve_cache=0;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return prog;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
3c0c28 | 1998-01-26 | Fredrik Hübinette (Hubbe) | | struct program *debug_end_program(void)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
return end_first_pass(1);
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
fbef2a | 1999-09-15 | Fredrik Hübinette (Hubbe) | | SIZE_T low_add_storage(SIZE_T size, SIZE_T alignment, int modulo_orig)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | long offset;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
if(alignment <=0 || (alignment & (alignment-1)) || alignment > 256)
fatal("Alignment must be 1,2,4,8,16,32,64,128 or 256 not %d\n",alignment);
#endif
|
fbef2a | 1999-09-15 | Fredrik Hübinette (Hubbe) | | modulo=( modulo_orig+OFFSETOF(object,storage) ) % alignment;
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
offset=DO_ALIGN(new_program->storage_needed-modulo,alignment)+modulo;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
if(!new_program->storage_needed)
new_program->inherits[0].storage_offset=offset;
if(new_program->alignment_needed<alignment)
new_program->alignment_needed=alignment;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | if(offset < new_program->storage_needed)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | fatal("add_storage failed horribly!\n");
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
if( (offset + OFFSETOF(object,storage) - modulo ) % alignment )
fatal("add_storage failed horribly(2)!\n");
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | #endif
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
new_program->storage_needed = offset + size;
return (SIZE_T) offset;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | void set_init_callback(void (*init)(struct object *))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program->init=init;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | void set_exit_callback(void (*exit)(struct object *))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program->exit=exit;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | |
void set_gc_mark_callback(void (*m)(struct object *))
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | new_program->gc_marked=m;
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | }
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | |
void set_gc_check_callback(void (*m)(struct object *))
{
new_program->gc_check=m;
}
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | int low_reference_inherited_identifier(struct program_state *q,
int e,
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | struct pike_string *name,
int flags)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | struct program *np=q?q->new_program:new_program;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct reference funp;
struct program *p;
int i,d;
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | p=np->inherits[e].prog;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | i=find_shared_string_identifier(name,p);
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | if(i==-1)
{
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | i=really_low_find_shared_string_identifier(name,p, flags);
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | if(i==-1) return -1;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if(p->identifier_references[i].id_flags & ID_HIDDEN)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return -1;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | if(p->identifier_references[i].id_flags & ID_PRIVATE)
if(!(flags & SEE_PRIVATE))
return -1;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | funp=p->identifier_references[i];
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | funp.inherit_offset+=e;
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | funp.id_flags|=ID_HIDDEN;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | for(d=0;d<(int)np->num_identifier_references;d++)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
struct reference *fp;
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | fp=np->identifier_references+d;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
if(!MEMCMP((char *)fp,(char *)&funp,sizeof funp)) return d;
}
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | if(q)
low_add_to_identifier_references(q,funp);
else
add_to_identifier_references(funp);
return np->num_identifier_references -1;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | node *reference_inherited_identifier(struct pike_string *super_name,
struct pike_string *function_name)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | int n,e,id;
struct program_state *state=previous_program_state;
struct program *p;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(function_name!=debug_findstring(function_name))
fatal("reference_inherited_function on nonshared string.\n");
#endif
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
p=new_program;
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | for(e=p->num_inherits-1;e>0;e--)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e].inherit_level!=1) continue;
if(!p->inherits[e].name) continue;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
if(super_name)
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | if(super_name != p->inherits[e].name)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | continue;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | id=low_reference_inherited_identifier(0,
e,
function_name,
SEE_STATIC);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | if(id!=-1)
return mkidentifiernode(id);
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | if(ISCONSTSTR(function_name,"`->") ||
ISCONSTSTR(function_name,"`[]"))
{
|
624f57 | 1999-03-11 | Fredrik Hübinette (Hubbe) | | return mknode(F_MAGIC_INDEX,mkintnode(e),mkintnode(0));
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | if(ISCONSTSTR(function_name,"`->=") ||
ISCONSTSTR(function_name,"`[]="))
{
|
624f57 | 1999-03-11 | Fredrik Hübinette (Hubbe) | | return mknode(F_MAGIC_SET_INDEX,mkintnode(e),mkintnode(0));
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
}
for(n=0;n<compilation_depth;n++,state=state->previous)
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | {
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | struct program *p=state->new_program;
for(e=p->num_inherits-1;e>0;e--)
{
if(p->inherits[e].inherit_level!=1) continue;
if(!p->inherits[e].name) continue;
if(super_name)
if(super_name != p->inherits[e].name)
continue;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | id=low_reference_inherited_identifier(state,e,function_name,SEE_STATIC);
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
if(id!=-1)
return mkexternalnode(n,id,ID_FROM_INT(state->new_program, id));
if(ISCONSTSTR(function_name,"`->") ||
ISCONSTSTR(function_name,"`[]"))
{
return mkapplynode(mkprgnode(magic_index_program),
mknode(F_ARG_LIST,mkintnode(e),mkintnode(n+1)));
}
if(ISCONSTSTR(function_name,"`->=") ||
ISCONSTSTR(function_name,"`[]="))
{
return mkapplynode(mkprgnode(magic_set_index_program),
mknode(F_ARG_LIST,mkintnode(e),mkintnode(n+1)));
}
}
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | | }
return 0;
}
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | void rename_last_inherit(struct pike_string *n)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->inherits[new_program->num_inherits].name)
free_string(new_program->inherits[new_program->num_inherits].name);
copy_shared_string(new_program->inherits[new_program->num_inherits].name,
n);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | void low_inherit(struct program *p,
struct object *parent,
int parent_identifier,
int parent_offset,
INT32 flags,
struct pike_string *name)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
int e, inherit_offset, storage_offset;
struct inherit inherit;
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | struct pike_string *s;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!p)
{
yyerror("Illegal program pointer.");
return;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_USES_PARENT)
{
if(!parent && !parent_offset)
{
yyerror("Parent pointer lost, cannot inherit!");
|
b1dd8f | 1999-09-06 | Henrik Grubbström (Grubba) | |
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | }
}
|
313989 | 1999-09-06 | Henrik Grubbström (Grubba) | | if(parent_offset)
parent_offset--;
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
|
bcf946 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | if(!(p->flags & (PROGRAM_FINISHED | PROGRAM_PASS_1_DONE)))
{
yyerror("Cannot inherit program which is not fully compiled yet.");
return;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | inherit_offset = new_program->num_inherits;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | storage_offset=(p->inherits[0].storage_offset + OFFSETOF(object,storage)) %
p->alignment_needed;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | storage_offset=low_add_storage(p->storage_needed,
p->alignment_needed,
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | storage_offset);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0; e<(int)p->num_inherits; e++)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
inherit=p->inherits[e];
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(inherit.prog);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | inherit.identifier_level += new_program->num_identifier_references;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | inherit.storage_offset += storage_offset;
inherit.inherit_level ++;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!e)
{
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | if(parent)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | if(parent->next == parent)
{
struct object *o;
for(o=fake_object->parent;o!=parent;o=o->parent)
{
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | if(!o) fatal("low_inherit with odd fake_object as parent!\n");
#endif
inherit.parent_offset++;
}
}else{
inherit.parent=parent;
inherit.parent_identifier=parent_identifier;
inherit.parent_offset=0;
}
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }else{
inherit.parent_offset+=parent_offset;
|
bcd574 | 1999-03-17 | Fredrik Hübinette (Hubbe) | | inherit.parent_identifier=parent_identifier;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | }else{
if(parent && parent->next != parent && inherit.parent_offset)
{
struct object *par=parent;
int e,pid=parent_identifier;
for(e=1;e<inherit.parent_offset;e++)
{
struct inherit *in;
if(!par->prog)
{
par=0;
pid=0;
break;
}
in=INHERIT_FROM_INT(par->prog, pid);
if(in->parent_offset)
{
pid=par->parent_identifier;
par=par->parent;
e-=in->parent_offset-1;
}else{
pid=in->parent_identifier;
par=in->parent;
}
}
inherit.parent=par;
inherit.parent_offset=0;
|
d0cd2f | 1998-11-08 | Fredrik Hübinette (Hubbe) | | }else{
inherit.parent_offset+=parent_offset;
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | if(inherit.parent) add_ref(inherit.parent);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(name)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(e==0)
{
|
3c0c28 | 1998-01-26 | Fredrik Hübinette (Hubbe) | | copy_shared_string(inherit.name,name);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
else if(inherit.name)
{
struct pike_string *s;
s=begin_shared_string(inherit.name->len + name->len + 2);
MEMCPY(s->str,name->str,name->len);
MEMCPY(s->str+name->len,"::",2);
MEMCPY(s->str+name->len+2,inherit.name->str,inherit.name->len);
inherit.name=end_shared_string(s);
}
else
{
inherit.name=0;
}
}else{
inherit.name=0;
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_inherits(inherit);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for (e=0; e < (int)p->num_identifier_references; e++)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
struct reference fun;
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | struct pike_string *name;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
fun = p->identifier_references[e];
name=ID_FROM_PTR(p,&fun)->name;
fun.inherit_offset += inherit_offset;
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if (fun.id_flags & ID_NOMASK)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
int n;
n = isidentifier(name);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if (n != -1 && ID_FROM_INT(new_program,n)->func.offset != -1)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine 'nomask' function/variable \"%s\"",name->str);
}
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if(fun.id_flags & ID_PRIVATE) fun.id_flags|=ID_HIDDEN;
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | |
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if (fun.id_flags & ID_PUBLIC)
fun.id_flags |= flags & ~ID_PRIVATE;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | else
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | fun.id_flags |= flags;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | fun.id_flags |= ID_INHERITED;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_identifier_references(fun);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
}
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | void do_inherit(struct svalue *s,
INT32 flags,
struct pike_string *name)
{
struct program *p=program_from_svalue(s);
low_inherit(p,
s->type == T_FUNCTION ? s->u.object : 0,
s->subtype,
0,
flags,
name);
}
void compiler_do_inherit(node *n,
INT32 flags,
struct pike_string *name)
{
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | struct program *p;
struct identifier *i;
INT32 numid, offset;
|
2416d8 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | if(!n)
{
yyerror("Unable to inherit");
return;
}
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | switch(n->token)
{
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | case F_IDENTIFIER:
p=new_program;
offset=0;
numid=n->u.number;
goto continue_inherit;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | case F_EXTERNAL:
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | p=parent_compilation(n->u.integer.a);
offset=n->u.integer.a;
numid=n->u.integer.b;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | |
if(!p)
{
yyerror("Failed to resolv external constant.\n");
return;
}
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | continue_inherit:
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | i=ID_FROM_INT(p, numid);
if(IDENTIFIER_IS_CONSTANT(i->identifier_flags))
{
|
2416d8 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | struct svalue *s=PROG_FROM_INT(p, numid)->constants + i->func.offset;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | if(s->type != T_PROGRAM)
{
|
2416d8 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | do_inherit(s,flags,name);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | return;
}else{
p=s->u.program;
}
}else{
yyerror("Inherit identifier is not a constant program");
return;
}
low_inherit(p,
0,
|
bcd574 | 1999-03-17 | Fredrik Hübinette (Hubbe) | | numid,
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | offset+1,
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | flags,
name);
break;
default:
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | resolv_class(n);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | do_inherit(sp-1, flags, name);
pop_stack();
}
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void simple_do_inherit(struct pike_string *s,
INT32 flags,
struct pike_string *name)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
reference_shared_string(s);
push_string(s);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | ref_push_string(lex.current_file);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | SAFE_APPLY_MASTER("handle_inherit", 2);
if(sp[-1].type != T_PROGRAM)
{
my_yyerror("Couldn't find file to inherit %s",s->str);
pop_stack();
return;
}
if(name)
{
free_string(s);
s=name;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | do_inherit(sp-1, flags, s);
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | free_string(s);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | pop_stack();
}
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | int isidentifier(struct pike_string *s)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
INT32 e;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(e=new_program->num_identifier_references-1;e>=0;e--)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->identifier_references[e].id_flags & ID_HIDDEN) continue;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(ID_FROM_INT(new_program, e)->name == s)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return e;
}
return -1;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | int low_define_variable(struct pike_string *name,
struct pike_string *type,
INT32 flags,
INT32 offset,
INT32 run_time_type)
{
int n;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | struct identifier dummy;
struct reference ref;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
fatal("Attempting to add variable to fixed program\n");
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | |
if(compiler_pass==2)
|
05bfe2 | 1998-07-20 | Henrik Grubbström (Grubba) | | fatal("Internal error: Not allowed to add more identifiers during second compiler pass.\n"
"Added identifier: \"%s\"\n", name->str);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | copy_shared_string(dummy.name, name);
copy_shared_string(dummy.type, type);
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | dummy.identifier_flags = 0;
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | dummy.run_time_type=run_time_type;
dummy.func.offset=offset;
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | #ifdef PROFILING
|
618963 | 1998-11-12 | Fredrik Hübinette (Hubbe) | | dummy.self_time=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | dummy.num_calls=0;
|
a2a880 | 1998-03-18 | Per Hedbor | | dummy.total_time=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | |
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | ref.id_flags=flags;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | ref.identifier_offset=new_program->num_identifiers;
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | ref.inherit_offset=0;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
add_to_variable_index(ref.identifier_offset);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
add_to_identifiers(dummy);
n=new_program->num_identifier_references;
add_to_identifier_references(ref);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | return n;
}
int map_variable(char *name,
char *type,
INT32 flags,
INT32 offset,
INT32 run_time_type)
{
int ret;
struct pike_string *n,*t;
n=make_shared_string(name);
t=parse_type(type);
ret=low_define_variable(n,t,flags,offset,run_time_type);
free_string(n);
free_string(t);
return ret;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | int define_variable(struct pike_string *name,
struct pike_string *type,
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | INT32 flags)
{
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | int n, run_time_type;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(name!=debug_findstring(name))
fatal("define_variable on nonshared string.\n");
#endif
if(type == void_type_string)
yyerror("Variables can't be of type void");
n = isidentifier(name);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->flags & PROGRAM_PASS_1_DONE)
{
if(n==-1)
yyerror("Pass2: Variable disappeared!");
else
return n;
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
fatal("Attempting to add variable to fixed program\n");
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(n != -1)
{
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
if(new_program->identifier_references[n].inherit_offset == 0)
{
my_yyerror("Identifier '%s' defined twice.",name->str);
return n;
}
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | if (IDENTIFIERP(n)->id_flags & ID_NOMASK)
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine 'nomask/final' variable/functions \"%s\"", name->str);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | | if(!(IDENTIFIERP(n)->id_flags & ID_INLINE) || compiler_pass!=1)
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | {
if(ID_FROM_INT(new_program, n)->type != type)
my_yyerror("Illegal to redefine inherited variable with different type.");
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
if(!IDENTIFIER_IS_VARIABLE(ID_FROM_INT(new_program, n)->identifier_flags))
{
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine inherited variable with different type.");
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | }
IDENTIFIERP(n)->id_flags = flags;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | return n;
}
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | run_time_type=compile_type_to_runtime_type(type);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | switch(run_time_type)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | case T_FUNCTION:
case T_PROGRAM:
run_time_type = T_MIXED;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | |
n=low_define_variable(name,type,flags,
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | low_add_storage(sizeof_variable(run_time_type),
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | alignof_variable(run_time_type),0),
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | run_time_type);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
return n;
}
|
574088 | 1998-01-01 | Fredrik Hübinette (Hubbe) | | int simple_add_variable(char *name,
char *type,
INT32 flags)
{
INT32 ret;
struct pike_string *name_s, *type_s;
name_s=make_shared_string(name);
type_s=parse_type(type);
ret=define_variable(name_s, type_s, flags);
free_string(name_s);
free_string(type_s);
return ret;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | int add_constant(struct pike_string *name,
struct svalue *c,
INT32 flags)
{
int n;
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | | struct identifier dummy;
struct reference ref;
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(name!=debug_findstring(name))
|
e43ca2 | 1996-11-15 | Fredrik Hübinette (Hubbe) | | fatal("define_constant on nonshared string.\n");
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | #endif
n = isidentifier(name);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
if(new_program->flags & PROGRAM_PASS_1_DONE)
{
if(n==-1)
{
yyerror("Pass2: Constant disappeared!");
}else{
#if 1
struct identifier *id;
id=ID_FROM_INT(new_program,n);
if(id->func.offset>=0)
{
struct pike_string *s;
struct svalue *c=PROG_FROM_INT(new_program,n)->constants+
id->func.offset;
s=get_type_of_svalue(c);
free_string(id->type);
id->type=s;
}
#endif
return n;
}
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
fatal("Attempting to add constant to fixed program\n");
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | |
if(compiler_pass==2)
fatal("Internal error: Not allowed to add more identifiers during second compiler pass.\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | | copy_shared_string(dummy.name, name);
dummy.type = get_type_of_svalue(c);
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | dummy.identifier_flags = IDENTIFIER_CONSTANT;
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | | dummy.run_time_type=c->type;
dummy.func.offset=store_constant(c, 0);
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | ref.id_flags=flags;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | ref.identifier_offset=new_program->num_identifiers;
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | | ref.inherit_offset=0;
|
a2a880 | 1998-03-18 | Per Hedbor | | #ifdef PROFILING
|
618963 | 1998-11-12 | Fredrik Hübinette (Hubbe) | | dummy.self_time=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | dummy.num_calls=0;
|
a2a880 | 1998-03-18 | Per Hedbor | | dummy.total_time=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
add_to_identifiers(dummy);
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | |
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(n != -1)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(IDENTIFIERP(n)->id_flags & ID_NOMASK)
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine 'nomask' identifier \"%s\"", name->str);
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
if(new_program->identifier_references[n].inherit_offset == 0)
{
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | my_yyerror("Identifier '%s' defined twice.",name->str);
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | return n;
}
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | if(!(IDENTIFIERP(n)->id_flags & ID_INLINE))
{
new_program->identifier_references[n]=ref;
return n;
}
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | }
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | n=new_program->num_identifier_references;
add_to_identifier_references(ref);
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | |
return n;
}
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | int simple_add_constant(char *name,
struct svalue *c,
INT32 flags)
{
INT32 ret;
struct pike_string *id;
id=make_shared_string(name);
ret=add_constant(id, c, flags);
free_string(id);
return ret;
}
|
e43ca2 | 1996-11-15 | Fredrik Hübinette (Hubbe) | | int add_integer_constant(char *name,
INT32 i,
INT32 flags)
{
struct svalue tmp;
tmp.u.integer=i;
tmp.type=T_INT;
tmp.subtype=NUMBER_NUMBER;
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | return simple_add_constant(name, &tmp, flags);
|
e43ca2 | 1996-11-15 | Fredrik Hübinette (Hubbe) | | }
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | int quick_add_integer_constant(char *name,
int name_length,
INT32 i,
INT32 flags)
{
struct svalue tmp;
struct pike_string *id;
INT32 ret;
tmp.u.integer=i;
tmp.type=T_INT;
tmp.subtype=NUMBER_NUMBER;
id=make_shared_binary_string(name,name_length);
ret=add_constant(id, &tmp, flags);
free_string(id);
return ret;
}
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | int add_float_constant(char *name,
double f,
INT32 flags)
{
struct svalue tmp;
tmp.type=T_FLOAT;
tmp.u.float_number=f;
tmp.subtype=0;
return simple_add_constant(name, &tmp, flags);
}
int add_string_constant(char *name,
char *str,
INT32 flags)
{
INT32 ret;
struct svalue tmp;
tmp.type=T_STRING;
tmp.subtype=0;
tmp.u.string=make_shared_string(str);
ret=simple_add_constant(name, &tmp, flags);
free_svalue(&tmp);
return ret;
}
|
e43ca2 | 1996-11-15 | Fredrik Hübinette (Hubbe) | |
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | int add_program_constant(char *name,
struct program *p,
INT32 flags)
{
INT32 ret;
struct svalue tmp;
tmp.type=T_PROGRAM;
tmp.subtype=0;
tmp.u.program=p;
ret=simple_add_constant(name, &tmp, flags);
return ret;
}
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | int add_object_constant(char *name,
struct object *o,
INT32 flags)
{
INT32 ret;
struct svalue tmp;
tmp.type=T_OBJECT;
tmp.subtype=0;
tmp.u.object=o;
ret=simple_add_constant(name, &tmp, flags);
return ret;
}
|
c15240 | 1997-02-10 | Fredrik Hübinette (Hubbe) | | int add_function_constant(char *name, void (*cfun)(INT32), char * type, INT16 flags)
{
struct svalue s;
struct pike_string *n;
INT32 ret;
s.type=T_FUNCTION;
s.subtype=FUNCTION_BUILTIN;
s.u.efun=make_callable(cfun, name, type, flags, 0, 0);
ret=simple_add_constant(name, &s, 0);
free_svalue(&s);
return ret;
}
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | int debug_end_class(char *name, int namelen, INT32 flags)
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | {
INT32 ret;
struct svalue tmp;
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | struct pike_string *id;
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | tmp.type=T_PROGRAM;
tmp.subtype=0;
tmp.u.program=end_program();
|
f839fa | 1997-02-28 | Fredrik Hübinette (Hubbe) | | if(!tmp.u.program)
fatal("Failed to initialize class '%s'\n",name);
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | |
id=make_shared_binary_string(name,namelen);
ret=add_constant(id, &tmp, flags);
free_string(id);
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | free_svalue(&tmp);
return ret;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | INT32 define_function(struct pike_string *name,
struct pike_string *type,
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | INT16 flags,
INT8 function_flags,
union idptr *func)
{
struct identifier *funp,fun;
struct reference ref;
INT32 i;
|
a2a880 | 1998-03-18 | Per Hedbor | | #ifdef PROFILING
|
618963 | 1998-11-12 | Fredrik Hübinette (Hubbe) | | fun.self_time=0;
|
a2a880 | 1998-03-18 | Per Hedbor | | fun.num_calls=0;
fun.total_time=0;
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | i=isidentifier(name);
if(i >= 0)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | funp=ID_FROM_INT(new_program, i);
ref=new_program->identifier_references[i];
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | if(ref.inherit_offset == 0)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | if( !( IDENTIFIER_IS_FUNCTION(funp->identifier_flags) &&
( (!func || func->offset == -1) || (funp->func.offset == -1))))
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | {
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | my_yyerror("Identifier '%s' defined twice.",name->str);
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | return i;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | if(!match_types(type, funp->type))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
my_yyerror("Prototype doesn't match for function %s.",name->str);
}
}
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | if(ref.inherit_offset==0)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | if(func)
funp->func = *func;
else
funp->func.offset = -1;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | funp->identifier_flags=function_flags;
}else{
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | if((ref.id_flags & ID_NOMASK)
#if 0
&& !(funp->func.offset == -1)
#endif
)
{
my_yyerror("Illegal to redefine 'nomask' function %s.",name->str);
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | | if(ref.id_flags & ID_INLINE)
{
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | goto make_a_new_def;
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | | }
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
copy_shared_string(fun.name, name);
copy_shared_string(fun.type, type);
fun.run_time_type=T_FUNCTION;
fun.identifier_flags=function_flags;
if(function_flags & IDENTIFIER_C_FUNCTION)
new_program->flags |= PROGRAM_HAS_C_METHODS;
if(func)
fun.func = *func;
else
fun.func.offset = -1;
ref.identifier_offset=new_program->num_identifiers;
add_to_identifiers(fun);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
ref.inherit_offset = 0;
ref.id_flags = flags;
new_program->identifier_references[i]=ref;
return i;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | make_a_new_def:
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | | if(compiler_pass==2)
fatal("Internal error: Not allowed to add more identifiers during second compiler pass.\n");
#endif
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | copy_shared_string(fun.name, name);
copy_shared_string(fun.type, type);
fun.identifier_flags=function_flags;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(function_flags & IDENTIFIER_C_FUNCTION)
new_program->flags |= PROGRAM_HAS_C_METHODS;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | |
fun.run_time_type=T_FUNCTION;
if(func)
fun.func = *func;
else
fun.func.offset = -1;
i=new_program->num_identifiers;
add_to_identifiers(fun);
ref.id_flags = flags;
ref.identifier_offset = i;
ref.inherit_offset = 0;
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | i=new_program->num_identifier_references;
add_to_identifier_references(ref);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return i;
}
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | int really_low_find_shared_string_identifier(struct pike_string *name,
struct program *prog,
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | int flags)
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | {
struct reference *funp;
struct identifier *fun;
int i,t;
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | CDFPRINTF((stderr,"th(%ld) Trying to find %s flags=%d\n",
(long)th_self(),name->str, flags));
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | |
|
5dbbf8 | 1999-07-01 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
if (!prog) {
fatal("really_low_find_shared_string_identifier(\"%s\", NULL, %d)\n"
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | "prog is NULL!\n", name->str, flags);
|
5dbbf8 | 1999-07-01 | Henrik Grubbström (Grubba) | | }
#endif /* PIKE_DEBUG */
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | for(i=0;i<(int)prog->num_identifier_references;i++)
{
funp = prog->identifier_references + i;
if(funp->id_flags & ID_HIDDEN) continue;
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | | if(funp->id_flags & ID_STATIC)
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | if(!(flags & SEE_STATIC))
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | continue;
fun = ID_FROM_PTR(prog, funp);
if(!is_same_string(fun->name,name)) continue;
if(funp->id_flags & ID_INHERITED)
{
if(funp->id_flags & ID_PRIVATE) continue;
for(t=0; t>=0 && t<(int)prog->num_identifier_references; t++)
{
struct reference *funpb;
struct identifier *funb;
if(t==i) continue;
funpb=prog->identifier_references+t;
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | | if(funpb->id_flags & ID_HIDDEN) continue;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | if(funpb->id_flags & ID_STATIC)
if(!(flags & SEE_STATIC))
continue;
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | if((funpb->id_flags & ID_INHERITED) && t<i) continue;
funb=ID_FROM_PTR(prog,funpb);
if(fun->name==funb->name) t=-10;
}
if(t < 0) continue;
}
return i;
}
return -1;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int low_find_shared_string_identifier(struct pike_string *name,
struct program *prog)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
int max,min,tst;
struct identifier *fun;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(prog->flags & PROGRAM_FIXED)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | unsigned short *funindex = prog->identifier_index;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!funindex)
fatal("No funindex in fixed program\n");
#endif
max = prog->num_identifier_index;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | min = 0;
while(max != min)
{
tst=(max + min) >> 1;
fun = ID_FROM_INT(prog, funindex[tst]);
if(is_same_string(fun->name,name)) return funindex[tst];
if(my_order_strcmp(fun->name, name) > 0)
max=tst;
else
min=tst+1;
}
}else{
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | return really_low_find_shared_string_identifier(name,prog,0);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
return -1;
}
#ifdef FIND_FUNCTION_HASHSIZE
#if FIND_FUNCTION_HASHSIZE == 0
#undef FIND_FUNCTION_HASHSIZE
#endif
#endif
#ifdef FIND_FUNCTION_HASHSIZE
struct ff_hash
{
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | struct pike_string *name;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | int id;
int fun;
};
static struct ff_hash cache[FIND_FUNCTION_HASHSIZE];
#endif
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | int find_shared_string_identifier(struct pike_string *name,
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct program *prog)
{
|
c55b91 | 1999-03-07 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
if (!prog) {
fatal("find_shared_string_identifier(): No program!\n"
"Identifier: %s%s%s\n",
name?"\"":"", name?name->str:"NULL", name?"\"":"");
}
#endif /* PIKE_DEBUG */
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #ifdef FIND_FUNCTION_HASHSIZE
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(prog -> flags & PROGRAM_FIXED)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
unsigned int hashval;
hashval=my_hash_string(name);
hashval+=prog->id;
|
f90e54 | 1995-08-17 | Fredrik Hübinette (Hubbe) | | hashval^=(unsigned long)prog;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | hashval-=name->str[0];
hashval%=FIND_FUNCTION_HASHSIZE;
if(is_same_string(cache[hashval].name,name) &&
cache[hashval].id==prog->id)
return cache[hashval].fun;
if(cache[hashval].name) free_string(cache[hashval].name);
copy_shared_string(cache[hashval].name,name);
cache[hashval].id=prog->id;
return cache[hashval].fun=low_find_shared_string_identifier(name,prog);
}
#endif /* FIND_FUNCTION_HASHSIZE */
return low_find_shared_string_identifier(name,prog);
}
int find_identifier(char *name,struct program *prog)
{
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | struct pike_string *n;
|
0b9d1c | 1998-05-15 | Henrik Grubbström (Grubba) | | if(!prog) {
if (strlen(name) < 1024) {
error("Lookup of identifier %s in destructed object.\n", name);
} else {
error("Lookup of long identifier in destructed object.\n");
}
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | n=findstring(name);
if(!n) return -1;
return find_shared_string_identifier(n,prog);
}
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | int store_prog_string(struct pike_string *str)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
unsigned int i;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for (i=0;i<new_program->num_strings;i++)
if (new_program->strings[i] == str)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return i;
reference_shared_string(str);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_strings(str);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return i;
}
|
5683de | 1995-11-06 | Fredrik Hübinette (Hubbe) | | int store_constant(struct svalue *foo, int equal)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct svalue tmp;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | unsigned int e;
|
5683de | 1995-11-06 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(e=0;e<new_program->num_constants;e++)
{
struct svalue *s=new_program->constants + e;
if(equal ? is_equal(s,foo) : is_eq(s,foo))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return e;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
assign_svalue_no_free(&tmp,foo);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_constants(tmp);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return e;
}
|
a36d82 | 1998-05-25 | Henrik Grubbström (Grubba) | |
struct array *program_indices(struct program *p)
{
int e;
int n = 0;
struct array *res;
for (e = p->num_identifier_references; e--; ) {
struct identifier *id;
if (p->identifier_references[e].id_flags & ID_HIDDEN) {
continue;
}
id = ID_FROM_INT(p, e);
if (IDENTIFIER_IS_CONSTANT(id->identifier_flags)) {
ref_push_string(ID_FROM_INT(p, e)->name);
n++;
}
}
f_aggregate(n);
res = sp[-1].u.array;
add_ref(res);
pop_stack();
return(res);
}
struct array *program_values(struct program *p)
{
int e;
int n = 0;
struct array *res;
for(e = p->num_identifier_references; e--; ) {
struct identifier *id;
if (p->identifier_references[e].id_flags & ID_HIDDEN) {
continue;
}
id = ID_FROM_INT(p, e);
if (IDENTIFIER_IS_CONSTANT(id->identifier_flags)) {
struct program *p2 = PROG_FROM_INT(p, e);
push_svalue(p2->constants + id->func.offset);
n++;
}
}
f_aggregate(n);
res = sp[-1].u.array;
add_ref(res);
pop_stack();
return(res);
}
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | void program_index_no_free(struct svalue *to, struct program *p,
struct svalue *ind)
{
int e;
struct pike_string *s;
if (ind->type != T_STRING) {
error("Can't index a program with a %s (expected string)\n",
get_name_of_type(ind->type));
}
s = ind->u.string;
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | #if 0
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | for (e = p->num_identifier_references; e--; ) {
struct identifier *id;
if (p->identifier_references[e].id_flags & ID_HIDDEN) {
continue;
}
id = ID_FROM_INT(p, e);
if (id->name != s) {
continue;
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
#else
e=find_shared_string_identifier(s, p);
if(e!=-1)
{
struct identifier *id;
id=ID_FROM_INT(p, e);
#endif
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | if (IDENTIFIER_IS_CONSTANT(id->identifier_flags)) {
struct program *p2 = PROG_FROM_INT(p, e);
|
a6850e | 1998-05-25 | Henrik Grubbström (Grubba) | | assign_svalue_no_free(to, (p2->constants + id->func.offset));
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | return;
} else {
if (s->len < 1024) {
|
60fbcb | 1999-05-01 | Henrik Grubbström (Grubba) | | error("Index \"%s\" is not constant.\n", s->str);
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | } else {
|
60fbcb | 1999-05-01 | Henrik Grubbström (Grubba) | | error("Index is not constant.\n");
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
}
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
#if 1
to->type=T_INT;
to->subtype=NUMBER_UNDEFINED;
to->u.integer=0;
#else
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | if (s->len < 1024) {
|
60fbcb | 1999-05-01 | Henrik Grubbström (Grubba) | | error("No such index \"%s\".\n", s->str);
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | } else {
|
60fbcb | 1999-05-01 | Henrik Grubbström (Grubba) | | error("No such index.\n");
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | #endif
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
static int get_small_number(char **q)
{
int ret;
switch(ret=(*(signed char **)q)++[0])
{
case -127:
ret=EXTRACT_WORD((unsigned char*)*q);
*q+=2;
return ret;
case -128:
ret=EXTRACT_INT((unsigned char*)*q);
*q+=4;
return ret;
default:
return ret;
}
}
void start_line_numbering(void)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(last_file)
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | | {
free_string(last_file);
last_file=0;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | last_pc=last_line=0;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | static void insert_small_number(INT32 a)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
if(a>-127 && a<127)
{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(a);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }else if(a>=-32768 && a<32768){
|
aeeef3 | 1998-01-16 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(-127);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | ins_short(a, add_to_linenumbers);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }else{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(-128);
ins_int(a, add_to_linenumbers);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
}
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | void store_linenumber(INT32 current_line, struct pike_string *current_file)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
if(last_line!=current_line || last_file != current_file)
{
if(last_file != current_file)
{
char *tmp;
if(last_file) free_string(last_file);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(127);
for(tmp=current_file->str; *tmp; tmp++)
add_to_linenumbers(*tmp);
add_to_linenumbers(0);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | copy_shared_string(last_file, current_file);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | insert_small_number(PC-last_pc);
insert_small_number(current_line-last_line);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | last_line=current_line;
last_pc=PC;
}
}
char *get_line(unsigned char *pc,struct program *prog,INT32 *linep)
{
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | static char *file, *cnt;
static INT32 off,line,pid;
INT32 offset;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
5683de | 1995-11-06 | Fredrik Hübinette (Hubbe) | | if (prog == 0) return "Unkown program";
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | offset = pc - prog->program;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(prog == new_program)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
linep[0]=0;
return "Optimizer";
}
|
45f993 | 1998-04-28 | Fredrik Hübinette (Hubbe) | | #if 0
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | if(prog->id != pid || offset < off)
|
45f993 | 1998-04-28 | Fredrik Hübinette (Hubbe) | | #endif
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | {
cnt=prog->linenumbers;
off=line=0;
file="Line not found";
pid=prog->id;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if (offset > (INT32)prog->num_program || offset<0)
return file;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | while(cnt < prog->linenumbers + prog->num_linenumbers)
{
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | int oline;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(*cnt == 127)
{
file=cnt+1;
cnt=file+strlen(file)+1;
}
off+=get_small_number(&cnt);
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | oline=line;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | line+=get_small_number(&cnt);
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | if(off > offset)
{
linep[0]=oline;
return file;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
linep[0]=line;
return file;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void my_yyerror(char *fmt,...) ATTRIBUTE((format(printf,1,2)))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
va_list args;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | char buf[8192];
|
52cf14 | 1998-05-15 | Henrik Grubbström (Grubba) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | va_start(args,fmt);
|
52cf14 | 1998-05-15 | Henrik Grubbström (Grubba) | |
#ifdef HAVE_VSNPRINTF
vsnprintf(buf, 8190, fmt, args);
#else /* !HAVE_VSNPRINTF */
VSPRINTF(buf, fmt, args);
#endif /* HAVE_VSNPRINTF */
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
197d17 | 1996-05-16 | Fredrik Hübinette (Hubbe) | | if((long)strlen(buf) >= (long)sizeof(buf))
|
8780ce | 1998-04-19 | Per Hedbor | | fatal("Buffer overflow in my_yyerror.\n");
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
yyerror(buf);
va_end(args);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *compile(struct pike_string *prog)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | JMP_BUF tmp;
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct program *p;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct lex save_lex;
int save_depth=compilation_depth;
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | int saved_threads_disabled;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | dynamic_buffer used_modules_save = used_modules;
INT32 num_used_modules_save = num_used_modules;
|
acbf0a | 1999-02-20 | Henrik Grubbström (Grubba) | | extern void yyparse(void);
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | |
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | CDFPRINTF((stderr, "th(%ld) compile() starting compilation_depth=%d\n",
(long)th_self(),compilation_depth));
low_init_threads_disable();
saved_threads_disabled = threads_disabled;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | if(SETJMP(tmp))
fatal("Compiler exited with longjump!\n");
#endif
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | num_used_modules=0;
initialize_buf(&used_modules);
{
struct svalue tmp;
tmp.type=T_MAPPING;
#ifdef __CHECKER__
tmp.subtype=0;
#endif /* __CHECKER__ */
tmp.u.mapping=get_builtin_constants();
use_module(& tmp);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | save_lex=lex;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
acbf0a | 1999-02-20 | Henrik Grubbström (Grubba) | | lex.end = prog->str + (prog->len << prog->size_shift);
switch(prog->size_shift) {
case 0:
lex.current_lexer = yylex0;
break;
case 1:
lex.current_lexer = yylex1;
break;
case 2:
lex.current_lexer = yylex2;
break;
default:
fatal("Program has bad shift %d!\n", prog->size_shift);
break;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | lex.current_line=1;
lex.current_file=make_shared_string("-");
lex.pragmas=0;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
bcd574 | 1999-03-17 | Fredrik Hübinette (Hubbe) | | low_start_new_program(0,0,0);
if(lex.current_file)
store_linenumber(last_pc, lex.current_file);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compilation_depth=0;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
45f993 | 1998-04-28 | Fredrik Hübinette (Hubbe) | |
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compiler_pass=1;
lex.pos=prog->str;
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | |
|
f06a82 | 1999-07-02 | Henrik Grubbström (Grubba) | | CDFPRINTF((stderr, "compile(): First pass\n"));
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | yyparse();
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | p=end_first_pass(0);
if(p && !num_parse_error)
{
|
76fb83 | 1999-07-01 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
if (compilation_depth != -1) {
fprintf(stderr, "compile(): compilation_depth is %d at end of pass 1.\n",
compilation_depth);
}
#endif /* PIKE_DEBUG */
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | low_start_new_program(p,0,0);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | free_program(p);
p=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compiler_pass=2;
lex.pos=prog->str;
|
f06a82 | 1999-07-02 | Henrik Grubbström (Grubba) | |
CDFPRINTF((stderr, "compile(): Second pass\n"));
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | yyparse();
p=end_program();
}
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | if (threads_disabled != saved_threads_disabled) {
|
4751d4 | 1998-04-14 | Henrik Grubbström (Grubba) | | fatal("compile(): threads_disabled:%d saved_threads_disabled:%d\n",
threads_disabled, saved_threads_disabled);
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #endif /* PIKE_DEBUG */
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | |
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | |
CDFPRINTF((stderr,
|
e0837a | 1999-07-01 | Fredrik Hübinette (Hubbe) | | "th(%ld) compile() Leave: threads_disabled:%d, compilation_depth:%d\n",
(long)th_self(),threads_disabled, compilation_depth));
|
a91ca0 | 1998-07-10 | Henrik Grubbström (Grubba) | |
exit_threads_disable(NULL);
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | free_string(lex.current_file);
lex=save_lex;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | unuse_modules(1);
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(num_used_modules)
fatal("Failed to pop modules properly.\n");
#endif
toss_buffer(&used_modules);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | compilation_depth=save_depth;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | used_modules = used_modules_save;
num_used_modules = num_used_modules_save ;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | UNSETJMP(tmp);
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(!p) error("Compilation failed.\n");
return p;
}
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | int add_function(char *name,void (*cfun)(INT32),char *type,INT16 flags)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | int ret;
|
06983f | 1996-09-22 | Fredrik Hübinette (Hubbe) | | struct pike_string *name_tmp,*type_tmp;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | union idptr tmp;
name_tmp=make_shared_string(name);
type_tmp=parse_type(type);
if(cfun)
{
tmp.c_fun=cfun;
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | ret=define_function(name_tmp,
type_tmp,
flags,
IDENTIFIER_C_FUNCTION,
&tmp);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }else{
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | ret=define_function(name_tmp,
type_tmp,
flags,
IDENTIFIER_C_FUNCTION,
0);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
free_string(name_tmp);
free_string(type_tmp);
|
e964ae | 1998-04-08 | Fredrik Hübinette (Hubbe) | | return ret;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | int quick_add_function(char *name,
int name_length,
void (*cfun)(INT32),
char *type,
int type_length,
INT16 flags,
int opt_flags)
{
int ret;
struct pike_string *name_tmp,*type_tmp;
union idptr tmp;
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | name_tmp=make_shared_binary_string(name,name_length);
type_tmp=make_shared_binary_string(type,type_length);
if(cfun)
{
tmp.c_fun=cfun;
ret=define_function(name_tmp,
type_tmp,
flags,
IDENTIFIER_C_FUNCTION,
&tmp);
}else{
ret=define_function(name_tmp,
type_tmp,
flags,
IDENTIFIER_C_FUNCTION,
0);
}
free_string(name_tmp);
free_string(type_tmp);
return ret;
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | void check_all_programs(void)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
struct program *p;
for(p=first_program;p;p=p->next)
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | check_program(p);
|
5d0e21 | 1997-04-10 | Fredrik Hübinette (Hubbe) | |
#ifdef FIND_FUNCTION_HASHSIZE
{
unsigned long e;
for(e=0;e<FIND_FUNCTION_HASHSIZE;e++)
{
if(cache[e].name)
{
check_string(cache[e].name);
if(cache[e].id<0 || cache[e].id > current_program_id)
|
1f6435 | 1997-04-14 | Fredrik Hübinette (Hubbe) | | fatal("Error in find_function_cache[%ld].id\n",(long)e);
|
5d0e21 | 1997-04-10 | Fredrik Hübinette (Hubbe) | |
|
d2a084 | 1997-04-10 | Fredrik Hübinette (Hubbe) | | if(cache[e].fun < -1 || cache[e].fun > 65536)
|
1f6435 | 1997-04-14 | Fredrik Hübinette (Hubbe) | | fatal("Error in find_function_cache[%ld].fun\n",(long)e);
|
5d0e21 | 1997-04-10 | Fredrik Hübinette (Hubbe) | | }
}
}
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
#endif
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | #undef THIS
#define THIS ((struct pike_trampoline *)(fp->current_storage))
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | struct program *pike_trampoline_program=0;
static void apply_trampoline(INT32 args)
{
error("Internal error: Trampoline magic failed!\n");
}
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | static void init_trampoline(struct object *o)
{
THIS->frame=0;
}
static void exit_trampoline(struct object *o)
{
if(THIS->frame)
{
free_pike_frame(THIS->frame);
THIS->frame=0;
}
}
static void gc_check_frame(struct pike_frame *f)
{
if(!f) return;
if(!debug_gc_check(f,T_UNKNOWN,f) && f->malloced_locals)
{
if(f->current_object) gc_check(f->current_object);
if(f->context.prog) gc_check(f->context.prog);
if(f->context.parent) gc_check(f->context.parent);
gc_check_svalues(f->locals,f->num_locals);
if(f->scope) gc_check_frame(f->scope);
}
}
static void gc_check_trampoline(struct object *o)
{
gc_check_frame(THIS->frame);
}
static void gc_mark_frame(struct pike_frame *f)
{
if(!f) return;
if(gc_mark(f))
{
if(f->current_object) gc_mark_object_as_referenced(f->current_object);
if(f->context.prog) gc_mark_program_as_referenced(f->context.prog);
if(f->context.parent) gc_mark_object_as_referenced(f->context.parent);
if(f->malloced_locals)gc_mark_svalues(f->locals,f->num_locals);
if(f->scope) gc_mark_frame(f->scope);
}
}
static void gc_mark_trampoline(struct object *o)
{
gc_mark_frame(THIS->frame);
}
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | void init_program(void)
{
start_new_program();
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | ADD_STORAGE(struct pike_trampoline);
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | add_function("`()",apply_trampoline,"function(mixed...:mixed)",0);
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | set_init_callback(init_trampoline);
set_exit_callback(exit_trampoline);
set_gc_check_callback(gc_check_trampoline);
set_gc_mark_callback(gc_mark_trampoline);
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | pike_trampoline_program=end_program();
}
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | void cleanup_program(void)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
int e;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | #ifdef FIND_FUNCTION_HASHSIZE
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | for(e=0;e<FIND_FUNCTION_HASHSIZE;e++)
{
if(cache[e].name)
{
free_string(cache[e].name);
cache[e].name=0;
}
}
#endif
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
#ifdef DO_PIKE_CLEANUP
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(resolve_cache)
{
free_mapping(resolve_cache);
resolve_cache=0;
}
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
if(pike_trampoline_program)
{
free_program(pike_trampoline_program);
pike_trampoline_program=0;
}
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | #endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #ifdef GC2
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | void gc_mark_program_as_referenced(struct program *p)
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | {
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | if(gc_mark(p))
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
int e;
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | gc_mark_svalues(p->constants, p->num_constants);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
for(e=0;e<p->num_inherits;e++)
{
if(p->inherits[e].parent)
gc_mark_object_as_referenced(p->inherits[e].parent);
|
6be8a8 | 1998-10-22 | Fredrik Hübinette (Hubbe) | | if(e && p->inherits[e].prog)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | gc_mark_program_as_referenced(p->inherits[e].prog);
}
}
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | }
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | void gc_check_all_programs(void)
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | {
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | struct program *p;
for(p=first_program;p;p=p->next)
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int e;
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check_svalues(p->constants, p->num_constants, T_PROGRAM, p);
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(e=0;e<p->num_inherits;e++)
{
if(p->inherits[e].parent)
{
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | if(debug_gc_check(p->inherits[e].parent,T_PROGRAM,p)==-2)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"(program at 0x%lx -> inherit[%d].parent)\n",
(long)p,
e);
#else
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check(p->inherits[e].parent, T_PROGRAM, p);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
}
if(d_flag && p->inherits[e].name)
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check(p->inherits[e].name, T_PROGRAM, p);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
6be8a8 | 1998-10-22 | Fredrik Hübinette (Hubbe) | | if(e && p->inherits[e].prog)
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check(p->inherits[e].prog, T_PROGRAM, p);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | | if(d_flag)
{
int e;
for(e=0;e<(int)p->num_strings;e++)
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check(p->strings[e], T_PROGRAM, p);
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | |
for(e=0;e<(int)p->num_identifiers;e++)
{
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | debug_gc_check(p->identifiers[e].name, T_PROGRAM, p);
debug_gc_check(p->identifiers[e].type, T_PROGRAM, p);
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | | }
}
|
0b6944 | 1998-01-19 | Fredrik Hübinette (Hubbe) | | #endif
|
936735 | 1997-01-27 | Fredrik Hübinette (Hubbe) | | }
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | }
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | void gc_mark_all_programs(void)
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | {
struct program *p;
for(p=first_program;p;p=p->next)
if(gc_is_referenced(p))
gc_mark_program_as_referenced(p);
}
|
be478c | 1997-08-30 | Henrik Grubbström (Grubba) | | void gc_free_all_unreferenced_programs(void)
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | {
struct program *p,*next;
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | for(p=first_program;p;p=next)
{
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | if(gc_do_free(p))
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int e;
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(p);
|
c94c37 | 1996-03-28 | Fredrik Hübinette (Hubbe) | | free_svalues(p->constants, p->num_constants, -1);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(e=0;e<p->num_inherits;e++)
{
if(p->inherits[e].parent)
{
free_object(p->inherits[e].parent);
p->inherits[e].parent=0;
}
}
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | next=p->next;
free_program(p);
}else{
next=p->next;
}
}
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif /* GC2 */
|
c3c703 | 1996-12-04 | Fredrik Hübinette (Hubbe) | |
void count_memory_in_programs(INT32 *num_, INT32 *size_)
{
INT32 size=0, num=0;
struct program *p;
for(p=first_program;p;p=p->next)
{
num++;
size+=p->total_size;
}
*num_=num;
*size_=size;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | void push_compiler_frame(int lexical_scope)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
struct compiler_frame *f;
f=ALLOC_STRUCT(compiler_frame);
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | f->lexical_scope=lexical_scope;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | f->current_type=0;
f->current_return_type=0;
f->current_number_of_locals=0;
f->max_number_of_locals=0;
f->previous=compiler_frame;
compiler_frame=f;
}
void pop_local_variables(int level)
|
329cc0 | 1997-02-17 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | while(compiler_frame->current_number_of_locals > level)
{
int e;
e=--(compiler_frame->current_number_of_locals);
free_string(compiler_frame->variable[e].name);
free_string(compiler_frame->variable[e].type);
}
|
329cc0 | 1997-02-17 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
void pop_compiler_frame(void)
|
329cc0 | 1997-02-17 | Fredrik Hübinette (Hubbe) | | {
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct compiler_frame *f;
int e;
f=compiler_frame;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!f)
fatal("Popping out of compiler frames\n");
#endif
|
329cc0 | 1997-02-17 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | pop_local_variables(0);
if(f->current_type)
free_string(f->current_type);
if(f->current_return_type)
free_string(f->current_return_type);
compiler_frame=f->previous;
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree((char *)f);
|
329cc0 | 1997-02-17 | Fredrik Hübinette (Hubbe) | | }
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | |
#define GET_STORAGE_CACHE_SIZE 1024
static struct get_storage_cache
{
INT32 oid, pid, offset;
} get_storage_cache[GET_STORAGE_CACHE_SIZE];
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | int low_get_storage(struct program *o, struct program *p)
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | {
INT32 oid,pid, offset;
unsigned INT32 hval;
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | if(!o) return 0;
oid=o->id;
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | pid=p->id;
|
535d17 | 1997-09-11 | Fredrik Hübinette (Hubbe) | | hval=oid*9248339 + pid;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | hval%=GET_STORAGE_CACHE_SIZE;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
535d17 | 1997-09-11 | Fredrik Hübinette (Hubbe) | | if(hval>GET_STORAGE_CACHE_SIZE)
fatal("hval>GET_STORAGE_CACHE_SIZE");
#endif
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | if(get_storage_cache[hval].oid == oid &&
get_storage_cache[hval].pid == pid)
{
offset=get_storage_cache[hval].offset;
}else{
INT32 e;
offset=-1;
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | for(e=0;e<o->num_inherits;e++)
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | {
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | if(o->inherits[e].prog==p)
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | {
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | offset=o->inherits[e].storage_offset;
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | break;
}
}
get_storage_cache[hval].oid=oid;
get_storage_cache[hval].pid=pid;
get_storage_cache[hval].offset=offset;
}
|
6bc928 | 1998-04-10 | Fredrik Hübinette (Hubbe) | | return offset;
}
char *get_storage(struct object *o, struct program *p)
{
int offset= low_get_storage(o->prog, p);
|
cff0d7 | 1997-03-23 | Fredrik Hübinette (Hubbe) | | if(offset == -1) return 0;
return o->storage + offset;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
struct program *low_program_from_function(struct program *p,
INT32 i)
{
struct svalue *f;
struct identifier *id=ID_FROM_INT(p, i);
if(!IDENTIFIER_IS_CONSTANT(id->identifier_flags)) return 0;
if(id->func.offset==-1) return 0;
f=PROG_FROM_INT(p,i)->constants + id->func.offset;
if(f->type!=T_PROGRAM) return 0;
return f->u.program;
}
struct program *program_from_function(struct svalue *f)
{
struct identifier *id;
if(f->type != T_FUNCTION) return 0;
if(f->subtype == FUNCTION_BUILTIN) return 0;
if(!f->u.object->prog) return 0;
return low_program_from_function(f->u.object->prog, f->subtype);
}
struct program *program_from_svalue(struct svalue *s)
{
switch(s->type)
{
|
bcf946 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | case T_OBJECT:
{
struct program *p;
push_svalue(s);
f_object_program(1);
p=program_from_svalue(sp-1);
pop_stack();
return p;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | case T_FUNCTION:
return program_from_function(s);
case T_PROGRAM:
return s->u.program;
default:
return 0;
}
}
#define FIND_CHILD_HASHSIZE 5003
struct find_child_cache_s
{
INT32 pid,cid,id;
};
static struct find_child_cache_s find_child_cache[FIND_CHILD_HASHSIZE];
int find_child(struct program *parent, struct program *child)
{
|
939b18 | 1998-07-17 | Fredrik Hübinette (Hubbe) | | unsigned INT32 h=(parent->id * 9248339 + child->id);
h= h % FIND_CHILD_HASHSIZE;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
939b18 | 1998-07-17 | Fredrik Hübinette (Hubbe) | | if(h>=FIND_CHILD_HASHSIZE)
fatal("find_child failed to hash within boundaries.\n");
#endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(find_child_cache[h].pid == parent->id &&
find_child_cache[h].cid == child->id)
{
return find_child_cache[h].id;
}else{
INT32 i;
for(i=0;i<parent->num_identifier_references;i++)
{
if(low_program_from_function(parent, i)==child)
{
find_child_cache[h].pid=parent->id;
find_child_cache[h].cid=child->id;
find_child_cache[h].id=i;
return i;
}
}
}
return -1;
}
void yywarning(char *fmt, ...) ATTRIBUTE((format(printf,1,2)))
{
char buf[4711];
va_list args;
va_start(args,fmt);
VSPRINTF(buf, fmt, args);
va_end(args);
if(strlen(buf)>sizeof(buf))
fatal("Buffer overfloat in yywarning!\n");
if(get_master())
{
ref_push_string(lex.current_file);
push_int(lex.current_line);
push_text(buf);
SAFE_APPLY_MASTER("compile_warning",3);
pop_stack();
}
}
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | |
static int low_implements(struct program *a, struct program *b)
{
int e,num=0;
struct pike_string *s=findstring("__INIT");
for(e=0;e<b->num_identifier_references;e++)
{
struct identifier *bid=ID_FROM_INT(b,e);
int i;
if(s==bid->name) continue;
i=find_shared_string_identifier(bid->name,a);
if(i!=-1)
{
if(!match_types(ID_FROM_INT(a,i)->type, bid->type))
return 0;
num++;
}
}
return num;
}
#define IMPLEMENTS_CACHE_SIZE 4711
struct implements_cache_s { INT32 aid, bid, ret; };
static struct implements_cache_s implements_cache[IMPLEMENTS_CACHE_SIZE];
int implements(struct program *a, struct program *b)
{
unsigned long hval;
if(!a || !b) return -1;
if(a==b) return 1;
|
636e47 | 1998-04-15 | Fredrik Hübinette (Hubbe) | |
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | hval = a->id*9248339 + b->id;
hval %= IMPLEMENTS_CACHE_SIZE;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
939b18 | 1998-07-17 | Fredrik Hübinette (Hubbe) | | if(hval >= IMPLEMENTS_CACHE_SIZE)
fatal("Implements_cache failed!\n");
#endif
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | if(implements_cache[hval].aid==a->id && implements_cache[hval].bid==b->id)
{
return implements_cache[hval].ret;
}
implements_cache[hval].aid=a->id;
implements_cache[hval].bid=b->id;
|
636e47 | 1998-04-15 | Fredrik Hübinette (Hubbe) | | implements_cache[hval].ret=low_implements(a,b);
return implements_cache[hval].ret;
|
0ee27b | 1998-04-14 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|