e576bb | 2002-10-11 | Martin Nilsson | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | || $Id: program.c,v 1.532 2003/11/10 01:42:33 mast Exp $
|
e576bb | 2002-10-11 | Martin Nilsson | | */
|
aedfb1 | 2002-10-09 | Martin Nilsson | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "global.h"
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | RCSID("$Id: program.c,v 1.532 2003/11/10 01:42:33 mast 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"
|
b2d3e4 | 2000-12-01 | Fredrik Hübinette (Hubbe) | | #include "pike_error.h"
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include "docode.h"
#include "interpret.h"
#include "hashtable.h"
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #include "main.h"
|
9173f7 | 2002-11-25 | Martin Stjernholm | | #include "pike_memory.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"
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | #include "pike_types.h"
|
f76b4c | 2000-05-11 | Henrik Grubbström (Grubba) | | #include "opcodes.h"
|
ac8715 | 2000-09-25 | Fredrik Hübinette (Hubbe) | | #include "version.h"
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | #include "block_alloc.h"
|
0e0cd7 | 2001-07-20 | Henrik Grubbström (Grubba) | | #include "pikecode.h"
|
8aeeb2 | 1996-11-19 | Fredrik Hübinette (Hubbe) | |
#include <errno.h>
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #include <fcntl.h>
|
6ad237 | 2002-05-11 | Martin Nilsson | | #define sp Pike_sp
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
#undef ATTRIBUTE
#define ATTRIBUTE(X)
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | static void exit_program_struct(struct program *);
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | static size_t add_xstorage(size_t size,
size_t alignment,
ptrdiff_t modulo_orig);
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | |
#undef EXIT_BLOCK
#define EXIT_BLOCK(P) exit_program_struct( (P) )
#undef COUNT_OTHER
#define COUNT_OTHER() do{ \
struct program *p; \
for(p=first_program;p;p=p->next) \
{ \
size+=p->total_size; \
} \
}while(0)
|
3aab37 | 2002-11-24 | Martin Stjernholm | | BLOCK_ALLOC_FILL_PAGES(program, 4)
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
1549c6 | 1999-07-02 | Henrik Grubbström (Grubba) | |
|
a78643 | 1999-11-18 | Martin Stjernholm | |
|
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) | | |
5985c1 | 2000-10-25 | Fredrik Hübinette (Hubbe) | | * These two values should probably be fine-tuned, but doing so
* more or less requires running a predictable 'typical' application
* and testing different hashsizes and tresholds. I tried to do it
* mathematically by measuring the extremes (no cache hits, 100%
* cache hits etc.) but it seems that the processor cache becomes
* exhausted in some of my measurements, which renders my mathematical
* model useless.
*
* Further measurements seems to indicate that this cache can slow
* things down a bit if the hit/miss rate is not fairly high.
* For normal applications, the hitrate is most likely well over 90%,
* but that should be verified.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | * - Holistiska Centralbyrån (Hubbe)
|
189fd0 | 1997-01-28 | Fredrik Hübinette (Hubbe) | | */
|
5985c1 | 2000-10-25 | Fredrik Hübinette (Hubbe) | |
#define FIND_FUNCTION_HASHSIZE 15013
#define FIND_FUNCTION_HASH_TRESHOLD 9
|
189fd0 | 1997-01-28 | Fredrik Hübinette (Hubbe) | |
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | #define DECLARE
#include "compilation.h"
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
0ee38f | 2002-05-11 | Martin Stjernholm | | struct pike_string *this_program_string = NULL, *this_string = NULL;
|
e8d37d | 2002-02-14 | Henrik Grubbström (Grubba) | | static struct pike_string *UNDEFINED_string=0;
|
9e2686 | 1999-12-31 | Martin Stjernholm | |
|
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) | | "`+=",
|
aa73fc | 1999-10-21 | Fredrik Hübinette (Hubbe) | | "_is_type",
"_sprintf",
|
2ba919 | 1999-10-23 | Fredrik Hübinette (Hubbe) | | "_equal",
|
5b7424 | 2001-02-05 | Henrik Grubbström (Grubba) | | "_m_delete",
|
226d64 | 2001-02-24 | Henrik Grubbström (Grubba) | | "_get_iterator",
|
142c80 | 2003-09-04 | Henrik Grubbström (Grubba) | |
"_search",
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | | };
|
286afb | 2001-02-05 | Henrik Grubbström (Grubba) | | struct pike_string *lfun_strings[NELEM(lfun_names)];
static struct mapping *lfun_ids;
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | |
static struct mapping *lfun_types;
static char *raw_lfun_types[] = {
tFuncV(tNone,tVoid,tVoid),
tFuncV(tNone,tZero,tVoid),
tFuncV(tNone,tVoid,tVoid),
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | tFuncV(tZero,tZero,tMix),
tFunc(tOr(tVoid,tZero),tMix),
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tZero,tVoid,tMix),
tFuncV(tZero,tVoid,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tVoid,tMix),
tFuncV(tMix,tVoid,tInt),
tFuncV(tMix,tVoid,tInt),
tFuncV(tMix,tVoid,tInt),
tFuncV(tNone,tVoid,tInt),
tFuncV(tString,tVoid,tMix),
tFuncV(tNone,tVoid,tInt),
tFuncV(tZero,tVoid,tMix),
tFuncV(tZero tSetvar(0,tZero),tVoid,tVar(0)),
tFuncV(tStr,tVoid,tMix),
tFuncV(tStr tSetvar(0,tZero),tVoid,tVar(0)),
tFuncV(tNone,tVoid,tInt),
tFuncV(tNone,tVoid,tArray),
tFuncV(tNone,tVoid,tArray),
tFuncV(tNone,tZero,tMix),
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | tFuncV(tZero,tZero,tMix),
tFuncV(tZero,tVoid,tMix),
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tZero,tVoid,tMix),
tFuncV(tZero,tVoid,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
tFuncV(tNone,tZero,tMix),
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | tFuncV(tZero,tZero,tMix),
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | tFuncV(tStr,tVoid,tInt),
|
d8bfc0 | 1999-12-27 | Henrik Grubbström (Grubba) | | tFuncV(tInt tOr(tMap(tStr,tInt),tVoid),tVoid,tStr),
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | tFuncV(tMix,tVoid,tInt),
|
3cd748 | 2001-04-28 | Martin Stjernholm | | tFuncV(tZero,tVoid,tMix),
|
ef34d5 | 2001-02-24 | Henrik Grubbström (Grubba) | | tFuncV(tNone,tVoid,tObj),
|
142c80 | 2003-09-04 | Henrik Grubbström (Grubba) | |
tFuncV(tZero tOr(tZero, tVoid), tVoid, tMix),
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | };
|
47251d | 2002-12-11 | Henrik Grubbström (Grubba) | | |
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *!
*! Callback functions used to overload various builtin functions.
*!
*! The functions can be grouped into a few sets:
*!
*! @ul
*! @item
*! Object initialization and destruction.
*!
*! @[__INIT()], @[create()], @[destroy()]
*!
*! @item
*! Unary operator overloading.
*!
*! @[`~()], @[`!()],
*! @[_values()], @[cast()],
*! @[_sizeof()], @[_indices()],
*! @[__hash()]
*!
*! @item
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Binary asymmetric operator overloading.
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *!
*! @[`+()], @[``+()],
*! @[`-()], @[``-()],
*! @[`&()], @[``&()],
*! @[`|()], @[``|()],
*! @[`^()], @[``^()],
*! @[`<<()], @[``<<()],
*! @[`>>()], @[``>>()],
*! @[`*()], @[``*()],
*! @[`/()], @[``/()],
*! @[`%()], @[``%()]
*!
*! @item
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Binary symmetric operator overloading.
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *!
*! The optimizer will make assumptions about the relations
*! between these functions.
*!
*! @[`==()], @[_equal()], @[`<()], @[`>()]
*!
*! @item
*! Other binary operator overloading.
*!
*! @[`[]()], @[`[]=()], @[`->()],
*! @[`->=()], @[`+=()], @[`()()]
*!
*! @item
*! Overloading of other builtin functions.
*!
*! @[_is_type()], @[_sprintf()], @[_m_delete()],
|
142c80 | 2003-09-04 | Henrik Grubbström (Grubba) | | *! @[_get_iterator()], @[_search()]
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @endul
*!
*! @note
*! Although these functions are called from outside the object
*! they exist in, they will still be used even if they are
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! declared @expr{static@}. It is in fact recommended to declare
|
cbe8c9 | 2003-04-07 | Martin Nilsson | | *! them @expr{static@}, since that will hinder them being used
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! for other purposes.
*!
*! @seealso
*! @[::]
|
397e7d | 2001-10-28 | Martin Nilsson | | */
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Inherit and variable initialization.
*!
*! This function is generated automatically by the compiler. It's
*! called just before @[lfun::create()] when an object is
*! instantiated.
*!
*! It first calls any @expr{__INIT@} functions in inherited classes
*! (regardless of modifiers on the inherits). It then executes all
*! the variable initialization expressions in this class, in the
*! order they occur.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @note
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! This function can not be overloaded or blocked from executing.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
*! @[lfun::create()]
*/
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! Object creation callback.
*!
*! This function is called right after @[lfun::__INIT()].
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @[args] are the arguments passed when the program was called.
|
269dd9 | 2001-05-23 | Henrik Grubbström (Grubba) | | *!
*! @note
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! In Pike 7.2 and later this function can be created implicitly
*! by the compiler using the new syntax:
|
f79bd8 | 2003-04-01 | Martin Nilsson | | *! @code
*! class Foo(int foo) {
*! int bar;
*! }
*! @endcode
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! In the above case an implicit @[lfun::create()] is created, and
*! it's equvivalent to:
|
f79bd8 | 2003-04-01 | Martin Nilsson | | *! @code
*! class Foo {
*! int foo;
*! int bar;
*! static void create(int foo)
*! {
*! local::foo = foo;
*! }
*! }
*! @endcode
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
*! @[lfun::__INIT()], @[lfun::destroy()]
*/
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! Object destruction callback.
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! This function is called by @[predef::destruct()] right before it
*! zeroes all the object variables and destroys the object.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! @note
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Note that it's also called on implicit destruct, i.e. when there
*! are no more references to the object, or when the garbage
*! collector decides to destruct it.
*!
*! @note
*! Regarding destruction order during garbage collection:
*!
*! If an object is destructed by the garbage collector, it's part of
*! a reference cycle with other things but with no external
*! references. If there are other objects with @expr{destroy@}
*! functions in the same cycle, it becomes a problem which to call
*! first.
*!
*! E.g. if this object has a variable with another object which
*! (directly or indirectly) points back to this one, you might find
*! that the other object already has been destructed and the variable
*! thus contains zero.
*!
*! The garbage collector tries to minimize such problems by defining
*! an order as far as possible:
*!
*! @ul
*! @item
*! If an object A contains an @[lfun::destroy] and an object B does
*! not, then A is destructed before B.
*! @item
*! If A references B single way, then A is destructed before B.
*! @item
*! If A and B are in a cycle, and there is a reference somewhere
*! from B to A that is weaker than any reference from A to B, then
*! A is destructed before B.
*! @item
*! Weak references (e.g. set with @[set_weak_flag]) are considered
*! weaker than normal references, and both are considered weaker
*! than strong references.
*! @item
*! Strong references are those from objects to the objects of their
*! lexically surrounding classes. There can never be a cycle
*! consisting only of strong references. (This means the gc never
*! destructs a parent object before all children have been
*! destructed.)
*! @endul
*!
*! An example with well defined destruct order due to strong
*! references:
*!
*! @code
*! class Super {
*! class Sub {
*! static void destroy() {
*! if (!Super::this)
*! error ("My parent has been destructed!\n");
*! }
*! }
*! Sub sub = Sub();
*! static void destroy() {
*! if (!sub)
*! werror ("sub already destructed.\n");
*! }
*! }
*! @endcode
*!
*! The garbage collector ensures that these objects are destructed in
*! an order so that @expr{werror@} in @expr{Super@} is called and not
*! @expr{error@} in @expr{Sub@}.
*!
*! @note
*! When the garbage collector calls @[lfun::destroy], all accessible
*! non-objects and objects without @expr{destroy@} functions are
*! still intact. They are not freed if the @expr{destroy@} function
*! adds external references to them. However, all objects with
*! @[lfun::destroy] in the cycle are already scheduled for
*! destruction and are thus be destroyed even if external references
*! are added to them.
*!
*! @note
*! The garbage collector had completely random destruct order in
*! versions prior to 7.2.
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::create()], @[predef::destruct()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side addition/concatenation callback.
*!
*! This is used by @[predef::`+]. It's called with any arguments
*! that follow this object in the argument list of the call to
*! @[predef::`+]. The returned value should be a new instance that
*! represents the addition/concatenation between this object and
*! the arguments in the order they are given.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
5d9136 | 2003-04-18 | Martin Stjernholm | | *! @[lfun::``+()], @[lfun::`+=()], @[predef::`+()]
*/
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | |
5d9136 | 2003-04-18 | Martin Stjernholm | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Destructive addition/concatenation callback.
*!
*! This is used by @[predef::`+]. It's called with any arguments
*! that follow this object in the argument list of the call to
*! @[predef::`+]. It should update this object to represent the
*! addition/concatenation between it and the arguments in the order
*! they are given. It should always return this object.
|
5d9136 | 2003-04-18 | Martin Stjernholm | | *!
*! @note
*! This function should only be implemented if @[lfun::`+()] also
*! is. It should only work as a more optimized alternative to that
*! one, for the case when it's safe to change the object
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! destructively and use it directly as the result.
|
5d9136 | 2003-04-18 | Martin Stjernholm | | *!
*! @note
*! This function is not an lfun for the @expr{+=@} operator. It's
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! only whether or not it's safe to do a destructive change that
*! decides if this function or @[lfun::`+()] is called; both the
|
5d9136 | 2003-04-18 | Martin Stjernholm | | *! @expr{+@} operator and the @expr{+=@} operator can call either
*! one.
*!
*! @seealso
*! @[lfun::`+()], @[predef::`+()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
f0ace3 | 2003-11-10 | Martin Stjernholm | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Right side addition/concatenation callback.
*!
*! This is used by @[predef::`+]. It's called with any arguments
*! that precedes this object in the argument list of the call to
*! @[predef::`+]. The returned value should be a new instance that
*! represents the addition/concatenation between the arguments in
*! the order they are given and this object.
*!
*! @note
*! It's assumed that this function is side-effect free.
*!
*! @seealso
*! @[lfun::`+()], @[predef::`+()]
*/
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``-()], @[predef::`-()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side bitwise and/intersection callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``&()], @[predef::`&()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side bitwise or/union callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``|()], @[predef::`|()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side exclusive or callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``^()], @[predef::`^()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side left shift callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``<<()], @[predef::`<<()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side right shift callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``>>()], @[predef::`>>()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side multiplication/repetition/implosion callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``*()], @[predef::`*()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side division/split callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``/()], @[predef::`/()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Left side modulo callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[lfun::``%()], @[predef::`%()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | |
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | |
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Complement/inversion callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`~()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Equality test callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
779ae1 | 2003-04-28 | Martin Stjernholm | | *! @note
*! If this is implemented it might be necessary to implement
*! @[lfun::__hash] too. Otherwise mappings might hold several
*! objects as indices which are duplicates according to this
*! function. Various other functions that use hashing also might
*! not work correctly, e.g. @[Array.uniq].
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
779ae1 | 2003-04-28 | Martin Stjernholm | | *! @[predef::`==()], @[lfun::__hash]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Less than test callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`<()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Greater than test callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`>()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! Hashing callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! This function gets called by various mapping operations when the
|
779ae1 | 2003-04-28 | Martin Stjernholm | | *! object is used as index in a mapping. It should return an
*! integer that corresponds to the object in such a way that all
*! values which @[lfun::`==] considers equal to the object gets the
*! same hash value.
*!
*! @note
*! The function @[predef::hash] does not return hash values that
*! are compatible with this one.
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
*!
|
779ae1 | 2003-04-28 | Martin Stjernholm | | *! @seealso
*! @[lfun::`==]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Value cast callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! @param requested_type
*! Type to cast to.
*!
*! @returns
*! Expected to return the object value-casted (converted) to
*! the type described by @[requested_type].
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @note
|
317384 | 2001-12-20 | Martin Nilsson | | *! The argument is currently a string with the name
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! of the type, but might in the future be a value of the type type.
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *!
*! @note
|
317384 | 2001-12-20 | Martin Nilsson | | *! Currently casting between object types is a noop.
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *!
*! @note
*! If the returned value is not deemed to be of the requested type
*! a runtime error may be thrown.
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Index/subrange callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`[]()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Index assignment callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`[]=()], @[lfun::`->=()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Arrow index callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`->()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Arrow index assignment callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`->=()], @[lfun::`[]=()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
5d086e | 2001-05-05 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Size query callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! Called by @[sizeof()] to determine the number of elements
*! in an object. If this function is not present, the number
*! of public symbols in the object will be returned.
*!
*! @returns
*! Expected to return the number of valid indices in the object.
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::sizeof()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
5d086e | 2001-05-05 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! List indices callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! @returns
*! Expected to return an array with the valid indices in the object.
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::indices()], @[lfun::_values()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
5d086e | 2001-05-05 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! List values callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! @returns
*! Expected to return an array with the values corresponding to
*! the indices returned by @[lfun::_indices()].
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! It's assumed that this function is side-effect free.
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::values()], @[lfun::_indices()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
5d086e | 2001-05-05 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Apply callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::`()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! Type comparison callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! Called by the cast operator to determine if an object
*! simulates a basic type.
*!
*! @param basic_type
*! One of:
*! @string
*! @value "array"
*! @value "float"
*! @value "function"
*! @value "int"
*! @value "mapping"
*! @value "multiset"
*! @value "object"
*! @value "program"
*! @value "string"
*! @value "type"
*! @value "void"
*! @value "zero"
*! @endstring
*!
*! The following five shouldn't occurr, but are here for completeness:
*! @string
*! @value "lvalue"
*! @value "mapping_data"
*! @value "object storage"
*! @value "pike_frame"
*! @value "unknown"
*! @endstring
*!
*! @returns
|
cbe8c9 | 2003-04-07 | Martin Nilsson | | *! Expected to return @expr{1@} if the object is to be regarded as a
|
317384 | 2001-12-20 | Martin Nilsson | | *! simulation of the type specified by @[basic_type].
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @note
|
317384 | 2001-12-20 | Martin Nilsson | | *! The argument is currently a string with the name
|
f60f89 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! of the type, but might in the future be a value of the type type.
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
8203d4 | 2001-02-09 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *! Sprintf callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
14230c | 2003-01-03 | Henrik Grubbström (Grubba) | | *! This method is called by @[predef::sprintf()] to print objects. If it is
|
302b71 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! not present, printing of the object will not be supported for any
|
b77275 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! conversion-type except for the @tt{%O@}-conversion-type, which
|
cbe8c9 | 2003-04-07 | Martin Nilsson | | *! will output @expr{"object"@}.
|
b77275 | 2001-12-20 | Henrik Grubbström (Grubba) | | *!
*! @param conversion_type
*! One of:
*! @int
*! @value 'b'
*! Signed binary integer.
*! @value 'd'
*! Signed decimal integer.
*! @value 'u'
*! Unsigned decimal integer.
*! @value 'o'
*! Signed octal integer.
*! @value 'x'
*! Lowercase signed hexadecimal integer.
*! @value 'X'
*! Uppercase signed hexadecimal integer.
*! @value 'c'
*! Character. If a fieldsize has been specified this will output
*! the low-order bytes of the integer in network byte order.
*! @value 'f'
*! Float.
*! @value 'g'
*! Heuristically chosen representation of float.
*! @value 'G'
*! Like @tt{%g@}, but uses uppercase @tt{E@} for exponent.
*! @value 'e'
*! Exponential notation float.
*! @value 'E'
*! Like @tt{%e@}, but uses uppercase @tt{E@} for exponent.
*! @value 's'
*! String.
*! @value 'O'
*! Any value (debug style).
*! @value 't'
*! Type of the argument.
*! @endint
*!
*! @param params
*! Conversion parameters. The following parameters may be supplied:
*! @mapping
*! @member int "precision"
*! Precision.
*! @member int "width"
*! Field width.
*! @member int(1..1) "flag_left"
*! Indicates that the output should be left-aligned.
*! @member int "indent"
*! Indentation level in @tt{%O@}-mode.
*! @endmapping
*!
*! @returns
*! Is expected to return a string describing the object formatted
*! according to @[conversion_type].
*!
*! @note
|
317384 | 2001-12-20 | Martin Nilsson | | *! @[_sprintf()] is currently not called for the following
|
b77275 | 2001-12-20 | Henrik Grubbström (Grubba) | | *! conversion-types:
*! @int
*! @value 'F'
*! Binary IEEE representation of float (@tt{%4F@} gives
*! single precision, @tt{%8F@} gives double precision.)
*! @endint
*!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! @note
*! This function might be called at odd times, e.g. before
*! @[lfun::create] has been called or when an error has occurred.
*! The reason is typically that it gets called when a backtrace is
*! being formatted to report an error. It should therefore be very
*! robust and not make any assumptions about its own internal
*! state, at least not when @[conversion_type] is @expr{'O'@}.
*!
*! @note
*! It's assumed that this function is side-effect free.
*!
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::sprintf()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
8203d4 | 2001-02-09 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Recursive equality callback.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::equal()], @[lfun::`==()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
8203d4 | 2001-02-09 | Henrik Grubbström (Grubba) | | |
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Delete index callback.
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | *!
*! @seealso
|
dd2c60 | 2002-12-20 | Henrik Grubbström (Grubba) | | *! @[predef::m_delete()]
|
1a5b2f | 2001-02-09 | Henrik Grubbström (Grubba) | | */
|
c4131e | 2003-04-18 | Martin Stjernholm | | |
226d64 | 2001-02-24 | Henrik Grubbström (Grubba) | | *!
|
dfceb0 | 2003-11-10 | Martin Stjernholm | | *! Iterator creation callback.
*!
*! The returned @[Iterator] instance works as a cursor that
*! references a specific item contained (in some arbitrary sense)
*! in this one.
*!
*! @note
*! It's assumed that this function is side-effect free.
|
83c261 | 2001-05-05 | Henrik Grubbström (Grubba) | | *!
|
c4131e | 2003-04-18 | Martin Stjernholm | | *! @seealso
*! @[Iterator], @[get_iterator], @[predef::foreach()]
|
226d64 | 2001-02-24 | Henrik Grubbström (Grubba) | | */
|
142c80 | 2003-09-04 | Henrik Grubbström (Grubba) | |
|
47251d | 2002-12-11 | Henrik Grubbström (Grubba) | |
|
193795 | 2002-12-08 | Henrik Grubbström (Grubba) | |
|
cbe8c9 | 2003-04-07 | Martin Nilsson | | *! Returns the default module, or @expr{0@} (zero).
|
193795 | 2002-12-08 | Henrik Grubbström (Grubba) | | *!
|
cbe8c9 | 2003-04-07 | Martin Nilsson | | *! If @expr{0@} (zero) is returned the compiler use the mapping
|
193795 | 2002-12-08 | Henrik Grubbström (Grubba) | | *! returned by @[all_constants()] as fallback.
*!
*! @seealso
*! @[get_predefines()]
*/
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct program *first_program = 0;
|
f8d8f4 | 2001-07-01 | Henrik Grubbström (Grubba) | | static int current_program_id = PROG_DYNAMIC_ID_START;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
aa68b1 | 2001-03-19 | Fredrik Hübinette (Hubbe) | | struct program *null_program=0;
|
10e16f | 1999-11-04 | Henrik Grubbström (Grubba) | | struct object *error_handler=0;
|
ac8715 | 2000-09-25 | Fredrik Hübinette (Hubbe) | | struct object *compat_handler=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | struct program *gc_internal_program = 0;
static struct program *gc_mark_program_pos = 0;
|
51717a | 2001-04-09 | Fredrik Hübinette (Hubbe) | | int compilation_depth=-1;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | dynamic_buffer used_modules;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | static struct mapping *resolve_cache=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
1415ff | 2003-03-19 | Martin Stjernholm | | #ifdef PIKE_DEBUG
#define CHECK_FILE_ENTRY(PROG, POS, LEN, SHIFT) \
do { \
if (SHIFT < 0 || SHIFT > 2 || \
POS + (LEN << SHIFT) > PROG->linenumbers + PROG->num_linenumbers) \
Pike_fatal ("Invalid file entry in linenumber info.\n"); \
} while (0)
#else
#define CHECK_FILE_ENTRY(PROG, POS, LEN, SHIFT) do {} while (0)
#endif
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | int get_small_number(char **q);
|
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) \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->malloc_size_program-> PIKE_CONCAT(num_,NAME) < Pike_compiler->new_program-> PIKE_CONCAT(num_,NAME)) \
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Pike_compiler->new_program->num_" #NAME " is out of order\n"); \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & PROGRAM_OPTIMIZED) \
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Tried to reallocate fixed program.\n")
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
#else
#define CHECK_FOO(NUMTYPE,TYPE,NAME)
#endif
|
0e0cd7 | 2001-07-20 | Henrik Grubbström (Grubba) | | #ifndef RELOCATE_program
#define RELOCATE_program(ORIG, NEW)
#endif /* !RELOCATE_program */
|
302ede | 2001-07-19 | Henrik Grubbström (Grubba) | | #define RELOCATE_linenumbers(ORIG,NEW)
#define RELOCATE_identifier_index(ORIG,NEW)
#define RELOCATE_variable_index(ORIG,NEW)
#define RELOCATE_identifier_references(ORIG,NEW)
#define RELOCATE_strings(ORIG,NEW)
#define RELOCATE_inherits(ORIG,NEW)
#define RELOCATE_identifiers(ORIG,NEW)
#define RELOCATE_constants(ORIG,NEW)
#define RELOCATE_relocations(ORIG,NEW)
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,NAME) \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | 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)) { \
|
302ede | 2001-07-19 | Henrik Grubbström (Grubba) | | TYPE *tmp; \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | state->malloc_size_program->PIKE_CONCAT(num_,NAME) *= 2; \
state->malloc_size_program->PIKE_CONCAT(num_,NAME)++; \
|
302ede | 2001-07-19 | Henrik Grubbström (Grubba) | | tmp = realloc((void *)state->new_program->NAME, \
sizeof(TYPE) * \
state->malloc_size_program-> \
PIKE_CONCAT(num_,NAME)); \
|
7ed496 | 2002-11-19 | Henrik Grubbström (Grubba) | | if(!tmp) Pike_fatal("Out of memory.\n"); \
|
302ede | 2001-07-19 | Henrik Grubbström (Grubba) | | PIKE_CONCAT(RELOCATE_,NAME)(state->new_program, tmp); \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | state->new_program->NAME=tmp; \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | } \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | state->new_program-> \
NAME[state->new_program->PIKE_CONCAT(num_,NAME)++]=(ARG); \
} \
|
7e877a | 2003-04-02 | Martin Stjernholm | | void PIKE_CONCAT(add_to_,NAME) (ARGTYPE ARG) { \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | CHECK_FOO(NUMTYPE,TYPE,NAME); \
PIKE_CONCAT(low_add_to_,NAME) ( Pike_compiler, ARG ); \
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
d429a7 | 1998-02-24 | Fredrik Hübinette (Hubbe) | |
#include "program_areas.h"
|
7ed496 | 2002-11-19 | Henrik Grubbström (Grubba) | | #define add_to_program(ARG) do { \
debug_malloc_touch(Pike_compiler->new_program->program); \
add_to_program(ARG); \
} while(0)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void ins_int(INT32 i, void (*func)(char tmp))
{
int e;
|
573ba4 | 2001-04-11 | Henrik Grubbström (Grubba) | | unsigned char *p = (unsigned char *)&i;
for(e=0;e<(long)sizeof(i);e++) {
func(p[e]);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
7e877a | 2003-04-02 | Martin Stjernholm | | void ins_short(int i, void (*func)(char tmp))
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
int e;
|
4dba52 | 2001-07-11 | Henrik Grubbström (Grubba) | | unsigned char *p = (unsigned char *)&i;
for(e=0;e<(long)sizeof(i);e++) {
func(p[e]);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
5f8eb7 | 1997-02-18 | Fredrik Hübinette (Hubbe) | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | | #ifdef PIKE_DEBUG
static void debug_add_to_identifiers (struct identifier id)
{
if (d_flag) {
int i;
for (i = 0; i < Pike_compiler->new_program->num_identifiers; i++)
if (Pike_compiler->new_program->identifiers[i].name == id.name) {
dump_program_tables (Pike_compiler->new_program, 0);
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal ("Adding identifier twice, old at %d.\n", i);
|
5ec106 | 2002-05-09 | Martin Stjernholm | | }
}
add_to_identifiers (id);
}
#else
#define debug_add_to_identifiers(ARG) add_to_identifiers(ARG)
#endif
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | void add_relocated_int_to_program(INT32 i)
{
add_to_relocations(Pike_compiler->new_program->num_program);
ins_int(i, (void (*)(char))add_to_program);
}
|
5ec106 | 2002-05-09 | Martin Stjernholm | |
|
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) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->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);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->module_index_cache)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_mapping(Pike_compiler->module_index_cache);
Pike_compiler->module_index_cache=0;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
|
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)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Unusing too many modules.\n");
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | #endif
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->num_used_modules-=howmany;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | 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);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->module_index_cache)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_mapping(Pike_compiler->module_index_cache);
Pike_compiler->module_index_cache=0;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
}
|
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);
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | static struct node_s *index_modules(struct pike_string *ident,
struct mapping **module_index_cache,
int num_used_modules,
struct svalue *modules)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | if(*module_index_cache)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | struct svalue *tmp=low_mapping_string_lookup(*module_index_cache,ident);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(tmp)
{
|
9f516a | 2001-12-16 | Martin Stjernholm | | if(!(SAFE_IS_ZERO(tmp) && tmp->subtype==1))
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | return mksvaluenode(tmp);
return 0;
}
}
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | JMP_BUF tmp;
if(SETJMP(tmp))
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
9036e8 | 2001-08-16 | Martin Stjernholm | | struct svalue thrown = throw_value;
throw_value.type = T_INT;
|
b34c9f | 2001-08-15 | Martin Stjernholm | |
|
a6ded6 | 2003-05-16 | Henrik Grubbström (Grubba) | | dmalloc_touch_svalue(&thrown);
|
b34c9f | 2001-08-15 | Martin Stjernholm | | if (!ident->size_shift) {
|
bd537b | 2002-12-10 | Martin Stjernholm | | my_yyerror("Couldn't index a module with '%s'.", ident->str);
|
b34c9f | 2001-08-15 | Martin Stjernholm | | } else {
|
bd537b | 2002-12-10 | Martin Stjernholm | | yyerror("Couldn't index a module.");
|
b34c9f | 2001-08-15 | Martin Stjernholm | | }
|
9036e8 | 2001-08-16 | Martin Stjernholm | | push_svalue(&thrown);
low_safe_apply_handler("compile_exception", error_handler, compat_handler, 1);
|
9f516a | 2001-12-16 | Martin Stjernholm | | if (SAFE_IS_ZERO(sp-1)) yy_describe_exception(&thrown);
|
b34c9f | 2001-08-15 | Martin Stjernholm | | pop_stack();
|
9036e8 | 2001-08-16 | Martin Stjernholm | | free_svalue(&thrown);
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | } else {
int e = num_used_modules;
struct svalue *m = modules - num_used_modules;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | while(--e>=0)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | push_svalue(m+e);
ref_push_string(ident);
f_index(2);
if(!IS_UNDEFINED(Pike_sp-1))
{
struct node_s *ret;
UNSETJMP(tmp);
|
bd537b | 2002-12-10 | Martin Stjernholm | |
if (Pike_compiler->compiler_pass == 2 &&
((Pike_sp[-1].type == T_OBJECT &&
Pike_sp[-1].u.object == placeholder_object) ||
(Pike_sp[-1].type == T_PROGRAM &&
Pike_sp[-1].u.program == placeholder_program))) {
if (!ident->size_shift)
my_yyerror("Got placeholder %s (resolver problem) "
"when indexing a module with '%s'.",
get_name_of_type (Pike_sp[-1].type), ident->str);
else
my_yyerror("Got placeholder %s (resolver problem).",
get_name_of_type (Pike_sp[-1].type));
ret = 0;
}
else {
if(!*module_index_cache)
*module_index_cache = allocate_mapping(10);
mapping_string_insert(*module_index_cache, ident, Pike_sp-1);
ret = mksvaluenode(Pike_sp-1);
}
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | pop_stack();
return ret;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | pop_stack();
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
}
|
8fa310 | 2000-09-05 | Henrik Grubbström (Grubba) | | UNSETJMP(tmp);
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
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;
}
|
561431 | 2002-11-17 | Henrik Grubbström (Grubba) | |
|
f34f64 | 2002-05-05 | Martin Stjernholm | | struct node_s *resolve_identifier(struct pike_string *ident);
|
281605 | 2000-03-30 | Fredrik Hübinette (Hubbe) | | struct node_s *find_module_identifier(struct pike_string *ident,
int see_inherit)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
struct node_s *ret;
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | struct svalue *modules=(struct svalue *)
(used_modules.s.str + used_modules.s.len);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
4d51e0 | 2002-06-10 | Martin Stjernholm | | struct program_state *p=Pike_compiler;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | int n;
|
4d51e0 | 2002-06-10 | Martin Stjernholm | | for(n=0;n<=compilation_depth;n++,p=p->previous)
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
281605 | 2000-03-30 | Fredrik Hübinette (Hubbe) | | int i;
if(see_inherit)
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | {
|
281605 | 2000-03-30 | Fredrik Hübinette (Hubbe) | | i=really_low_find_shared_string_identifier(ident,
p->new_program,
|
4d51e0 | 2002-06-10 | Martin Stjernholm | | SEE_STATIC|SEE_PRIVATE);
|
281605 | 2000-03-30 | Fredrik Hübinette (Hubbe) | | if(i!=-1)
{
|
4d51e0 | 2002-06-10 | Martin Stjernholm | | return p == Pike_compiler ?
mkidentifiernode(i) :
mkexternalnode(p->new_program, i);
|
281605 | 2000-03-30 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | |
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | if((ret=index_modules(ident,
&p->module_index_cache,
p->num_used_modules,
modules))) return ret;
modules-=p->num_used_modules;
#ifdef PIKE_DEBUG
if( ((char *)modules ) < used_modules.s.str)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Modules out of whack!\n");
|
4d7b18 | 1999-12-07 | Fredrik Hübinette (Hubbe) | | #endif
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
}
|
e8d37d | 2002-02-14 | Henrik Grubbström (Grubba) | |
if (ident == UNDEFINED_string) {
struct svalue s;
s.type = T_INT;
s.subtype = NUMBER_UNDEFINED;
s.u.integer = 0;
return mkconstantsvaluenode(&s);
}
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
f34f64 | 2002-05-05 | Martin Stjernholm | | return resolve_identifier(ident);
}
struct node_s *resolve_identifier(struct pike_string *ident)
{
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(resolve_cache)
{
struct svalue *tmp=low_mapping_string_lookup(resolve_cache,ident);
if(tmp)
{
|
9f516a | 2001-12-16 | Martin Stjernholm | | if(!(SAFE_IS_ZERO(tmp) && tmp->subtype==1))
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | return mkconstantsvaluenode(tmp);
return 0;
}
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!Pike_compiler->num_parse_error && get_master())
|
27ae84 | 2000-02-07 | Per Hedbor | | {
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | 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);
|
e5e44e | 2001-05-24 | Henrik Grubbström (Grubba) | | if (error_handler) {
ref_push_object(error_handler);
} else {
push_int(0);
}
|
d55569 | 2000-03-10 | Fredrik Hübinette (Hubbe) | |
|
9036e8 | 2001-08-16 | Martin Stjernholm | | if (safe_apply_handler("resolv", error_handler, compat_handler, 3, 0)) {
|
bd537b | 2002-12-10 | Martin Stjernholm | | if (Pike_compiler->compiler_pass == 2 &&
((Pike_sp[-1].type == T_OBJECT &&
Pike_sp[-1].u.object == placeholder_object) ||
(Pike_sp[-1].type == T_PROGRAM &&
Pike_sp[-1].u.program == placeholder_program))) {
if (!ident->size_shift)
my_yyerror("Got placeholder %s (resolver problem) "
"when resolving '%s'.",
get_name_of_type (Pike_sp[-1].type), ident->str);
else
my_yyerror("Got placeholder %s (resolver problem).",
get_name_of_type (Pike_sp[-1].type));
}
else {
if(!resolve_cache)
resolve_cache=dmalloc_touch(struct mapping *, allocate_mapping(10));
mapping_string_insert(resolve_cache,ident,Pike_sp-1);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
bd537b | 2002-12-10 | Martin Stjernholm | | if(!(SAFE_IS_ZERO(Pike_sp-1) && Pike_sp[-1].subtype==1))
{
ret=mkconstantsvaluenode(Pike_sp-1);
}
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
9036e8 | 2001-08-16 | Martin Stjernholm | | pop_stack();
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
9036e8 | 2001-08-16 | Martin Stjernholm | | else
if(Pike_compiler->compiler_pass==2) {
if (throw_value.type == T_STRING && !throw_value.u.string->size_shift) {
yyerror(throw_value.u.string->str);
free_svalue(&throw_value);
throw_value.type = T_INT;
}
else {
struct svalue thrown = throw_value;
throw_value.type = T_INT;
|
a6ded6 | 2003-05-16 | Henrik Grubbström (Grubba) | | dmalloc_touch_svalue(&thrown);
|
9036e8 | 2001-08-16 | Martin Stjernholm | | if (!ident->size_shift)
my_yyerror("Error resolving '%s'.", ident->str);
else
yyerror("Error resolving identifier.");
push_svalue(&thrown);
low_safe_apply_handler("compile_exception", error_handler, compat_handler, 1);
|
9f516a | 2001-12-16 | Martin Stjernholm | | if (SAFE_IS_ZERO(sp-1)) yy_describe_exception(&thrown);
|
9036e8 | 2001-08-16 | Martin Stjernholm | | pop_stack();
free_svalue(&thrown);
}
}
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
14bb59 | 2000-05-06 | Fredrik Hübinette (Hubbe) | | END_CYCLIC();
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(ret) return ret;
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
b8cda2 | 1997-01-21 | Fredrik Hübinette (Hubbe) | | return 0;
}
|
561431 | 2002-11-17 | Henrik Grubbström (Grubba) | | |
88e9fb | 2003-08-03 | Martin Stjernholm | | *! Builtin read only variable that evaluates to the current object.
|
561431 | 2002-11-17 | Henrik Grubbström (Grubba) | | *!
*! @seealso
*! @[this_program], @[this_object()]
*/
|
0ee38f | 2002-05-11 | Martin Stjernholm | |
struct node_s *program_magic_identifier (struct program_state *state,
int state_depth, int inherit_num,
struct pike_string *ident,
int colon_colon_ref)
{
#if 0
fprintf (stderr, "magic_identifier (state, %d, %d, %s, %d)\n",
state_depth, inherit_num, ident->str, colon_colon_ref);
#endif
if (!inherit_num) {
|
88e9fb | 2003-08-03 | Martin Stjernholm | |
if (ident == this_string) {
if (state_depth > 0)
return mkexternalnode (state->new_program, IDREF_MAGIC_THIS);
else
return mkidentifiernode (IDREF_MAGIC_THIS);
}
|
0ee38f | 2002-05-11 | Martin Stjernholm | |
|
88e9fb | 2003-08-03 | Martin Stjernholm | | if (ident == this_program_string) {
node *n = mkefuncallnode ("object_program",
state_depth > 0 ?
mkexternalnode (state->new_program, IDREF_MAGIC_THIS) :
mkidentifiernode (IDREF_MAGIC_THIS));
n->node_info &= ~OPT_NOT_CONST;
n->tree_info &= ~OPT_NOT_CONST;
return n;
}
|
0ee38f | 2002-05-11 | Martin Stjernholm | | }
if (colon_colon_ref) {
if (inherit_num < 0) inherit_num = 0;
if(ident == lfun_strings[LFUN_ARROW] ||
ident == lfun_strings[LFUN_INDEX]) {
return mknode(F_MAGIC_INDEX, mknewintnode(inherit_num),
mknewintnode(state_depth));
} else if(ident == lfun_strings[LFUN_ASSIGN_ARROW] ||
ident == lfun_strings[LFUN_ASSIGN_INDEX]) {
return mknode(F_MAGIC_SET_INDEX, mknewintnode(inherit_num),
mknewintnode(state_depth));
} else if(ident == lfun_strings[LFUN__INDICES]) {
return mknode(F_MAGIC_INDICES, mknewintnode(inherit_num),
mknewintnode(state_depth));
} else if(ident == lfun_strings[LFUN__VALUES]) {
return mknode(F_MAGIC_VALUES, mknewintnode(inherit_num),
mknewintnode(state_depth));
}
}
return NULL;
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | struct program *parent_compilation(int level)
{
int n;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | struct program_state *p=Pike_compiler->previous;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | 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;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | for(p=first_program;p;p=p->next)
{
if(id==p->id)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | id_to_program_cache[h]=p;
return p;
}
}
if ((id > 0) && (id < PROG_DYNAMIC_ID_START)) {
char *module = NULL;
switch(id) {
case PROG_PARSER_HTML_ID:
module = "Parser._parser";
break;
case PROG_GMP_MPZ_ID:
|
ac2a18 | 2003-03-19 | Martin Nilsson | | module = "Gmp.mpz";
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | break;
case PROG_MODULE_MIME_ID:
module = "___MIME";
break;
default:
if ((id >= 100) && (id <= 300)) {
module = "Image";
} else if ((id >= 1000) && (id <= 2000)) {
module = "GTK";
}
break;
}
if (module) {
push_text(module);
SAFE_APPLY_MASTER("resolv", 1);
pop_stack();
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | for(p=first_program;p;p=p->next)
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | {
if(id==p->id)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | id_to_program_cache[h]=p;
return p;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
a38237 | 2001-07-02 | Henrik Grubbström (Grubba) | | }
|
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) | | |
aa771b | 2003-08-20 | Martin Stjernholm | | * 1) The individual blocks are much bigger than they need to be
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | * 2) cuts down on malloc overhead (maybe)
* 3) localizes memory access (decreases paging)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | */
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void optimize_program(struct program *p)
{
|
080b1a | 2000-08-10 | Henrik Grubbström (Grubba) | | size_t size=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | char *data;
if(p->flags & PROGRAM_OPTIMIZED) return;
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,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);
|
f82226 | 2001-07-16 | Fredrik Hübinette (Hubbe) | | if(!data)
{
make_program_executable(p);
return;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
size=0;
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,NAME) \
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | size=DO_ALIGN(size, ALIGNOF(TYPE)); \
|
37cd45 | 2003-06-09 | Martin Stjernholm | | if (p->PIKE_CONCAT (num_, NAME)) \
MEMCPY(data+size,p->NAME,p->PIKE_CONCAT(num_,NAME)*sizeof(p->NAME[0])); \
|
302ede | 2001-07-19 | Henrik Grubbström (Grubba) | | PIKE_CONCAT(RELOCATE_,NAME)(p, (TYPE *)(data+size)); \
|
193795 | 2002-12-08 | Henrik Grubbström (Grubba) | | dmfree(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;
|
f82226 | 2001-07-16 | Fredrik Hübinette (Hubbe) | | make_program_executable(p);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
828815 | 2003-06-30 | Martin Stjernholm | | static int program_identifier_index_compare(int a, int b,
const struct program *p)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
828815 | 2003-06-30 | Martin Stjernholm | | size_t val_a = PTR_TO_INT (ID_FROM_INT(p, a)->name);
size_t val_b = PTR_TO_INT (ID_FROM_INT(p, b)->name);
return val_a < val_b ? -1 : (val_a == val_b ? 0 : 1);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
ab9db5 | 2003-02-20 | Henrik Grubbström (Grubba) | | #define CMP(X,Y) program_identifier_index_compare(*(X), *(Y), prog)
#define EXTRA_ARGS , struct program *prog
#define XARGS , prog
#define ID fsort_program_identifier_index
#define TYPE unsigned short
#include "fsort_template.h"
#undef TYPE
#undef ID
#undef XARGS
#undef EXTRA_ARGS
#undef CMP
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | struct pike_string *find_program_name(struct program *p, INT32 *line)
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | {
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | INT32 l;
if(!line) line=&l;
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | |
#ifdef DEBUG_MALLOC
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | {
char *tmp=dmalloc_find_name(p);
|
a275d2 | 2003-03-29 | Martin Stjernholm | | if (tmp) {
|
7e877a | 2003-04-02 | Martin Stjernholm | | char *p = STRCHR (tmp, ':');
|
a275d2 | 2003-03-29 | Martin Stjernholm | | if (p) {
char *pp;
|
7e877a | 2003-04-02 | Martin Stjernholm | | while ((pp = STRCHR (p + 1, ':'))) p = pp;
|
a275d2 | 2003-03-29 | Martin Stjernholm | | *line = atoi (p + 1);
return make_shared_binary_string (tmp, p - tmp);
}
else {
*line=0;
return make_shared_string(tmp);
}
}
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | }
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | #endif
|
4f985f | 2001-06-30 | Martin Stjernholm | | return get_program_line(p, line);
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | }
#endif
|
a1f852 | 2002-06-11 | Martin Stjernholm | | int override_identifier (struct reference *ref, struct pike_string *name)
|
5ec106 | 2002-05-09 | Martin Stjernholm | | {
|
a1f852 | 2002-06-11 | Martin Stjernholm | | int id = -1, cur_id = 0;
|
c2060d | 2003-06-06 | Henrik Grubbström (Grubba) | |
int new_is_variable =
IDENTIFIER_IS_VARIABLE(ID_FROM_PTR(Pike_compiler->new_program,
ref)->identifier_flags);
|
5ec106 | 2002-05-09 | Martin Stjernholm | |
for(;cur_id<Pike_compiler->new_program->num_identifier_references;cur_id++)
{
if(Pike_compiler->new_program->identifier_references[cur_id].id_flags & ID_HIDDEN)
continue;
|
89a2ad | 2002-05-09 | Martin Stjernholm | | if((Pike_compiler->new_program->identifier_references[cur_id].id_flags &
|
5ec106 | 2002-05-09 | Martin Stjernholm | | (ID_INLINE|ID_INHERITED)) == (ID_INLINE|ID_INHERITED))
continue;
if(ID_FROM_INT(Pike_compiler->new_program, cur_id)->name != name)
continue;
#ifdef PROGRAM_BUILD_DEBUG
fprintf(stderr, "%.*soverloaded reference %d (id_flags:0x%04x)\n",
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | compilation_depth, " ", cur_id,
|
5ec106 | 2002-05-09 | Martin Stjernholm | | Pike_compiler->new_program->identifier_references[cur_id].id_flags);
#endif
|
c2060d | 2003-06-06 | Henrik Grubbström (Grubba) | | if (!new_is_variable &&
IDENTIFIER_IS_VARIABLE(ID_FROM_INT(Pike_compiler->new_program,
cur_id)->identifier_flags)) {
|
fa6afc | 2003-06-06 | Henrik Grubbström (Grubba) | |
|
c2060d | 2003-06-06 | Henrik Grubbström (Grubba) | | Pike_compiler->new_program->identifier_references[cur_id].id_flags |=
ID_INLINE|ID_HIDDEN;
yywarning("Attempt to override a non local variable %s%s%swith a non variable.",
(name&&!name->size_shift)?"\"":"",
(name&&!name->size_shift)?name->str:"",
(name&&!name->size_shift)?"\" ":"");
continue;
}
|
5ec106 | 2002-05-09 | Martin Stjernholm | | Pike_compiler->new_program->identifier_references[cur_id]=*ref;
id = cur_id;
}
return id;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | void fixate_program(void)
{
INT32 i,e,t;
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | struct program *p=Pike_compiler->new_program;
if(p->flags & PROGRAM_FIXED) return;
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_OPTIMIZED)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Cannot fixate optimized program\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
757128 | 2003-06-03 | Martin Stjernholm | |
for (i = 0; i < p->num_identifier_references; i++) {
struct reference *ref = p->identifier_references + i;
if (ref->id_flags & ID_HIDDEN) continue;
if (ref->inherit_offset != 0) continue;
override_identifier (ref, ID_FROM_PTR (p, ref)->name);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | for(e=i=0;i<(int)p->num_identifier_references;i++)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
struct reference *funp;
struct identifier *fun;
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | funp=p->identifier_references+i;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(funp->id_flags & (ID_HIDDEN|ID_STATIC)) continue;
|
e18d90 | 2002-04-26 | Henrik Grubbström (Grubba) | | fun=ID_FROM_PTR(p, funp);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(funp->id_flags & ID_INHERITED)
{
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | int found_better=-1;
int funa_is_prototype;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(funp->id_flags & ID_PRIVATE) continue;
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | funa_is_prototype = fun->func.offset == -1;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | for(t=i+1;t<(int)p->num_identifier_references;t++)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
struct reference *funpb;
struct identifier *funb;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | funpb=p->identifier_references+t;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(funpb->id_flags & (ID_HIDDEN|ID_STATIC)) continue;
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | funb=ID_FROM_PTR(p,funpb);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | |
if(fun->name==funb->name)
{
found_better=t;
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | |
if(funa_is_prototype && (funb->func.offset != -1) &&
!(funp->id_flags & ID_INLINE))
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | {
funp->inherit_offset = funpb->inherit_offset;
funp->identifier_offset = funpb->identifier_offset;
}
if(!funa_is_prototype && funb->func.offset == -1)
{
funpb->inherit_offset = funp->inherit_offset;
funpb->identifier_offset = funp->identifier_offset;
}
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | if(found_better!=-1)
continue;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
e18d90 | 2002-04-26 | Henrik Grubbström (Grubba) | | if ((fun->func.offset == -1) && (funp->id_flags & ID_INLINE) &&
IDENTIFIER_IS_PIKE_FUNCTION(fun->identifier_flags)) {
if (!fun->name->size_shift && fun->name->len < 900) {
my_yyerror("Missing definition for local function %s().",
fun->name->str);
} else {
yyerror("Missing definition for local function.");
}
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_identifier_index(i);
}
|
ab9db5 | 2003-02-20 | Henrik Grubbström (Grubba) | | fsort_program_identifier_index(p->identifier_index,
p->identifier_index +
p->num_identifier_index - 1,
p);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | |
|
87d5c5 | 2000-02-16 | Henrik Grubbström (Grubba) | | for(i=1;i<NUM_LFUNS;i++) {
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | p->lfuns[i] = low_find_lfun(p, i);
|
2c1709 | 1999-06-22 | Fredrik Hübinette (Hubbe) | | }
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | p->flags |= PROGRAM_FIXED;
if(Pike_compiler->check_final)
{
for(i=0;i<(int)p->num_identifier_references;i++)
{
|
e9900c | 2002-04-17 | Henrik Grubbström (Grubba) | | if((p->identifier_references[i].id_flags & (ID_NOMASK|ID_HIDDEN)) ==
ID_NOMASK)
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | {
struct pike_string *name=ID_FROM_INT(p, i)->name;
e=find_shared_string_identifier(name,p);
|
5a071a | 2001-10-02 | Fredrik Hübinette (Hubbe) | | if(e == -1)
|
e9900c | 2002-04-17 | Henrik Grubbström (Grubba) | | e=really_low_find_shared_string_identifier(name, p,
SEE_STATIC|SEE_PRIVATE);
|
5a071a | 2001-10-02 | Fredrik Hübinette (Hubbe) | |
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | if((e != i) && (e != -1))
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | {
if(name->len < 1024 && !name->size_shift)
|
5a071a | 2001-10-02 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine final identifier %s",name->str);
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | else
|
5a071a | 2001-10-02 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine final identifier (unable to output name of identifier).");
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | }
}
}
}
|
98bc6f | 2001-09-27 | Henrik Grubbström (Grubba) | |
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | #ifdef DEBUG_MALLOC
{
#define DBSTR(X) ((X)?(X)->str:"")
int e,v;
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | INT32 line;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | struct pike_string *tmp;
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | struct memory_map *m=0;;
if(lex.current_file &&
lex.current_file->str &&
lex.current_file->len &&
!strcmp(lex.current_file->str,"-"))
{
m=dmalloc_alloc_mmap( DBSTR(lex.current_file), lex.current_line);
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | else if( (tmp=find_program_name(Pike_compiler->new_program, &line)) )
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | {
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | m=dmalloc_alloc_mmap( tmp->str, line);
free_string(tmp);
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | }else{
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | m=dmalloc_alloc_mmap( "program id", Pike_compiler->new_program->id);
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | for(e=0;e<Pike_compiler->new_program->num_inherits;e++)
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | struct inherit *i=Pike_compiler->new_program->inherits+e;
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | char *tmp;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | struct pike_string *tmp2 = NULL;
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | char buffer[50];
for(v=0;v<i->prog->num_variable_index;v++)
{
int d=i->prog->variable_index[v];
struct identifier *id=i->prog->identifiers+d;
dmalloc_add_mmap_entry(m,
id->name->str,
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | i->storage_offset + id->func.offset,
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | sizeof_variable(id->run_time_type),
1,
0,0);
}
if(i->name)
{
tmp=i->name->str;
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | }
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | else if(!(tmp2 = find_program_name(i->prog, &line)))
|
a4033e | 2000-04-14 | Fredrik Hübinette (Hubbe) | | {
sprintf(buffer,"inherit[%d]",e);
tmp=buffer;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | } else {
tmp = tmp2->str;
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | }
dmalloc_add_mmap_entry(m,
tmp,
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | i->storage_offset,
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | i->prog->storage_needed - i->prog->inherits[0].storage_offset,
1,
0,0);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | if (tmp2) {
free_string(tmp2);
}
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | dmalloc_set_mmap_template(Pike_compiler->new_program, m);
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | }
#endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | struct program *low_allocate_program(void)
{
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | struct program *p=alloc_program();
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | MEMSET(p, 0, sizeof(struct program));
|
aa68b1 | 2001-03-19 | Fredrik Hübinette (Hubbe) | | p->flags|=PROGRAM_VIRGIN;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | p->alignment_needed=1;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
7bf623 | 2000-04-23 | Martin Stjernholm | | GC_ALLOC(p);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | p->id=++current_program_id;
|
45637c | 2001-04-07 | Fredrik Hübinette (Hubbe) | | INIT_PIKE_MEMOBJ(p);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | DOUBLELINK(first_program, p);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | GETTIMEOFDAY(& p->timestamp);
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,
|
757128 | 2003-06-03 | Martin Stjernholm | | int pass,
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | struct pike_string *name,
int flags,
int *idp)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
757128 | 2003-06-03 | Martin Stjernholm | | int id=0;
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | struct svalue tmp;
|
5c8e89 | 1995-10-29 | Fredrik Hübinette (Hubbe) | |
|
27ae84 | 2000-02-07 | Per Hedbor | | #if 0
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | #ifdef SHARED_NODES
if (!node_hash.table) {
|
d3a313 | 2000-12-01 | Henrik Grubbström (Grubba) | | node_hash.table = malloc(sizeof(node *)*32831);
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | if (!node_hash.table) {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Out of memory!\n");
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | }
|
d3a313 | 2000-12-01 | Henrik Grubbström (Grubba) | | MEMSET(node_hash.table, 0, sizeof(node *)*32831);
node_hash.size = 32831;
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | }
#endif /* SHARED_NODES */
#endif /* 0 */
|
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++;
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | tmp.type=T_PROGRAM;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(!p)
{
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | p=low_allocate_program();
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | if(name)
{
tmp.u.program=p;
id=add_constant(name, &tmp, flags & ~ID_EXTERN);
|
51717a | 2001-04-09 | Fredrik Hübinette (Hubbe) | | #if 0
fprintf(stderr,"Compiling class %s, depth=%d\n",name->str,compilation_depth);
}else{
fprintf(stderr,"Compiling file %s, depth=%d\n",
lex.current_file ? lex.current_file->str : "-",
compilation_depth);
#endif
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }else{
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | tmp.u.program=p;
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(p);
|
7d6575 | 2003-06-04 | Henrik Grubbström (Grubba) | | if((pass == 2) && name)
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | {
struct identifier *i;
id=isidentifier(name);
if (id < 0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program constant disappeared in second pass.\n");
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | i=ID_FROM_INT(Pike_compiler->new_program, id);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(i->type);
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | i->type=get_type_of_svalue(&tmp);
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
7d6575 | 2003-06-04 | Henrik Grubbström (Grubba) | | if (pass == 1) {
if(compilation_depth >= 1)
add_ref(p->parent = Pike_compiler->new_program);
}
|
aa68b1 | 2001-03-19 | Fredrik Hübinette (Hubbe) | | p->flags &=~ PROGRAM_VIRGIN;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->parent_identifier=id;
|
993ba7 | 2000-02-15 | Fredrik Hübinette (Hubbe) | | if(idp) *idp=id;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
a35974 | 2001-12-16 | Martin Stjernholm | | CDFPRINTF((stderr, "th(%ld) %p low_start_new_program() %s "
|
3fa452 | 2002-04-13 | Martin Stjernholm | | "pass=%d: threads_disabled:%d, compilation_depth:%d\n",
|
a35974 | 2001-12-16 | Martin Stjernholm | | (long)th_self(), p, name ? name->str : "-",
Pike_compiler->compiler_pass,
|
3fa452 | 2002-04-13 | Martin Stjernholm | | threads_disabled, compilation_depth));
|
cb6704 | 2001-12-12 | Martin Stjernholm | |
|
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) | |
|
757128 | 2003-06-03 | Martin Stjernholm | | Pike_compiler->compiler_pass = pass;
|
e37a3e | 1999-10-09 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->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;
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->malloc_size_program = ALLOC_STRUCT(program);
Pike_compiler->fake_object=alloc_object();
|
193795 | 2002-12-08 | Henrik Grubbström (Grubba) | |
|
379b68 | 2002-09-30 | Marcus Comstedt | | #ifdef PIKE_DEBUG
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->storage=(char *)xalloc(256 * sizeof(struct svalue));
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | MEMSET(Pike_compiler->fake_object->storage,0x55,256*sizeof(struct svalue));
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | #else
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->storage=(char *)malloc(sizeof(struct parent_info));
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | #endif
|
ddac67 | 2000-07-02 | Martin Stjernholm | |
if (Pike_in_gc) remove_marker(Pike_compiler->fake_object);
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->next=Pike_compiler->fake_object;
Pike_compiler->fake_object->prev=Pike_compiler->fake_object;
|
50ea68 | 2003-03-14 | Henrik Grubbström (Grubba) | | Pike_compiler->fake_object->refs=0;
add_ref(Pike_compiler->fake_object);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->prog=p;
|
3aa0db | 1999-10-22 | Henrik Grubbström (Grubba) | | add_ref(p);
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | |
#ifdef PIKE_DEBUG
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->program_id=p->id;
|
1e4e5f | 2000-04-07 | Fredrik Hübinette (Hubbe) | | #endif
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_SECURITY
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->fake_object->prot=0;
|
7e97c3 | 1999-01-21 | Fredrik Hübinette (Hubbe) | | #endif
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_compiler->fake_object);
debug_malloc_touch(Pike_compiler->fake_object->storage);
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | |
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | if(name)
{
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | |
if((((struct parent_info *)Pike_compiler->fake_object->storage)->parent=Pike_compiler->previous->fake_object))
add_ref(Pike_compiler->previous->fake_object);
((struct parent_info *)Pike_compiler->fake_object->storage)->parent_identifier=id;
}else{
((struct parent_info *)Pike_compiler->fake_object->storage)->parent=0;
((struct parent_info *)Pike_compiler->fake_object->storage)->parent_identifier=0;
|
6d2254 | 1998-01-28 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program=p;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
a78643 | 1999-11-18 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
if (name) {
fprintf (stderr, "%.*sstarting program %d (pass=%d): ",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | compilation_depth, " ", Pike_compiler->new_program->id, Pike_compiler->compiler_pass);
|
a78643 | 1999-11-18 | Martin Stjernholm | | push_string (name);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | print_svalue (stderr, --Pike_sp);
|
a78643 | 1999-11-18 | Martin Stjernholm | | putc ('\n', stderr);
}
else
fprintf (stderr, "%.*sstarting program %d (pass=%d)\n",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | compilation_depth, " ", Pike_compiler->new_program->id, Pike_compiler->compiler_pass);
|
a78643 | 1999-11-18 | Martin Stjernholm | | #endif
|
f39720 | 2002-06-12 | Martin Stjernholm | | if (compilation_depth >= 1) {
if(TEST_COMPAT(7,2) || (lex.pragmas & ID_SAVE_PARENT))
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | {
|
f39720 | 2002-06-12 | Martin Stjernholm | | p->flags |= PROGRAM_USES_PARENT;
}else if (!(lex.pragmas & ID_DONT_SAVE_PARENT)) {
struct pike_string *tmp=findstring("__pragma_save_parent__");
if(tmp)
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | {
|
f39720 | 2002-06-12 | Martin Stjernholm | | struct node_s *n=find_module_identifier(tmp, 0);
if(n)
{
int do_save_parent = !node_is_false(n);
free_node(n);
if (do_save_parent) p->flags |= PROGRAM_USES_PARENT;
}
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | }
}
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_compiler->fake_object);
debug_malloc_touch(Pike_compiler->fake_object->storage);
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->program)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,NAME) \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->malloc_size_program->PIKE_CONCAT(num_,NAME)=Pike_compiler->new_program->PIKE_CONCAT(num_,NAME);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | |
{
INT32 line=0, off=0;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | size_t len = 0;
INT32 shift = 0;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | char *file=0;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | char *cnt=Pike_compiler->new_program->linenumbers;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | while(cnt < Pike_compiler->new_program->linenumbers +
Pike_compiler->new_program->num_linenumbers)
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | {
if(*cnt == 127)
{
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | cnt++;
len = get_small_number(&cnt);
shift = *cnt;
file = ++cnt;
|
1415ff | 2003-03-19 | Martin Stjernholm | | CHECK_FILE_ENTRY (Pike_compiler->new_program, cnt, len, shift);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | cnt += len<<shift;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | }
off+=get_small_number(&cnt);
line+=get_small_number(&cnt);
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->last_line=line;
Pike_compiler->last_pc=off;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | if(file)
{
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | struct pike_string *str = begin_wide_shared_string(len, shift);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->last_file) free_string(Pike_compiler->last_file);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | memcpy(str->str, file, len<<shift);
Pike_compiler->last_file = end_shared_string(str);
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | }
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }else{
static struct pike_string *s;
struct inherit i;
#define START_SIZE 64
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,NAME) \
|
7c7a3f | 2002-12-01 | Martin Stjernholm | | if (Pike_compiler->new_program->NAME) { \
free (Pike_compiler->new_program->NAME); \
Pike_compiler->new_program->PIKE_CONCAT(num_,NAME) = 0; \
} \
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->malloc_size_program->PIKE_CONCAT(num_,NAME)=START_SIZE; \
Pike_compiler->new_program->NAME=(TYPE *)xalloc(sizeof(TYPE) * START_SIZE);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | i.prog=Pike_compiler->new_program;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | i.identifier_level=0;
i.storage_offset=0;
i.inherit_level=0;
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | i.identifier_ref_offset=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | i.parent=0;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | i.parent_identifier=-1;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | i.parent_offset=OBJECT_PARENT;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | i.name=0;
add_to_inherits(i);
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->init_node=0;
Pike_compiler->num_parse_error=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
421801 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | push_compiler_frame(0);
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(Pike_compiler->compiler_frame->current_return_type,
void_type_string);
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_compiler->fake_object);
debug_malloc_touch(Pike_compiler->fake_object->storage);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT void debug_start_new_program(int line, const char *file)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | struct pike_string *save_file = lex.current_file;
int save_line = lex.current_line;
|
cbb2be | 2003-02-04 | Martin Stjernholm | |
{
const char *p = DEFINETOSTR(PIKE_SRC_ROOT), *f = file;
while (*p && *p == *f) p++, f++;
while (*f == '/' || *f == '\\') f++;
lex.current_file = make_shared_string(f);
lex.current_line = line;
}
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | |
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | | CDFPRINTF((stderr,
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | "th(%ld) start_new_program(%d, %s): "
"threads_disabled:%d, compilation_depth:%d\n",
(long)th_self(), line, file, threads_disabled, compilation_depth));
|
b6f8c3 | 1999-07-01 | Henrik Grubbström (Grubba) | |
|
757128 | 2003-06-03 | Martin Stjernholm | | low_start_new_program(0,1,0,0,0);
|
2fbfc4 | 2002-06-11 | Martin Stjernholm | | store_linenumber(line,lex.current_file);
debug_malloc_name(Pike_compiler->new_program, file, line);
free_string(lex.current_file);
lex.current_file = save_file;
lex.current_line = save_line;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | static void exit_program_struct(struct program *p)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
7e877a | 2003-04-02 | Martin Stjernholm | | unsigned e;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d631b8 | 2002-12-01 | Martin Stjernholm | | #ifdef PIKE_DEBUG
if (p->refs) {
#ifdef DEBUG_MALLOC
describe_something(p, T_PROGRAM, 0,2,0, NULL);
#endif
Pike_fatal("Program to be freed still got %d references.\n", p->refs);
}
#endif
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | if(p->parent)
{
|
c82a99 | 2001-04-13 | Henrik Grubbström (Grubba) | |
struct program *parent = p->parent;
p->parent = NULL;
free_program(parent);
|
1c1c5e | 2001-04-08 | Fredrik Hübinette (Hubbe) | | }
|
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)
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(p->identifiers[e].type);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | if(p->constants)
|
43fc17 | 1999-09-19 | Fredrik Hübinette (Hubbe) | | {
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | for(e=0;e<p->num_constants;e++)
|
43fc17 | 1999-09-19 | Fredrik Hübinette (Hubbe) | | {
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | free_svalue(& p->constants[e].sval);
|
43fc17 | 1999-09-19 | Fredrik Hübinette (Hubbe) | | if(p->constants[e].name) free_string(p->constants[e].name);
}
}
|
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) | |
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | DOUBLEUNLINK(first_program, p);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_OPTIMIZED)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
|
9173f7 | 2002-11-25 | Martin Stjernholm | | if(p->program) {
#ifdef PIKE_USE_MACHINE_CODE
#ifdef VALGRIND_DISCARD_TRANSLATIONS
VALGRIND_DISCARD_TRANSLATIONS(p->program,
p->num_program*sizeof(p->program[0]));
#endif /* VALGRIND_DISCARD_TRANSLATIONS */
#endif /* PIKE_USE_MACHINE_CODE */
|
424d9c | 1999-05-02 | Fredrik Hübinette (Hubbe) | | dmfree(p->program);
|
9173f7 | 2002-11-25 | Martin Stjernholm | | }
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,NAME) p->NAME=0;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #include "program_areas.h"
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }else{
|
7e877a | 2003-04-02 | Martin Stjernholm | | #define FOO(NUMTYPE,TYPE,ARGTYPE,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) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
45637c | 2001-04-07 | Fredrik Hübinette (Hubbe) | | EXIT_PIKE_MEMOBJ(p);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
553d23 | 2000-09-14 | Martin Stjernholm | | GC_FREE(p);
|
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;
|
a1f852 | 2002-06-11 | Martin Stjernholm | | fprintf(stderr,"$$$$$ dump_program_desc for %p\n", p);
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"All inherits:\n");
for(e=0;e<p->num_inherits;e++)
{
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | fprintf(stderr,"%3d:\n",e);
|
b8896b | 2000-02-10 | Fredrik Hübinette (Hubbe) | | for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"inherited program: %d\n",p->inherits[e].prog->id);
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e].name)
{
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"name : %s\n",p->inherits[e].name->str);
}
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"inherit_level: %d\n",p->inherits[e].inherit_level);
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"identifier_level: %d\n",p->inherits[e].identifier_level);
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"parent_identifier: %d\n",p->inherits[e].parent_identifier);
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"parent_offset: %d\n",p->inherits[e].parent_offset);
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
|
63540d | 2000-08-15 | Henrik Grubbström (Grubba) | | fprintf(stderr,"storage_offset: %ld\n",
DO_NOT_WARN((long)p->inherits[e].storage_offset));
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | |
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"parent: %p\n",p->inherits[e].parent);
if(p->inherits[e].parent &&
p->inherits[e].parent->prog &&
p->inherits[e].parent->prog->num_linenumbers>1)
{
for(d=0;d<p->inherits[e].inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"parent: %s\n",p->inherits[e].parent->prog->linenumbers+1);
}
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | }
|
a1f852 | 2002-06-11 | Martin Stjernholm | | fprintf(stderr,"All identifier references:\n");
|
2acdd3 | 1995-10-29 | Fredrik Hübinette (Hubbe) | | for(e=0;e<(int)p->num_identifier_references;e++)
{
|
a1f852 | 2002-06-11 | Martin Stjernholm | | struct inherit *inh = INHERIT_FROM_INT(p,e);
fprintf(stderr,"%3d: ",e);
for(d=0;d<inh->inherit_level;d++) fprintf(stderr," ");
fprintf(stderr,"%-40s flags 0x%x",ID_FROM_INT(p,e)->name->str,
p->identifier_references[e].id_flags);
for (q = 0; q < p->num_inherits; q++)
if (p->inherits + q == inh) {
fprintf (stderr, " inherit %d\n", q);
goto inherit_found;
}
fprintf (stderr, " inherit not found!\n");
inherit_found:;
|
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) | | }
|
a1f852 | 2002-06-11 | Martin Stjernholm | |
fprintf(stderr,"$$$$$ dump_program_desc for %p done\n", p);
|
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) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->fake_object)
|
a3c6ad | 1998-01-29 | Fredrik Hübinette (Hubbe) | | {
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | if( ((struct parent_info *)Pike_compiler->fake_object->storage)->parent )
{
free_object(((struct parent_info *)Pike_compiler->fake_object->storage)->parent);
((struct parent_info *)Pike_compiler->fake_object->storage)->parent=0;
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_program(Pike_compiler->fake_object->prog);
Pike_compiler->fake_object->prog=0;
free_object(Pike_compiler->fake_object);
Pike_compiler->fake_object=0;
|
a3c6ad | 1998-01-29 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_program(Pike_compiler->new_program);
Pike_compiler->new_program=0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->malloc_size_program)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | dmfree((char *)Pike_compiler->malloc_size_program);
Pike_compiler->malloc_size_program=0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->module_index_cache)
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_mapping(Pike_compiler->module_index_cache);
Pike_compiler->module_index_cache=0;
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | while(Pike_compiler->compiler_frame)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | pop_compiler_frame();
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | |
|
de1d7d | 2000-07-10 | Henrik Grubbström (Grubba) | | if(Pike_compiler->last_identifier)
{
free_string(Pike_compiler->last_identifier);
Pike_compiler->last_identifier=0;
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->last_file)
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_string(Pike_compiler->last_file);
Pike_compiler->last_file=0;
|
591c0c | 1997-01-19 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | unuse_modules(Pike_compiler->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_FLOAT: return sizeof(FLOAT_TYPE);
|
2ba919 | 1999-10-23 | Fredrik Hübinette (Hubbe) | | case T_INT: return sizeof(INT_TYPE);
|
6ccad4 | 2002-04-25 | Henrik Grubbström (Grubba) | | default: return sizeof(void *);
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | }
}
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | static ptrdiff_t alignof_variable(int run_time_type)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | {
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_FLOAT: return ALIGNOF(FLOAT_TYPE);
|
2ba919 | 1999-10-23 | Fredrik Hübinette (Hubbe) | | case T_INT: return ALIGNOF(INT_TYPE);
|
6ccad4 | 2002-04-25 | Henrik Grubbström (Grubba) | | default: return ALIGNOF(void *);
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | }
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | | void dump_program_tables (struct program *p, int indent)
{
int d;
|
7d6575 | 2003-06-04 | Henrik Grubbström (Grubba) | | if (!p) {
fprintf(stderr, "%*sProgram: NULL\n\n", indent, "");
return;
}
|
5ec106 | 2002-05-09 | Martin Stjernholm | | fprintf(stderr,
"%*sProgram flags: 0x%04x\n\n",
indent, "", p->flags);
fprintf(stderr,
"%*sReference table:\n"
"%*s ####: Flags Inherit Identifier\n",
indent, "", indent, "");
for (d=0; d < p->num_identifier_references; d++) {
struct reference *ref = p->identifier_references + d;
fprintf(stderr, "%*s %4d: %5x %7d %10d %s\n",
indent, "",
d, ref->id_flags, ref->inherit_offset,
ref->identifier_offset,
ID_FROM_PTR(p,ref)->name->size_shift ? "(wide)" :
ID_FROM_PTR(p,ref)->name->str);
if (IDENTIFIER_IS_PIKE_FUNCTION(ID_FROM_PTR(p,ref)->identifier_flags)) {
INT32 line;
struct program *inh_p = INHERIT_FROM_PTR(p,ref)->prog;
|
89a2ad | 2002-05-09 | Martin Stjernholm | | struct pike_string *file =
get_line (ID_FROM_PTR(p,ref)->func.offset + inh_p->program, inh_p, &line);
if (!file->size_shift)
fprintf (stderr, "%*s %s:%d\n",
indent, "", file->str, line);
|
fcbde0 | 2003-08-20 | Martin Stjernholm | | free_string (file);
|
5ec106 | 2002-05-09 | Martin Stjernholm | | }
}
|
757128 | 2003-06-03 | Martin Stjernholm | |
fprintf(stderr, "\n"
"%*sIdentifier index table:\n"
"%*s ####: Index\n",
indent, "", indent, "");
for (d = 0; d < p->num_identifier_index; d++) {
fprintf(stderr, "%*s %4d: %5d\n",
indent, "",
d, p->identifier_index[d]);
}
|
5ec106 | 2002-05-09 | Martin Stjernholm | | fprintf(stderr, "\n"
"%*sInherit table:\n"
|
684bd2 | 2003-08-02 | Martin Stjernholm | | "%*s ####: Level prog_id id_level storage_offs "
"par_id par_offs par_obj_id id_ref_offs\n",
|
5ec106 | 2002-05-09 | Martin Stjernholm | | indent, "", indent, "");
for (d=0; d < p->num_inherits; d++) {
struct inherit *inh = p->inherits + d;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | fprintf(stderr, "%*s %4d: %5d %7d %8d %12d %6d %8d %10d %11d\n",
|
5ec106 | 2002-05-09 | Martin Stjernholm | | indent, "",
|
684bd2 | 2003-08-02 | Martin Stjernholm | | d, inh->inherit_level,
inh->prog ? inh->prog->id : -1,
inh->identifier_level, inh->storage_offset,
inh->parent_identifier, inh->parent_offset,
inh->parent ? inh->parent->program_id : -1,
inh->identifier_ref_offset);
|
5ec106 | 2002-05-09 | Martin Stjernholm | | }
fprintf(stderr, "\n"
"%*sIdentifier table:\n"
"%*s ####: Flags Offset Type Name\n",
indent, "", indent, "");
for (d=0; d < p->num_identifiers; d++) {
struct identifier *id = p->identifiers + d;
fprintf(stderr, "%*s %4d: %5x %6d %4d \"%s\"\n",
indent, "",
d, id->identifier_flags, id->func.offset,
id->run_time_type, id->name->str);
}
|
757128 | 2003-06-03 | Martin Stjernholm | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | | fprintf(stderr, "\n"
"%*sVariable table:\n"
"%*s ####: Index\n",
indent, "", indent, "");
for (d = 0; d < p->num_variable_index; d++) {
fprintf(stderr, "%*s %4d: %5d\n",
indent, "",
d, p->variable_index[d]);
}
fprintf(stderr, "\n"
"%*sConstant table:\n"
"%*s ####: Type Name\n",
indent, "", indent, "");
for (d = 0; d < p->num_constants; d++) {
struct program_constant *c = p->constants + d;
|
aa771b | 2003-08-20 | Martin Stjernholm | | fprintf(stderr, "%*s %4d: %-15s %s%s%s\n",
|
5ec106 | 2002-05-09 | Martin Stjernholm | | indent, "",
|
aa771b | 2003-08-20 | Martin Stjernholm | | d, get_name_of_type (c->sval.type),
|
5ec106 | 2002-05-09 | Martin Stjernholm | | c->name?"\"":"",c->name?c->name->str:"NULL",c->name?"\"":"");
}
|
9b7828 | 2002-11-07 | Henrik Grubbström (Grubba) | |
fprintf(stderr, "\n"
"%*sLinenumber table:\n",
indent, "");
{
INT32 off = 0, line = 0;
|
ad6a88 | 2002-11-07 | Henrik Grubbström (Grubba) | | char *cnt = p->linenumbers;
|
9b7828 | 2002-11-07 | Henrik Grubbström (Grubba) | |
|
ad6a88 | 2002-11-07 | Henrik Grubbström (Grubba) | | while (cnt < p->linenumbers + p->num_linenumbers) {
|
9b7828 | 2002-11-07 | Henrik Grubbström (Grubba) | | if (*cnt == 127) {
|
354695 | 2002-11-07 | Henrik Grubbström (Grubba) | | int len, shift;
|
9b7828 | 2002-11-07 | Henrik Grubbström (Grubba) | | char *file;
cnt++;
len = get_small_number(&cnt);
shift = *cnt;
file = ++cnt;
|
1415ff | 2003-03-19 | Martin Stjernholm | | CHECK_FILE_ENTRY (p, cnt, len, shift);
|
9b7828 | 2002-11-07 | Henrik Grubbström (Grubba) | | cnt += len << shift;
if (!shift) {
fprintf(stderr, "%*s Filename: \"%s\"\n", indent, "", file);
} else {
fprintf(stderr, "%*s Filename: len:%d, shift:%d\n", indent, "", len, shift);
}
}
off += get_small_number(&cnt);
line += get_small_number(&cnt);
fprintf(stderr, "%*s %8d:%8d\n", indent, "", off, line);
}
}
|
757128 | 2003-06-03 | Martin Stjernholm | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | | fprintf(stderr, "\n");
}
|
624d09 | 1996-02-24 | Fredrik Hübinette (Hubbe) | | void check_program(struct program *p)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | INT32 size;
unsigned INT32 checksum, e;
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | int variable_positions[1024];
|
8ba59a | 2000-03-26 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_AVOID_CHECK) return;
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | 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)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program id is out of sync! (p->id=%d, current_program_id=%d)\n",p->id,current_program_id);
|
636e47 | 1998-04-15 | Fredrik Hübinette (Hubbe) | |
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | if(p->refs <=0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program has zero refs.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
if(p->next && p->next->prev != p)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program ->next->prev != program.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
if(p->prev)
{
if(p->prev->next != p)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program ->prev->next != program.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }else{
if(first_program != p)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program ->prev == 0 but first_program != program.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(p->id > current_program_id || p->id <= 0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program id is wrong.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
if(p->storage_needed < 0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program->storage_needed < 0.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(p->num_identifier_index > p->num_identifier_references)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Too many identifier index entries in program!\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<p->num_constants;e++)
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | {
|
aa771b | 2003-08-20 | Martin Stjernholm | | struct svalue *s = & p->constants[e].sval;
check_svalue(s);
if (p->flags & PROGRAM_FINISHED && s->type == T_OBJECT &&
s->u.object->next == s->u.object)
Pike_fatal ("Got fake object in constant in finished program.\n");
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | if(p->constants[e].name) check_string(p->constants[e].name);
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<p->num_strings;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | check_string(p->strings[e]);
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<p->num_inherits;e++)
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | {
|
ce277e | 2000-03-25 | Fredrik Hübinette (Hubbe) | | if(!p->inherits[e].prog)
{
|
e05acb | 2000-03-25 | Fredrik Hübinette (Hubbe) | |
return;
|
ce277e | 2000-03-25 | Fredrik Hübinette (Hubbe) | | }
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e].storage_offset < 0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Inherit->storage_offset is wrong.\n");
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
1f5bfe | 1999-09-28 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e].prog &&
p->inherits[e].storage_offset + STORAGE_NEEDED(p->inherits[e].prog) >
p->storage_needed)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Not enough room allocated by inherit!\n");
|
1f5bfe | 1999-09-28 | Fredrik Hübinette (Hubbe) | |
|
684bd2 | 2003-08-02 | Martin Stjernholm | | if (p->inherits[e].inherit_level == 1 &&
|
88e9fb | 2003-08-03 | Martin Stjernholm | | p->inherits[e].identifier_level != (INT32) p->inherits[e].identifier_ref_offset) {
|
684bd2 | 2003-08-02 | Martin Stjernholm | | dump_program_tables (p, 0);
Pike_fatal ("Unexpected difference between identifier_level "
"and identifier_ref_offset in inherit %d.\n", e);
}
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | if(e)
{
|
27ae84 | 2000-02-07 | Per Hedbor | | if(p->inherits[e-1].storage_offset >
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | p->inherits[e].storage_offset)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Overlapping inherits! (1)\n");
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | if(p->inherits[e-1].prog &&
|
27ae84 | 2000-02-07 | Per Hedbor | | p->inherits[e-1].inherit_level >= p->inherits[e].inherit_level &&
|
1f5bfe | 1999-09-28 | Fredrik Hübinette (Hubbe) | | ( p->inherits[e-1].storage_offset +
STORAGE_NEEDED(p->inherits[e-1].prog)) >
p->inherits[e].storage_offset)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Overlapping inherits! (3)\n");
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | }
}
|
29338d | 1999-09-29 | Henrik Grubbström (Grubba) | |
|
7066e1 | 1999-09-14 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_FINISHED)
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<p->num_identifiers;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
check_string(p->identifiers[e].name);
|
4b9d80 | 2001-02-21 | Henrik Grubbström (Grubba) | | check_type_string(p->identifiers[e].type);
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
|
88e9fb | 2003-08-03 | Martin Stjernholm | | switch (p->identifiers[e].identifier_flags & IDENTIFIER_TYPE_MASK) {
case IDENTIFIER_VARIABLE:
case IDENTIFIER_PIKE_FUNCTION:
case IDENTIFIER_C_FUNCTION:
case IDENTIFIER_CONSTANT:
break;
default:
Pike_fatal("Invalid identifier type.\n");
}
|
97f628 | 2000-03-07 | Fredrik Hübinette (Hubbe) | | if(p->identifiers[e].identifier_flags & ~IDENTIFIER_MASK)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Unknown flags in identifier flag field.\n");
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | |
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))
{
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | if( (p->identifiers[e].func.offset ) &
|
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) | | {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Variable %s offset is not properly aligned (%ld).\n",
|
6f9590 | 2000-08-17 | Henrik Grubbström (Grubba) | | p->identifiers[e].name->str,
PTRDIFF_T_TO_LONG(p->identifiers[e].func.offset));
|
2f1b9e | 1998-04-06 | Fredrik Hübinette (Hubbe) | | }
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<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)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_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;
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("p->inherit[%d].prog = NULL!\n",p->identifier_references[e].inherit_offset);
|
513ece | 1999-09-09 | Fredrik Hübinette (Hubbe) | | }
|
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)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Identifier offset %d is wrong! %d > %d\n",
|
19be9f | 2001-07-02 | Fredrik Hübinette (Hubbe) | | e,
p->identifier_references[e].identifier_offset,
p->inherits[p->identifier_references[e].inherit_offset].prog->num_identifiers);
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
i=ID_FROM_INT(p, e);
|
88e9fb | 2003-08-03 | Martin Stjernholm | | if(IDENTIFIER_IS_VARIABLE(i->identifier_flags))
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | {
|
63540d | 2000-08-15 | Henrik Grubbström (Grubba) | | size_t q, size;
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
63540d | 2000-08-15 | Henrik Grubbström (Grubba) | | ptrdiff_t 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);
|
63540d | 2000-08-15 | Henrik Grubbström (Grubba) | | if((offset+size > (size_t)p->storage_needed) || offset<0)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Variable outside storage! (%s)\n",i->name->str);
|
e51d10 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
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)
{
|
2509e9 | 2001-07-02 | Henrik Grubbström (Grubba) | | fprintf(stderr, "Storage offset: 0x%08x vs 0x%08x\n"
"Func offset: 0x%08x vs 0x%08x\n"
"Type: %s vs %s\n",
INHERIT_FROM_INT(p, variable_positions[offset+q])->
storage_offset,
INHERIT_FROM_INT(p, e)->storage_offset,
ID_FROM_INT(p, variable_positions[offset+q])->func.offset,
i->func.offset,
get_name_of_type(ID_FROM_INT(p,variable_positions[offset+q]
)->run_time_type),
get_name_of_type(i->run_time_type));
|
66e2cf | 2001-06-10 | Henrik Grubbström (Grubba) | | if (i->name) {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Variable '%s' and '%s' overlap\n"
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | "Offset 0x%08x - 0x%08x overlaps with 0x%08x - 0x%08x\n",
|
66e2cf | 2001-06-10 | Henrik Grubbström (Grubba) | | ID_FROM_INT(p, variable_positions[offset+q])->name->str,
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | i->name->str,
INHERIT_FROM_INT(p, variable_positions[offset+q])->
storage_offset +
ID_FROM_INT(p, variable_positions[offset+q])->func.offset,
INHERIT_FROM_INT(p, variable_positions[offset+q])->
storage_offset +
ID_FROM_INT(p, variable_positions[offset+q])->func.offset +
sizeof_variable(ID_FROM_INT(p, variable_positions[offset+q]
|
2653e8 | 2001-07-02 | Henrik Grubbström (Grubba) | | )->run_time_type)-1,
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | offset, offset+size-1);
|
66e2cf | 2001-06-10 | Henrik Grubbström (Grubba) | | } else {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Variable '%s' and anonymous variable (%d) overlap\n"
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | "Offset 0x%08x - 0x%08x overlaps with 0x%08x - 0x%08x\n",
|
66e2cf | 2001-06-10 | Henrik Grubbström (Grubba) | | ID_FROM_INT(p, variable_positions[offset+q])->name->str,
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | e,
INHERIT_FROM_INT(p, variable_positions[offset+q])->
storage_offset +
ID_FROM_INT(p, variable_positions[offset+q])->func.offset,
INHERIT_FROM_INT(p, variable_positions[offset+q])->
storage_offset +
ID_FROM_INT(p, variable_positions[offset+q])->func.offset +
sizeof_variable(ID_FROM_INT(p, variable_positions[offset+q]
|
2653e8 | 2001-07-02 | Henrik Grubbström (Grubba) | | )->run_time_type)-1,
|
062628 | 2001-07-02 | Henrik Grubbström (Grubba) | | offset, offset+size-1);
|
66e2cf | 2001-06-10 | Henrik Grubbström (Grubba) | | }
|
68b695 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | }
}
variable_positions[offset+q]=e;
}
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
|
3c58e5 | 1999-09-22 | Henrik Grubbström (Grubba) | | for(e=0;e<p->num_identifier_index;e++)
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | {
if(p->identifier_index[e] > p->num_identifier_references)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program->identifier_indexes[%ld] is wrong\n",(long)e);
|
ab9db5 | 2003-02-20 | Henrik Grubbström (Grubba) | | if (e && (program_identifier_index_compare(p->identifier_index[e-1],
p->identifier_index[e],
p) > 0)) {
Pike_fatal("Program->identifier_index[%ld] > "
"Program->identifier_index[%ld]\n",
(long)(e-1), (long)e);
}
|
0d202a | 1995-10-20 | Fredrik Hübinette (Hubbe) | | }
}
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
cb6704 | 2001-12-12 | Martin Stjernholm | |
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | |
|
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;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_compiler->fake_object);
debug_malloc_touch(Pike_compiler->fake_object->storage);
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | |
|
de56ec | 2003-02-08 | Martin Stjernholm | | MAKE_CONST_STRING(s,"__INIT");
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | if (!(Pike_compiler->new_program->flags & PROGRAM_AVOID_CHECK)) {
for(e=Pike_compiler->new_program->num_inherits-1;e;e--)
|
0ffa00 | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | int id;
if(Pike_compiler->new_program->inherits[e].inherit_level!=1) continue;
id=low_reference_inherited_identifier(0, e, s, SEE_STATIC);
if(id!=-1)
{
Pike_compiler->init_node=mknode(F_COMMA_EXPR,
mkcastnode(void_type_string,
mkapplynode(mkidentifiernode(id),0)),
Pike_compiler->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) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->init_node)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
dc8062 | 2002-11-14 | Henrik Grubbström (Grubba) | | Pike_compiler->compiler_frame->current_function_number = -2;
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | e=dooptcode(s,
|
3d7882 | 1999-11-06 | Henrik Grubbström (Grubba) | | mknode(F_COMMA_EXPR,
|
dc8062 | 2002-11-14 | Henrik Grubbström (Grubba) | | Pike_compiler->init_node,
mknode(F_RETURN,mkintnode(0),0)),
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | function_type_string,
ID_STATIC);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->init_node=0;
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | } else if (finish == 2) {
e = low_find_lfun(Pike_compiler->new_program, LFUN___INIT);
|
a5787d | 1999-03-03 | Fredrik Hübinette (Hubbe) | | }else{
e=-1;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->lfuns[LFUN___INIT]=e;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | pop_compiler_frame();
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->num_parse_error > 0)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
prog=0;
}else{
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | prog=Pike_compiler->new_program;
|
8c8337 | 1998-04-16 | Fredrik Hübinette (Hubbe) | | add_ref(prog);
|
558069 | 1996-06-21 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->flags |= PROGRAM_PASS_1_DONE;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
if(finish)
{
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & PROGRAM_USES_PARENT)
{
Pike_compiler->new_program->parent_info_storage =
add_xstorage(sizeof(struct parent_info),
ALIGNOF(struct parent_info),
0);
}else{
Pike_compiler->new_program->parent_info_storage=-1;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | fixate_program();
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->num_parse_error)
{
free_program(prog);
prog=0;
}else{
optimize_program(Pike_compiler->new_program);
Pike_compiler->new_program->flags |= PROGRAM_FINISHED;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
aa771b | 2003-08-20 | Martin Stjernholm | | #ifdef PIKE_DEBUG
check_program(prog);
if(l_flag)
dump_program_desc(prog);
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
a78643 | 1999-11-18 | Martin Stjernholm | |
#ifdef PROGRAM_BUILD_DEBUG
fprintf (stderr, "%.*sfinishing program %d (pass=%d)\n",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | compilation_depth, " ", Pike_compiler->new_program->id, Pike_compiler->compiler_pass);
|
a78643 | 1999-11-18 | Martin Stjernholm | | #endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | toss_compilation_resources();
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
cb6704 | 2001-12-12 | Martin Stjernholm | | #if 0
|
aed42d | 1999-12-29 | Martin Stjernholm | | CDFPRINTF((stderr,
|
cb6704 | 2001-12-12 | Martin Stjernholm | | "th(%ld) end_first_pass(): "
"compilation_depth:%d, Pike_compiler->compiler_pass:%d\n",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | (long)th_self(), compilation_depth, Pike_compiler->compiler_pass));
|
cb6704 | 2001-12-12 | Martin Stjernholm | | #endif
|
aed42d | 1999-12-29 | Martin Stjernholm | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!Pike_compiler->compiler_frame && (Pike_compiler->compiler_pass==2 || !prog) && resolve_cache)
|
aed42d | 1999-12-29 | Martin Stjernholm | | {
free_mapping(dmalloc_touch(struct mapping *, resolve_cache));
resolve_cache=0;
}
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | #ifdef SHARED_NODES
#endif /* SHARED_NODES */
|
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) | |
|
b3cca7 | 2001-06-14 | Henrik Grubbström (Grubba) | | CDFPRINTF((stderr,
|
cb6704 | 2001-12-12 | Martin Stjernholm | | "th(%ld) %p end_first_pass(%d): "
"threads_disabled:%d, compilation_depth:%d\n",
(long)th_self(), prog, finish,
threads_disabled, compilation_depth));
|
b3cca7 | 2001-06-14 | Henrik Grubbström (Grubba) | |
|
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) | |
|
a8ef6e | 1996-12-03 | Fredrik Hübinette (Hubbe) | | free_all_nodes();
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return prog;
}
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT struct program *debug_end_program(void)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
37b022 | 2002-01-31 | Marcus Comstedt | | Pike_compiler->compiler_pass = 2;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | return end_first_pass(1);
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
b81935 | 2000-08-14 | Henrik Grubbström (Grubba) | | PMOD_EXPORT size_t low_add_storage(size_t size, size_t alignment,
ptrdiff_t modulo_orig)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | ptrdiff_t offset;
ptrdiff_t modulo;
|
2ad3c0 | 1999-09-16 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!size) return Pike_compiler->new_program->storage_needed;
|
2ad3c0 | 1999-09-16 | Fredrik Hübinette (Hubbe) | |
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
if(alignment <=0 || (alignment & (alignment-1)) || alignment > 256)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Alignment must be 1,2,4,8,16,32,64,128 or 256 not %ld\n",
|
69bb40 | 2000-08-17 | Henrik Grubbström (Grubba) | | PTRDIFF_T_TO_LONG(alignment));
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | #endif
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | modulo=( modulo_orig ) % alignment;
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | offset=DO_ALIGN(Pike_compiler->new_program->storage_needed-modulo,alignment)+modulo;
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!Pike_compiler->new_program->storage_needed) {
|
29338d | 1999-09-29 | Henrik Grubbström (Grubba) | | * Otherwise the debug code below ought to be trigged.
* But since it isn't, I guess this is dead code?
* /grubba 1999-09-28
|
eb071e | 1999-09-28 | Fredrik Hübinette (Hubbe) | | *
* No, the below offset represents the storage in the beginning
* of obj->storage which is not used because of alignment constraints.
* However, for historical reasons, prog->storage_offset needs to
* contain this unused space as well. This means that the real
* space used by all variables in an object is really:
* o->prog->storage_needed - o->prog->inherits[0].storage_offset,
* This can also be written as STORAGE_NEEDED(o->prog)
* STORAGE_NEEDED() is defined in program.h.
* /Hubbe 1999-09-29
|
0ee233 | 1999-09-29 | Henrik Grubbström (Grubba) | | *
* Oops, seems I read the test below the wrong way around.
* /grubba 1999-09-29
|
29338d | 1999-09-29 | Henrik Grubbström (Grubba) | | */
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->inherits[0].storage_offset=offset;
|
29338d | 1999-09-29 | Henrik Grubbström (Grubba) | | }
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->alignment_needed<alignment)
|
b81935 | 2000-08-14 | Henrik Grubbström (Grubba) | | Pike_compiler->new_program->alignment_needed =
DO_NOT_WARN((unsigned INT8)alignment);
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(offset < Pike_compiler->new_program->storage_needed)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("add_storage failed horribly!\n");
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | if( (offset - modulo_orig ) % alignment )
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("add_storage failed horribly(2) %ld %ld %ld %ld!\n",
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | DO_NOT_WARN((long)offset),
|
648a1a | 2000-06-22 | Fredrik Hübinette (Hubbe) | | (long)0 ,
|
63540d | 2000-08-15 | Henrik Grubbström (Grubba) | | DO_NOT_WARN((long)modulo_orig),
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | DO_NOT_WARN((long)alignment));
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | #endif
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->storage_needed = offset + size;
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | |
|
b81935 | 2000-08-14 | Henrik Grubbström (Grubba) | | return (size_t) offset;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | |
static size_t add_xstorage(size_t size,
size_t alignment,
ptrdiff_t modulo_orig)
{
ptrdiff_t offset, modulo, available;
int e;
if(!size) return Pike_compiler->new_program->xstorage;
modulo=( modulo_orig ) % alignment;
offset=DO_ALIGN(Pike_compiler->new_program->xstorage-modulo,alignment)+modulo;
Pike_compiler->new_program->xstorage = offset + size;
available = Pike_compiler->new_program->inherits[0].storage_offset;
|
21fdac | 2001-05-02 | Henrik Grubbström (Grubba) | | if(available < (ptrdiff_t)(offset+size))
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | {
available=
DO_ALIGN( ((offset + size) - available),
Pike_compiler->new_program->alignment_needed);
for(e=0;e<Pike_compiler->new_program->num_inherits;e++)
Pike_compiler->new_program->inherits[e].storage_offset+=available;
Pike_compiler->new_program->storage_needed+=available;
}
return (size_t) offset;
}
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | typedef void (*oldhandlertype)(struct object *);
|
b5dc81 | 2001-07-12 | Fredrik Hübinette (Hubbe) | | static void compat_event_handler(int e)
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | {
oldhandlertype handler;
|
d0787c | 2001-09-20 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_fp->current_object);
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | handler=((oldhandlertype *)Pike_fp->context.prog->program)[e];
if(handler) handler(Pike_fp->current_object);
|
d0787c | 2001-09-20 | Fredrik Hübinette (Hubbe) | | debug_malloc_touch(Pike_fp->current_object);
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | }
static void add_compat_event_handler(void)
{
if(Pike_compiler->new_program->event_handler != compat_event_handler)
{
unsigned int e,d;
unsigned char *tmp=(unsigned char *)&Pike_compiler->new_program->event_handler;
|
6d727b | 2001-07-08 | Henrik Grubbström (Grubba) | | for(d=0;d<NUM_PROG_EVENTS;d++) {
|
b5dc81 | 2001-07-12 | Fredrik Hübinette (Hubbe) | |
|
6d727b | 2001-07-08 | Henrik Grubbström (Grubba) | | #ifdef HAVE_COMPUTED_GOTO
add_to_program(Pike_compiler->new_program->event_handler);
#else /* !HAVE_COMPUTED_GOTO */
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | for(e=0;e<sizeof(Pike_compiler->new_program->event_handler);e++)
add_to_program(tmp[e]);
|
6d727b | 2001-07-08 | Henrik Grubbström (Grubba) | | #endif /* HAVE_COMPUTED_GOTO */
}
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->event_handler=compat_event_handler;
}
}
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | |
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | * This function is obsolete, use pike_set_prog_event_callback instead.
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | */
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT void set_init_callback(void (*init)(struct object *))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | add_compat_event_handler();
((oldhandlertype *)Pike_compiler->new_program->program)[PROG_EVENT_INIT]=init;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | * This function is obsolete, use pike_set_prog_event_callback instead.
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | */
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT void set_exit_callback(void (*exit)(struct object *))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | add_compat_event_handler();
((oldhandlertype *)Pike_compiler->new_program->program)[PROG_EVENT_EXIT]=exit;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | |
e2d9e6 | 2000-06-10 | Martin Stjernholm | | * This callback is used by the gc to traverse all references to
* objects. It should call some gc_recurse_* function exactly once for
* each reference that the pike internals doesn't know about.
*
* If a reference is shared between objects, it should be traversed
* once for every instance sharing it.
*
* The callback might be called more than once for the same instance
* during a gc pass. The gc assumes that the references are enumerated
* in the same order in that case.
|
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | *
* This function is obsolete, use pike_set_prog_event_callback instead.
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | */
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT void set_gc_recurse_callback(void (*m)(struct object *))
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | {
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | add_compat_event_handler();
((oldhandlertype *)Pike_compiler->new_program->program)[PROG_EVENT_GC_RECURSE]=m;
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | }
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | |
e2d9e6 | 2000-06-10 | Martin Stjernholm | | * This callback is used by the gc to count all references to objects.
* It should call gc_check, gc_check_(weak_)svalues or
* gc_check_(weak_)short_svalue exactly once for each reference that
* the pike internals doesn't know about.
*
* If a reference is shared between objects, it should be counted once
* for all shared instances. The return value from gc_check is useful
* to ensure this; it's zero when called the first time for its
* argument.
|
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | *
* This function is obsolete, use pike_set_prog_event_callback instead.
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | */
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT void set_gc_check_callback(void (*m)(struct object *))
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | {
|
763f68 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | add_compat_event_handler();
((oldhandlertype *)Pike_compiler->new_program->program)[PROG_EVENT_GC_CHECK]=m;
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | }
|
b5dc81 | 2001-07-12 | Fredrik Hübinette (Hubbe) | | void pike_set_prog_event_callback(void (*cb)(int))
|
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | {
#ifdef PIKE_DEBUG
if(Pike_compiler->new_program->event_handler)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program already has an event handler!\n");
|
03bcb9 | 2001-03-12 | Fredrik Hübinette (Hubbe) | | #endif
Pike_compiler->new_program->event_handler=cb;
}
|
a5d45c | 2001-05-26 | Henrik Grubbström (Grubba) | | void pike_set_prog_optimize_callback(node *(*opt)(node *))
{
#ifdef PIKE_DEBUG
if(Pike_compiler->new_program->optimize)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Program already has an optimize handler!\n");
|
a5d45c | 2001-05-26 | Henrik Grubbström (Grubba) | | #endif
Pike_compiler->new_program->optimize = opt;
}
|
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) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | struct program *np=(q?q:Pike_compiler)->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;
|
5ec106 | 2002-05-09 | Martin Stjernholm | | funp.id_flags = (funp.id_flags & ~ID_INHERITED) | ID_INLINE|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) | | {
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | struct reference *refp;
refp=np->identifier_references+d;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | if(!MEMCMP((char *)refp,(char *)&funp,sizeof funp)) return d;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
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) | | }
|
ba8c39 | 2000-06-26 | Henrik Grubbström (Grubba) | | int find_inherit(struct program *p, struct pike_string *name)
|
9a3e73 | 2000-06-26 | Henrik Grubbström (Grubba) | | {
int e;
|
ba8c39 | 2000-06-26 | Henrik Grubbström (Grubba) | | #if 0
fprintf(stderr, "find_inherit(0x%08lx, \"%s\")...\n",
(unsigned long)p, name->str);
#endif /* 0 */
for(e = p->num_inherits-1; e>0; e--) {
#if 0
fprintf(stderr, " %04d: %04d %s\n",
e, p->inherits[e].inherit_level,
p->inherits[e].name?p->inherits[e].name->str:"NULL");
#endif /* 0 */
if (p->inherits[e].inherit_level > 1) continue;
|
9a3e73 | 2000-06-26 | Henrik Grubbström (Grubba) | | if (name == p->inherits[e].name) return e;
}
return 0;
}
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | node *reference_inherited_identifier(struct pike_string *super_name,
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | 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;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | struct program_state *state=Pike_compiler->previous;
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
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))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("reference_inherited_function on nonshared string.\n");
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #endif
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | p=Pike_compiler->new_program;
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
|
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,"`[]"))
{
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | return mknode(F_MAGIC_INDEX,mknewintnode(e),mknewintnode(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,"`[]="))
{
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | return mknode(F_MAGIC_SET_INDEX,mknewintnode(e),mknewintnode(0));
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
|
cbe113 | 2001-12-16 | Martin Stjernholm | |
if(ISCONSTSTR(function_name,"_indices"))
{
return mknode(F_MAGIC_INDICES,mknewintnode(e),mknewintnode(0));
}
if(ISCONSTSTR(function_name,"_values"))
{
return mknode(F_MAGIC_VALUES,mknewintnode(e),mknewintnode(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;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | for(e=p->num_inherits-1;e>0;e--)
{
if(p->inherits[e].inherit_level!=1) continue;
if(!p->inherits[e].name) continue;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | if(super_name)
if(super_name != p->inherits[e].name)
continue;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
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)
|
ff88db | 2000-07-12 | Henrik Grubbström (Grubba) | | return mkexternalnode(p, id);
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | |
if(ISCONSTSTR(function_name,"`->") ||
ISCONSTSTR(function_name,"`[]"))
{
|
55aa4a | 2000-01-27 | Fredrik Hübinette (Hubbe) | | return mknode(F_MAGIC_INDEX,
mknewintnode(e),mknewintnode(n+1));
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | if(ISCONSTSTR(function_name,"`->=") ||
ISCONSTSTR(function_name,"`[]="))
{
|
55aa4a | 2000-01-27 | Fredrik Hübinette (Hubbe) | | return mknode(F_MAGIC_SET_INDEX,
mknewintnode(e),mknewintnode(n+1));
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
|
cbe113 | 2001-12-16 | Martin Stjernholm | |
if(ISCONSTSTR(function_name,"_indices"))
{
return mknode(F_MAGIC_INDICES,
mknewintnode(e),mknewintnode(n+1));
}
if(ISCONSTSTR(function_name,"_values"))
{
return mknode(F_MAGIC_VALUES,
mknewintnode(e),mknewintnode(n+1));
}
|
a005eb | 1999-03-04 | Fredrik Hübinette (Hubbe) | | }
|
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) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->inherits[Pike_compiler->new_program->num_inherits].name)
free_string(Pike_compiler->new_program->inherits[Pike_compiler->new_program->num_inherits].name);
copy_shared_string(Pike_compiler->new_program->inherits[Pike_compiler->new_program->num_inherits].name,
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | n);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
88e9fb | 2003-08-03 | Martin Stjernholm | | #if 0
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | static int locate_parent_state(struct program_state **state,
struct inherit **i,
int *parent_identifier,
int depth)
{
int result=1;
if(depth<=0) return depth;
while(depth-->0)
{
|
684bd2 | 2003-08-02 | Martin Stjernholm | | if( (*i)->parent_offset != INHERIT_PARENT)
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | {
int tmp=(*i)->parent_identifier;
if( (*i)->parent_offset > 0)
{
int po=(*i)->parent_offset;
*parent_identifier = (*state)->parent_identifier;
*state = (*state)->previous;
result++;
fprintf(stderr,"INHERIT: state=state->previous (po=%d)\n",po);
if(po>1)
{
*i=INHERIT_FROM_INT( (*state)->new_program,
*parent_identifier);
result+=locate_parent_state(state,i,parent_identifier, po-1);
}
}
if(tmp != -1)
{
if( *parent_identifier == -4711)
{
*parent_identifier = tmp;
}else{
*parent_identifier = tmp + INHERIT_FROM_INT( (*state)->new_program,
*parent_identifier)->identifier_level;
}
}
}else{
fprintf(stderr,"INHERIT: Bailout!\n");
return result+depth+1;
}
*i = INHERIT_FROM_INT( (*state)->new_program, *parent_identifier);
}
return result;
}
static int find_depth(struct program_state *state,
struct inherit *i,
int parent_identifier,
int depth)
{
#if 0
int e;
struct inherit *oi;
for(e=0;e<=parent_offset;e++) state=state->previous;
oi=INHERIT_FROM_INT(state->new_program, parent_identifier);
parent_offset+=i->parent_offset;
#endif
return locate_parent_state(&state,
&i,
&parent_identifier,
depth);
}
|
88e9fb | 2003-08-03 | Martin Stjernholm | | #endif
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
5582a8 | 2000-08-28 | 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) | | {
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | int e;
ptrdiff_t inherit_offset, storage_offset;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | struct inherit inherit;
|
02a79a | 2000-09-04 | Fredrik Hübinette (Hubbe) | | #if 0
|
0f2b44 | 2001-12-14 | Martin Stjernholm | | fprintf(stderr,"%p low_inherit(pid=%d, parent=%p, parid=%d, "
"paroff=%d, flags=0x%x, name=%s);\n",
Pike_compiler->new_program,
p ? p->id : 0,
|
02a79a | 2000-09-04 | Fredrik Hübinette (Hubbe) | | parent,
parent_identifier,
parent_offset,
flags,
name? name->str : "");
#endif
|
a35974 | 2001-12-16 | Martin Stjernholm | | CDFPRINTF((stderr, "th(%ld) %p inherit %p\n",
(long) th_self(), Pike_compiler->new_program, p));
|
02a79a | 2000-09-04 | 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) | |
|
bd537b | 2002-12-10 | Martin Stjernholm | | if (p == placeholder_program) {
yyerror("Trying to inherit placeholder program (resolver problem).");
return;
}
|
0f2b44 | 2001-12-14 | Martin Stjernholm | |
|
22d799 | 2001-06-23 | Fredrik Hübinette (Hubbe) | | if(p->flags & PROGRAM_NEEDS_PARENT)
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | {
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | struct program_state *state=Pike_compiler;
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | 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) | | }
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | |
#if 0
|
0f2b44 | 2001-12-14 | Martin Stjernholm | | |
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | * previous compilations, but I'm too lazy to figure out
* exactly how deep down we need to go...
*/
for(e=0;e<compilation_depth;e++,state=state->previous)
state->new_program->flags |= PROGRAM_USES_PARENT;
#endif
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | }
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | |
|
313989 | 1999-09-06 | Henrik Grubbström (Grubba) | | if(parent_offset)
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | parent_offset-=42;
|
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;
}
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | inherit_offset = Pike_compiler->new_program->num_inherits;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | |
|
9386f7 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | storage_offset=p->inherits[0].storage_offset % p->alignment_needed;
|
1f5bfe | 1999-09-28 | Fredrik Hübinette (Hubbe) | | storage_offset=low_add_storage(STORAGE_NEEDED(p),
|
90e978 | 1999-01-31 | Fredrik Hübinette (Hubbe) | | p->alignment_needed,
|
b1c803 | 1999-09-15 | Fredrik Hübinette (Hubbe) | | storage_offset);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
1f5bfe | 1999-09-28 | Fredrik Hübinette (Hubbe) | |
|
27ae84 | 2000-02-07 | Per Hedbor | | storage_offset-=p->inherits[0].storage_offset;
|
1f5bfe | 1999-09-28 | 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);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | inherit.identifier_level += Pike_compiler->new_program->num_identifier_references;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | inherit.storage_offset += storage_offset;
inherit.inherit_level ++;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | |
|
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)
{
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | #if 0
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | struct object *o;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | inherit.parent_offset=0;
for(o=Pike_compiler->fake_object;o!=parent;o=o->parent)
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | {
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
5aad93 | 2002-08-15 | Marcus Comstedt | | if(!o) Pike_fatal("low_inherit with odd Pike_compiler->fake_object as parent!\n");
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | #endif
inherit.parent_offset++;
}
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | #else
struct program_state *state=Pike_compiler;
inherit.parent_offset=0;
for(;state->fake_object!=parent;state=state->previous)
{
#ifdef PIKE_DEBUG
if(!state->fake_object)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("low_inherit with odd Pike_compiler->fake_object as parent!\n");
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | #endif
inherit.parent_offset++;
}
#endif
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | }else{
inherit.parent=parent;
inherit.parent_identifier=parent_identifier;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | inherit.parent_offset=INHERIT_PARENT;
|
9e5238 | 1998-03-01 | Fredrik Hübinette (Hubbe) | | }
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }else{
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | 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{
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | if(!inherit.parent)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | {
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | if(parent && parent->next != parent && inherit.parent_offset)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | {
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | struct object *par=parent;
int e,pid=parent_identifier;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | |
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | for(e=1;e<inherit.parent_offset;e++)
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | {
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | struct inherit *in;
if(!par->prog)
{
par=0;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | pid=-1;
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | break;
}
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | in=INHERIT_FROM_INT(par->prog, pid);
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | switch(in->parent_offset)
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | {
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | default:
{
struct external_variable_context tmp;
struct inherit *in2=in;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | while(in2->inherit_level >= in->inherit_level) in2--;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | tmp.o=par;
tmp.inherit=in2;
tmp.parent_identifier=pid;
find_external_context(&tmp, in->parent_offset);
|
5222e9 | 2000-08-24 | Henrik Grubbström (Grubba) | | par = tmp.o;
pid = tmp.parent_identifier;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | }
break;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | case INHERIT_PARENT:
|
5222e9 | 2000-08-24 | Henrik Grubbström (Grubba) | | pid = in->parent_identifier;
par = in->parent;
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | break;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | case OBJECT_PARENT:
|
4d51e0 | 2002-06-10 | Martin Stjernholm | |
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | if(par->prog->flags & PROGRAM_USES_PARENT)
{
pid = PARENT_INFO(par)->parent_identifier;
par = PARENT_INFO(par)->parent;
}else{
pid=-1;
par=0;
}
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | }
|
199498 | 1998-04-07 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5f05c1 | 1999-12-27 | Fredrik Hübinette (Hubbe) | | inherit.parent=par;
|
684bd2 | 2003-08-02 | Martin Stjernholm | | inherit.parent_offset=INHERIT_PARENT;
|
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)
{
|
684bd2 | 2003-08-02 | Martin Stjernholm | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | 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) | | }
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | |
Pike_compiler->new_program->inherits[inherit_offset].identifier_ref_offset =
Pike_compiler->new_program->num_identifier_references;
|
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) | | {
|
3b7d18 | 2001-09-26 | Fredrik Hübinette (Hubbe) | | Pike_compiler->check_final++;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
9f1f30 | 2001-09-27 | Per Hedbor | |
|
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) | | }
}
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT void do_inherit(struct svalue *s,
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | INT32 flags,
struct pike_string *name)
{
struct program *p=program_from_svalue(s);
|
5582a8 | 2000-08-28 | Fredrik Hübinette (Hubbe) | | low_inherit(p,
s->type == T_FUNCTION ? s->u.object : 0,
s->type == T_FUNCTION ? s->subtype : -1,
0,
flags,
name);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
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;
|
5582a8 | 2000-08-28 | Fredrik Hübinette (Hubbe) | | INT32 numid=-1, offset=0;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
2416d8 | 1998-01-27 | Fredrik Hübinette (Hubbe) | | if(!n)
{
yyerror("Unable to inherit");
return;
}
|
a31a10 | 2003-08-21 | Henrik Grubbström (Grubba) | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | switch(n->token)
{
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | case F_IDENTIFIER:
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | p=Pike_compiler->new_program;
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | offset=0;
|
f807f0 | 1999-11-11 | Henrik Grubbström (Grubba) | | numid=n->u.id.number;
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | goto continue_inherit;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | case F_EXTERNAL:
{
|
342fef | 2000-08-23 | Fredrik Hübinette (Hubbe) | | struct program_state *state = Pike_compiler;
|
ff88db | 2000-07-12 | Henrik Grubbström (Grubba) | |
|
5582a8 | 2000-08-28 | Fredrik Hübinette (Hubbe) | | offset = 0;
|
ff88db | 2000-07-12 | Henrik Grubbström (Grubba) | | while (state && (state->new_program->id != n->u.integer.a)) {
state = state->previous;
offset++;
}
if (!state) {
yyerror("Failed to resolv external constant.\n");
return;
}
p = state->new_program;
numid = n->u.integer.b;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | continue_inherit:
|
88e9fb | 2003-08-03 | Martin Stjernholm | | if(numid != IDREF_MAGIC_THIS &&
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | (IDENTIFIER_IS_CONSTANT((i=ID_FROM_INT(p, numid))->
identifier_flags)) &&
(i->func.offset != -1))
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | {
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | struct svalue *s=&PROG_FROM_INT(p, numid)->
constants[i->func.offset].sval;
|
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{
|
684bd2 | 2003-08-02 | Martin Stjernholm | | low_inherit(s->u.program,
0,
numid,
offset+42,
flags,
name);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
}else{
yyerror("Inherit identifier is not a constant program");
return;
}
break;
default:
|
086acc | 1999-09-11 | Fredrik Hübinette (Hubbe) | | resolv_class(n);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | do_inherit(Pike_sp-1, flags, name);
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | pop_stack();
}
}
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
9036e8 | 2001-08-16 | Martin Stjernholm | | int call_handle_inherit(struct pike_string *s)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
9036e8 | 2001-08-16 | Martin Stjernholm | | int args;
|
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);
|
9036e8 | 2001-08-16 | Martin Stjernholm | | if (error_handler && error_handler->prog) {
ref_push_object(error_handler);
args = 3;
}
else args = 2;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
9036e8 | 2001-08-16 | Martin Stjernholm | | if (safe_apply_handler("handle_inherit", error_handler, compat_handler,
args, BIT_PROGRAM|BIT_FUNCTION|BIT_ZERO))
if (Pike_sp[-1].type != T_INT)
return 1;
else {
pop_stack();
if (!s->size_shift)
my_yyerror("Couldn't find program: %s",s->str);
else
yyerror("Couldn't find program");
}
else {
struct svalue thrown = throw_value;
throw_value.type = T_INT;
|
a6ded6 | 2003-05-16 | Henrik Grubbström (Grubba) | | dmalloc_touch_svalue(&thrown);
|
9036e8 | 2001-08-16 | Martin Stjernholm | | my_yyerror("Error finding program");
push_svalue(&thrown);
low_safe_apply_handler("compile_exception", error_handler, compat_handler, 1);
|
9f516a | 2001-12-16 | Martin Stjernholm | | if (SAFE_IS_ZERO(sp-1)) yy_describe_exception(&thrown);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | pop_stack();
|
9036e8 | 2001-08-16 | Martin Stjernholm | | free_svalue(&thrown);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
9036e8 | 2001-08-16 | Martin Stjernholm | | return 0;
}
void simple_do_inherit(struct pike_string *s,
INT32 flags,
struct pike_string *name)
{
if (!call_handle_inherit(s)) return;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(name)
{
free_string(s);
s=name;
}
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | do_inherit(Pike_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) | | {
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | return really_low_find_shared_string_identifier(s,
Pike_compiler->new_program,
|
baf400 | 2002-04-07 | Henrik Grubbström (Grubba) | | SEE_STATIC|SEE_PRIVATE);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | int low_define_variable(struct pike_string *name,
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_type *type,
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | INT32 flags,
|
de1d7d | 2000-07-10 | Henrik Grubbström (Grubba) | | size_t offset,
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | 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
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Attempting to add variable to fixed program\n");
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->compiler_pass==2)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Internal error: Not allowed to add more identifiers during second compiler pass.\n"
|
05bfe2 | 1998-07-20 | Henrik Grubbström (Grubba) | | "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);
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(dummy.type, type);
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | if (flags & ID_ALIAS) {
|
88e9fb | 2003-08-03 | Martin Stjernholm | | dummy.identifier_flags = IDENTIFIER_VARIABLE | IDENTIFIER_ALIAS;
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | } else {
|
88e9fb | 2003-08-03 | Martin Stjernholm | | dummy.identifier_flags = IDENTIFIER_VARIABLE;
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | }
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | dummy.run_time_type=run_time_type;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | dummy.func.offset=offset - Pike_compiler->new_program->inherits[0].storage_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;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | ref.identifier_offset=Pike_compiler->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);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | | debug_add_to_identifiers(dummy);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | n=Pike_compiler->new_program->num_identifier_references;
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_identifier_references(ref);
|
05590d | 1998-04-23 | Fredrik Hübinette (Hubbe) | |
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | return n;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int map_variable(const char *name,
const char *type,
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | INT32 flags,
|
de1d7d | 2000-07-10 | Henrik Grubbström (Grubba) | | size_t offset,
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | INT32 run_time_type)
{
int ret;
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_string *n;
struct pike_type *t;
|
a78643 | 1999-11-18 | Martin Stjernholm | |
#ifdef PROGRAM_BUILD_DEBUG
fprintf (stderr, "%.*sdefining variable (pass=%d): %s %s\n",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | compilation_depth, " ", Pike_compiler->compiler_pass, type, name);
|
a78643 | 1999-11-18 | Martin Stjernholm | | #endif
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | n=make_shared_string(name);
t=parse_type(type);
ret=low_define_variable(n,t,flags,offset,run_time_type);
free_string(n);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(t);
|
d4828c | 1997-07-17 | Fredrik Hübinette (Hubbe) | | return ret;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int quick_map_variable(const char *name,
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | int name_length,
|
de1d7d | 2000-07-10 | Henrik Grubbström (Grubba) | | size_t offset,
|
0929a0 | 2002-09-12 | Marcus Comstedt | | const char *type,
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | int type_length,
INT32 run_time_type,
INT32 flags)
{
int ret;
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_string *n;
struct pike_type *t;
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | |
|
8a2a52 | 2001-03-03 | Henrik Grubbström (Grubba) | | n = make_shared_binary_string(name, name_length);
t = make_pike_type(type);
|
aed520 | 2002-05-01 | Martin Stjernholm | |
#ifdef PROGRAM_BUILD_DEBUG
{
|
f34f64 | 2002-05-05 | Martin Stjernholm | | struct pike_string *d = describe_type (t);
fprintf (stderr, "%.*sdefining variable (pass=%d): %s ",
compilation_depth, " ", Pike_compiler->compiler_pass, d->str);
free_string (d);
|
aed520 | 2002-05-01 | Martin Stjernholm | | push_string (n);
print_svalue (stderr, --Pike_sp);
putc ('\n', stderr);
}
#endif
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | ret=low_define_variable(n,t,flags,offset,run_time_type);
free_string(n);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(t);
|
e2d9e6 | 2000-06-10 | Martin Stjernholm | | 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,
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_type *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))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("define_variable on nonshared string.\n");
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | #endif
|
a78643 | 1999-11-18 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
{
|
f34f64 | 2002-05-05 | Martin Stjernholm | | struct pike_string *d = describe_type (type);
fprintf (stderr, "%.*sdefining variable (pass=%d): %s ",
compilation_depth, " ", Pike_compiler->compiler_pass, d->str);
free_string (d);
|
a78643 | 1999-11-18 | Martin Stjernholm | | push_string (name);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | print_svalue (stderr, --Pike_sp);
|
a78643 | 1999-11-18 | Martin Stjernholm | | putc ('\n', stderr);
}
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(type == void_type_string)
yyerror("Variables can't be of type void");
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | n = isidentifier(name);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & PROGRAM_PASS_1_DONE)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
if(n==-1)
yyerror("Pass2: Variable disappeared!");
|
a78643 | 1999-11-18 | Martin Stjernholm | | else {
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | struct identifier *id=ID_FROM_INT(Pike_compiler->new_program,n);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(id->type);
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(id->type, type);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | return n;
|
a78643 | 1999-11-18 | Martin Stjernholm | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | }
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Attempting to add variable to fixed program\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | if(n != -1)
{
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->identifier_references[n].inherit_offset == 0)
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | {
|
e77439 | 1999-12-31 | Henrik Grubbström (Grubba) | | if (!((IDENTIFIERP(n)->id_flags | flags) & ID_EXTERN)) {
my_yyerror("Identifier '%s' defined twice.",name->str);
return n;
}
if (flags & ID_EXTERN) {
return n;
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | }
|
e77439 | 1999-12-31 | Henrik Grubbström (Grubba) | | if (!(IDENTIFIERP(n)->id_flags & ID_EXTERN)) {
if (IDENTIFIERP(n)->id_flags & ID_NOMASK)
my_yyerror("Illegal to redefine 'nomask/final' "
"variable/functions \"%s\"", name->str);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!(IDENTIFIERP(n)->id_flags & ID_INLINE) || Pike_compiler->compiler_pass!=1)
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | | {
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | int n2;
if(ID_FROM_INT(Pike_compiler->new_program, n)->type != type &&
!pike_types_le(type,
ID_FROM_INT(Pike_compiler->new_program, n)->type)) {
if (!match_types(ID_FROM_INT(Pike_compiler->new_program, n)->type,
type)) {
my_yyerror("Illegal to redefine inherited variable '%s' "
"with different type.", name->str);
return n;
} else {
yywarning("Redefining inherited variable '%s' "
"with different type.", name->str);
}
}
|
9eaa6e | 2000-02-12 | Fredrik Hübinette (Hubbe) | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(!IDENTIFIER_IS_VARIABLE(ID_FROM_INT(Pike_compiler->new_program, n)->
|
e77439 | 1999-12-31 | Henrik Grubbström (Grubba) | | identifier_flags))
{
my_yyerror("Illegal to redefine inherited variable "
"with different type.");
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | return n;
|
e77439 | 1999-12-31 | Henrik Grubbström (Grubba) | | }
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | if ((ID_FROM_INT(Pike_compiler->new_program, n)->run_time_type !=
PIKE_T_MIXED) &&
(ID_FROM_INT(Pike_compiler->new_program, n)->run_time_type !=
compile_type_to_runtime_type(type))) {
my_yyerror("Illegal to redefine inherited variable "
"with different type.");
return n;
}
n2 = low_define_variable(name, type,
(flags | ID_ALIAS) & ~ID_EXTERN,
ID_FROM_INT(Pike_compiler->new_program, n)->
func.offset +
INHERIT_FROM_INT(Pike_compiler->new_program,
n)->storage_offset,
ID_FROM_INT(Pike_compiler->new_program, n)->
run_time_type);
|
1dd921 | 2003-03-14 | Henrik Grubbström (Grubba) | |
ID_FROM_INT(Pike_compiler->new_program, n2)->identifier_flags |=
ID_FROM_INT(Pike_compiler->new_program, n)->identifier_flags &
IDENTIFIER_NO_THIS_REF;
|
901cf8 | 2001-07-03 | Henrik Grubbström (Grubba) | |
Pike_compiler->new_program->identifier_references[n].id_flags |=
|
37cd45 | 2003-06-09 | Martin Stjernholm | | ID_HIDDEN;
|
eff2b0 | 2001-07-03 | Henrik Grubbström (Grubba) | | return n2;
|
e77439 | 1999-12-31 | Henrik Grubbström (Grubba) | | }
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
}
|
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)
{
|
2ba919 | 1999-10-23 | Fredrik Hübinette (Hubbe) | | #ifdef AUTO_BIGNUM
|
095753 | 1999-10-25 | Fredrik Hübinette (Hubbe) | | #if 0
|
659ccc | 1999-10-25 | Fredrik Hübinette (Hubbe) | | case T_OBJECT:
|
095753 | 1999-10-25 | Fredrik Hübinette (Hubbe) | | #endif
|
2ba919 | 1999-10-23 | Fredrik Hübinette (Hubbe) | | case T_INT:
#endif
|
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) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
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);
|
7d6575 | 2003-06-04 | Henrik Grubbström (Grubba) | |
|
e0d6f5 | 2003-02-13 | Martin Stjernholm | | ID_FROM_INT(Pike_compiler->new_program, n)->identifier_flags |= IDENTIFIER_NO_THIS_REF;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
return n;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int simple_add_variable(const char *name,
const char *type,
INT32 flags)
|
574088 | 1998-01-01 | Fredrik Hübinette (Hubbe) | | {
INT32 ret;
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_string *name_s;
struct pike_type *type_s;
|
babd87 | 2001-02-23 | Henrik Grubbström (Grubba) | | name_s = make_shared_string(name);
type_s = parse_type(type);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
574088 | 1998-01-01 | Fredrik Hübinette (Hubbe) | | ret=define_variable(name_s, type_s, flags);
free_string(name_s);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(type_s);
|
574088 | 1998-01-01 | Fredrik Hübinette (Hubbe) | | return ret;
}
|
1f2133 | 2000-07-28 | Fredrik Hübinette (Hubbe) | | PMOD_EXPORT int add_constant(struct pike_string *name,
|
fd9827 | 2002-07-03 | Henrik Grubbström (Grubba) | | struct svalue *c,
INT32 flags)
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | {
int n;
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | | struct identifier dummy;
struct reference ref;
|
9dd69a | 2002-03-04 | Martin Stjernholm | | struct svalue zero;
|
a78643 | 1999-11-18 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
{
if (c) {
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_type *t = get_type_of_svalue(c);
|
a78643 | 1999-11-18 | Martin Stjernholm | | struct pike_string *d = describe_type (t);
fprintf (stderr, "%.*sdefining constant (pass=%d): %s ",
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | compilation_depth, " ",
Pike_compiler->compiler_pass, d->str);
free_type(t);
|
a78643 | 1999-11-18 | Martin Stjernholm | | free_string (d);
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | push_string (name);
print_svalue (stderr, --Pike_sp);
fputs (" = ", stderr);
print_svalue (stderr, c);
|
a78643 | 1999-11-18 | Martin Stjernholm | | }
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | else {
|
a78643 | 1999-11-18 | Martin Stjernholm | | fprintf (stderr, "%.*sdeclaring constant (pass=%d): ",
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | compilation_depth, " ",
Pike_compiler->compiler_pass);
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | push_string (name);
print_svalue (stderr, --Pike_sp);
}
|
a78643 | 1999-11-18 | Martin Stjernholm | | putc ('\n', stderr);
}
#endif
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 0
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | if (!c) {
zero.type = T_INT;
zero.subtype = 0;
zero.u.integer = 0;
c = &zero;
}
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #endif
|
fa0b2e | 2002-05-12 | Martin Stjernholm | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(name!=debug_findstring(name))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("define_constant on nonshared string.\n");
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | #endif
|
a31a10 | 2003-08-21 | Henrik Grubbström (Grubba) | | n = isidentifier(name);
|
c4a08a | 2003-08-22 | Martin Stjernholm | | if(
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 1
|
c4a08a | 2003-08-22 | Martin Stjernholm | | c &&
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #endif
|
c4a08a | 2003-08-22 | Martin Stjernholm | | c->type == T_FUNCTION &&
c->subtype != FUNCTION_BUILTIN &&
c->u.object->prog)
{
struct reference *idref = PTR_FROM_INT(c->u.object->prog, c->subtype);
struct program *p = PROG_FROM_PTR(c->u.object->prog, idref);
struct identifier *id = p->identifiers + idref->identifier_offset;
if(c->u.object->prog == Pike_compiler->new_program) {
if(IDENTIFIER_IS_CONSTANT(id->identifier_flags) &&
id->func.offset != -1) {
c=& p->constants[id->func.offset].sval;
}
else if (IDENTIFIER_IS_FUNCTION(id->identifier_flags)) {
if (!idref->inherit_offset) {
return define_function(name,
id->type,
flags,
id->identifier_flags | IDENTIFIER_ALIAS,
& id->func,
id->opt_flags);
} else if (Pike_compiler->new_program->flags & PROGRAM_PASS_1_DONE) {
yyerror("Aliasing of inherited functions not supported yet.");
return define_function(name,
id->type,
flags,
id->identifier_flags | IDENTIFIER_ALIAS,
NULL,
id->opt_flags);
} else {
return define_function(name,
id->type,
flags,
id->identifier_flags | IDENTIFIER_ALIAS,
NULL,
id->opt_flags);
|
84387d | 2001-09-24 | Fredrik Hübinette (Hubbe) | | }
|
c4a08a | 2003-08-22 | Martin Stjernholm | | } else if (IDENTIFIER_IS_VARIABLE(id->identifier_flags)) {
yyerror("Attempt to make a constant of a variable.");
c = NULL;
|
84387d | 2001-09-24 | Fredrik Hübinette (Hubbe) | | }
}
|
c4a08a | 2003-08-22 | Martin Stjernholm | | }
|
84387d | 2001-09-24 | Fredrik Hübinette (Hubbe) | |
|
c4a08a | 2003-08-22 | Martin Stjernholm | | if(
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 1
|
c4a08a | 2003-08-22 | Martin Stjernholm | | c &&
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #endif
|
c4a08a | 2003-08-22 | Martin Stjernholm | | !svalues_are_constant(c,1,BIT_MIXED,0))
yyerror("Constant values may not have references to this.");
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & PROGRAM_PASS_1_DONE)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | if(n==-1
#if 1
|| !c
#endif
)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
yyerror("Pass2: Constant disappeared!");
}else{
struct identifier *id;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | id=ID_FROM_INT(Pike_compiler->new_program,n);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | if(id->func.offset>=0)
{
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_type *s;
|
fa0b2e | 2002-05-12 | Martin Stjernholm | |
#if 0
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | struct svalue *c=&PROG_FROM_INT(Pike_compiler->new_program,n)->
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | constants[id->func.offset].sval;
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #else
assign_svalue (&PROG_FROM_INT(Pike_compiler->new_program,n)->
constants[id->func.offset].sval, c);
#endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | s=get_type_of_svalue(c);
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(id->type);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | id->type=s;
}
|
a78643 | 1999-11-18 | Martin Stjernholm | | else {
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 1
|
a78643 | 1999-11-18 | Martin Stjernholm | | #ifdef PIKE_DEBUG
|
5aad93 | 2002-08-15 | Marcus Comstedt | | if (!c) Pike_fatal("Can't declare constant during second compiler pass\n");
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(id->type);
|
a78643 | 1999-11-18 | Martin Stjernholm | | id->type = get_type_of_svalue(c);
id->run_time_type = c->type;
id->func.offset = store_constant(c, 0, 0);
}
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
fprintf (stderr, "%.*sstored constant #%d at %d\n",
compilation_depth, " ",
n, id->func.offset);
#endif
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | return n;
}
}
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->flags & (PROGRAM_FIXED | PROGRAM_OPTIMIZED))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Attempting to add constant to fixed program\n");
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->compiler_pass==2)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_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);
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | dummy.identifier_flags = IDENTIFIER_CONSTANT;
|
a78643 | 1999-11-18 | Martin Stjernholm | |
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 1
|
a78643 | 1999-11-18 | Martin Stjernholm | | if (c) {
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #endif
|
a78643 | 1999-11-18 | Martin Stjernholm | | dummy.type = get_type_of_svalue(c);
dummy.run_time_type=c->type;
dummy.func.offset=store_constant(c, 0, 0);
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | dummy.opt_flags=OPT_SIDE_EFFECT | OPT_EXTERNAL_DEPEND;
if(c->type == PIKE_T_PROGRAM && (c->u.program->flags & PROGRAM_CONSTANT))
dummy.opt_flags=0;
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | #if 1
|
a78643 | 1999-11-18 | Martin Stjernholm | | }
else {
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(dummy.type, mixed_type_string);
|
a78643 | 1999-11-18 | Martin Stjernholm | | dummy.run_time_type=T_MIXED;
dummy.func.offset=-1;
|
f3c715 | 2001-04-14 | Fredrik Hübinette (Hubbe) | | dummy.opt_flags=0;
|
a78643 | 1999-11-18 | Martin Stjernholm | | }
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #endif
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | |
|
7fda7a | 1997-09-08 | Fredrik Hübinette (Hubbe) | | ref.id_flags=flags;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | ref.identifier_offset=Pike_compiler->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
|
5ec106 | 2002-05-09 | Martin Stjernholm | | debug_add_to_identifiers(dummy);
|
2d1234 | 1997-03-10 | Fredrik Hübinette (Hubbe) | |
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | if(n != -1)
{
|
5ec106 | 2002-05-09 | Martin Stjernholm | | int overridden;
|
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);
|
86d54d | 2001-11-08 | Fredrik Hübinette (Hubbe) | | if(!TEST_COMPAT(7,2) &&
|
e037dc | 2001-10-02 | Fredrik Hübinette (Hubbe) | | IDENTIFIER_IS_VARIABLE(ID_FROM_INT(Pike_compiler->new_program,
|
2c9835 | 2001-09-25 | Fredrik Hübinette (Hubbe) | | n)->identifier_flags))
{
|
e037dc | 2001-10-02 | Fredrik Hübinette (Hubbe) | | my_yyerror("Illegal to redefine variable \"%s\" as constant.",
|
2c9835 | 2001-09-25 | Fredrik Hübinette (Hubbe) | | name->str);
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->new_program->identifier_references[n].inherit_offset == 0)
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | {
|
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) | |
|
5ec106 | 2002-05-09 | Martin Stjernholm | |
|
a1f852 | 2002-06-11 | Martin Stjernholm | | if ((overridden = override_identifier (&ref, name)) >= 0) {
|
5ec106 | 2002-05-09 | Martin Stjernholm | | #ifdef PIKE_DEBUG
if(MEMCMP(Pike_compiler->new_program->identifier_references+n, &ref,sizeof(ref)))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("New constant overriding algorithm failed!\n");
|
5ec106 | 2002-05-09 | Martin Stjernholm | | #endif
return overridden;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | }
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | n=Pike_compiler->new_program->num_identifier_references;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | add_to_identifier_references(ref);
|
d2c608 | 1996-11-07 | Fredrik Hübinette (Hubbe) | |
return n;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int simple_add_constant(const char *name,
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | 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;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_integer_constant(const char *name,
|
e6f913 | 2003-11-07 | Martin Stjernholm | | INT_ARG_TYPE i,
INT32 flags)
|
e43ca2 | 1996-11-15 | Fredrik Hübinette (Hubbe) | | {
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) | | }
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int quick_add_integer_constant(const char *name,
|
e6f913 | 2003-11-07 | Martin Stjernholm | | int name_length,
INT_ARG_TYPE i,
INT32 flags)
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | {
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;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_float_constant(const char *name,
|
e6f913 | 2003-11-07 | Martin Stjernholm | | FLOAT_ARG_TYPE f,
INT32 flags)
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | {
struct svalue tmp;
tmp.type=T_FLOAT;
|
e6f913 | 2003-11-07 | Martin Stjernholm | | tmp.u.float_number = f;
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | tmp.subtype=0;
return simple_add_constant(name, &tmp, flags);
}
|
e6f913 | 2003-11-07 | Martin Stjernholm | | PMOD_EXPORT int quick_add_float_constant(const char *name,
int name_length,
FLOAT_ARG_TYPE f,
INT32 flags)
{
struct svalue tmp;
struct pike_string *id;
INT32 ret;
tmp.u.float_number=f;
tmp.type=T_FLOAT;
tmp.subtype=0;
id=make_shared_binary_string(name,name_length);
ret=add_constant(id, &tmp, flags);
free_string(id);
return ret;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_string_constant(const char *name,
const char *str,
INT32 flags)
|
0683be | 1997-01-26 | Fredrik Hübinette (Hubbe) | | {
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) | |
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_program_constant(const char *name,
|
ab901e | 2003-06-06 | Henrik Grubbström (Grubba) | | struct program *p,
INT32 flags)
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | {
INT32 ret;
struct svalue tmp;
|
ab901e | 2003-06-06 | Henrik Grubbström (Grubba) | | if (p) {
tmp.type=T_PROGRAM;
tmp.subtype=0;
tmp.u.program=p;
} else {
tmp.type = T_INT;
tmp.subtype = NUMBER_UNDEFINED;
tmp.u.integer = 0;
my_yyerror("Program constant \"%s\" is NULL.", name);
}
|
5c0a10 | 1997-02-06 | Fredrik Hübinette (Hubbe) | | ret=simple_add_constant(name, &tmp, flags);
return ret;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_object_constant(const char *name,
|
f0c3d3 | 1998-04-05 | Fredrik Hübinette (Hubbe) | | 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;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int add_function_constant(const char *name, void (*cfun)(INT32),
|
7e877a | 2003-04-02 | Martin Stjernholm | | const char * type, int flags)
|
c15240 | 1997-02-10 | Fredrik Hübinette (Hubbe) | | {
struct svalue s;
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;
}
|
0929a0 | 2002-09-12 | Marcus Comstedt | | PMOD_EXPORT int debug_end_class(const char *name, ptrdiff_t 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)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_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);
|
a6ded6 | 2003-05-16 | Henrik Grubbström (Grubba) | |
Pike_compiler->new_program->flags |=
tmp.u.program->flags & PROGRAM_HAS_C_METHODS;
|
45ee5d | 1999-02-10 | Fredrik Hübinette (Hubbe) | | 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,
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | struct pike_type *type,
|
7e877a | 2003-04-02 | Martin Stjernholm | | unsigned flags,
unsigned function_flags,
|
1ef557 | 2000-08-30 | Henrik Grubbström (Grubba) | | union idptr *func,
|
7e877a | 2003-04-02 | Martin Stjernholm | | unsigned opt_flags)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
struct identifier *funp,fun;
struct reference ref;
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | struct svalue *lfun_type;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | INT32 i;
|
a78643 | 1999-11-18 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
{
struct pike_string *d = describe_type (type);
fprintf (stderr, "%.*sdefining function (pass=%d): %s ",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | compilation_depth, " ", Pike_compiler->compiler_pass, d->str);
|
a78643 | 1999-11-18 | Martin Stjernholm | | free_string (d);
push_string (name);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | print_svalue (stderr, --Pike_sp);
|
a78643 | 1999-11-18 | Martin Stjernholm | | putc ('\n', stderr);
}
#endif
|
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
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | |
if ((lfun_type = low_mapping_string_lookup(lfun_types, name))) {
#ifdef PIKE_DEBUG
if (lfun_type->type != T_TYPE) {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Bad entry in lfun_types for key \"%s\"\n", name->str);
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | }
#endif /* PIKE_DEBUG */
|
4b9d80 | 2001-02-21 | Henrik Grubbström (Grubba) | | if (!pike_types_le(type, lfun_type->u.type)) {
if (!match_types(type, lfun_type->u.type)) {
|
de3b51 | 2002-07-09 | Henrik Grubbström (Grubba) | | my_yyerror("Type mismatch for callback function %s():",
name->str);
yytype_error(NULL, lfun_type->u.type, type, 0);
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | } else if (lex.pragmas & ID_STRICT_TYPES) {
|
de3b51 | 2002-07-09 | Henrik Grubbström (Grubba) | | yywarning("Type mismatch for callback function %s():",
name->str);
yytype_error(NULL, lfun_type->u.type, type,
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | | YYTE_IS_WARNING);
}
}
}
|
7c429f | 2000-04-06 | Fredrik Hübinette (Hubbe) | | if(function_flags & IDENTIFIER_C_FUNCTION)
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->flags |= PROGRAM_HAS_C_METHODS;
|
7c429f | 2000-04-06 | Fredrik Hübinette (Hubbe) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | i=isidentifier(name);
if(i >= 0)
{
|
a1f852 | 2002-06-11 | Martin Stjernholm | | int overridden;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
fprintf(stderr, "%.*sexisted as identifier #%d\n",
compilation_depth, " ", i);
#endif
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | funp=ID_FROM_INT(Pike_compiler->new_program, i);
ref=Pike_compiler->new_program->identifier_references[i];
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | if(!(ref.id_flags & ID_INHERITED))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
51059b | 1999-12-26 | Henrik Grubbström (Grubba) | |
|
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) | | {
|
51f0e0 | 2000-08-10 | Henrik Grubbström (Grubba) | | if (!(flags & ID_VARIANT)) {
my_yyerror("Prototype doesn't match for function %s.",name->str);
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
}
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | |
|
98cf2a | 2003-02-24 | Martin Stjernholm | | if (funp->identifier_flags & IDENTIFIER_HAS_BODY)
function_flags |= IDENTIFIER_HAS_BODY;
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | if(!(ref.id_flags & ID_INHERITED))
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | if(func)
funp->func = *func;
|
23c675 | 2000-07-29 | Fredrik Hübinette (Hubbe) | | #if 0 /* prototypes does not override non-prototypes, ok? */
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | else
funp->func.offset = -1;
|
23c675 | 2000-07-29 | Fredrik Hübinette (Hubbe) | | #endif
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | funp->identifier_flags=function_flags;
|
a78643 | 1999-11-18 | Martin Stjernholm | |
|
e07bed | 2000-08-31 | Henrik Grubbström (Grubba) | | funp->opt_flags &= opt_flags;
|
1ef557 | 2000-08-30 | Henrik Grubbström (Grubba) | |
|
d68a07 | 2001-02-20 | Henrik Grubbström (Grubba) | | free_type(funp->type);
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(funp->type, type);
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | }else{
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | #ifdef PROGRAM_BUILD_DEBUG
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | fprintf(stderr, "%.*sidentifier was inherited\n",
compilation_depth, " ");
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | #endif
|
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);
}
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
8aae6d | 1999-08-19 | Fredrik Hübinette (Hubbe) | |
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | | if(ref.id_flags & ID_INLINE)
{
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | #ifdef PROGRAM_BUILD_DEBUG
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | fprintf(stderr, "%.*sidentifier is local\n",
compilation_depth, " ");
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | #endif
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | goto make_a_new_def;
|
12bdcd | 1999-04-08 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | |
#ifdef PROGRAM_BUILD_DEBUG
fprintf(stderr, "%.*saltering the existing definition\n",
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | compilation_depth, " ");
|
d89fa1 | 2002-04-26 | Henrik Grubbström (Grubba) | | #endif
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | copy_shared_string(fun.name, name);
|
be6fec | 2001-04-01 | Henrik Grubbström (Grubba) | | copy_pike_type(fun.type, type);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | fun.run_time_type=T_FUNCTION;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | fun.identifier_flags=function_flags;
if(function_flags & IDENTIFIER_C_FUNCTION)
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->new_program->flags |= PROGRAM_HAS_C_METHODS;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | if(func)
fun.func = *func;
else
fun.func.offset = -1;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
1ef557 | 2000-08-30 | Henrik Grubbström (Grubba) | | fun.opt_flags = opt_flags;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | ref.identifier_offset=Pike_compiler->new_program->num_identifiers;
|
5ec106 | 2002-05-09 | Martin Stjernholm | | debug_add_to_identifiers(fun);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | | ref.inherit_offset = 0;
ref.id_flags = flags;
|
a1f852 | 2002-06-11 | Martin Stjernholm | | if ((overridden = override_identifier (&ref, name)) >= 0) {
|
8b8157 | 2000-01-15 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
a1f852 | 2002-06-11 | Martin Stjernholm | | if(MEMCMP(Pike_compiler->new_program->identifier_references+i, &ref,sizeof(ref)))
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("New function overloading algorithm failed!\n");
|
8b8157 | 2000-01-15 | Fredrik Hübinette (Hubbe) | | #endif
|
a1f852 | 2002-06-11 | Martin Stjernholm | | return overridden;
}
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | |
} else {
make_a_new_def:
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
71f3a2 | 1998-11-22 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | if(Pike_compiler->compiler_pass==2)
Pike_fatal("Internal error: Not allowed to add more identifiers during second compiler pass.\n");
|
22edc2 | 1998-01-29 | Fredrik Hübinette (Hubbe) | | #endif
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | copy_shared_string(fun.name, name);
copy_pike_type(fun.type, type);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | fun.identifier_flags=function_flags;
fun.run_time_type=T_FUNCTION;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | if(func)
fun.func = *func;
else
fun.func.offset = -1;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | fun.opt_flags = opt_flags;
|
1ef557 | 2000-08-30 | Henrik Grubbström (Grubba) | |
|
2d5c86 | 2002-11-22 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | if (a_flag > 5) {
fprintf(stderr,
"Adding new function #%d: '%s'\n"
" identifier_flags:0x%02x opt_flags:0x%04x\n",
Pike_compiler->new_program->num_identifiers,
fun.name->str,
fun.identifier_flags, fun.opt_flags);
}
|
2d5c86 | 2002-11-22 | Henrik Grubbström (Grubba) | | #endif /* PIKE_DEBUG */
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | i=Pike_compiler->new_program->num_identifiers;
debug_add_to_identifiers(fun);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | | ref.id_flags = flags;
ref.identifier_offset = i;
ref.inherit_offset = 0;
}
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
3b6901 | 2003-09-30 | Henrik Grubbström (Grubba) | |
|
ae9503 | 1999-04-07 | Fredrik Hübinette (Hubbe) | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | i=Pike_compiler->new_program->num_identifier_references;
|
61e9a0 | 1998-01-25 | Fredrik Hübinette (Hubbe) | | add_to_identifier_references(ref);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | |
|
fa0b2e | 2002-05-12 | Martin Stjernholm | | #ifdef PROGRAM_BUILD_DEBUG
fprintf(stderr, "%.*sadded new definition #%d\n",
compilation_depth, " ", i);
#endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | return i;
}
|
7d6575 | 2003-06-04 | Henrik Grubbström (Grubba) | | #if 0
int add_ext_ref(struct program_state *state, struct program *target, int i)
{
struct reference ref, *r;
int j;
if (state->new_program == target) return i;
i = add_ext_ref(state->previous, target, i);
for (r = state->new_program->identifier_references, j = 0;
j < state->new_program->num_identifier_references;
j++, r++) {
if (((r->id_flags & ID_PARENT_REF|ID_STATIC|ID_PRIVATE|ID_HIDDEN) ==
ID_PARENT_REF|ID_STATIC|ID_PRIVATE|ID_HIDDEN) &&
(r->identifier_offset == i) &&
(!(r->inherit_offset))) {
return j;
}
}
ref.id_flags = ID_PARENT_REF|ID_STATIC|ID_PRIVATE|ID_HIDDEN;
ref.identifier_offset = i;
ref.inherit_offset = 0;
add_to_identifier_references(ref);
state->new_program->flags |= PROGRAM_USES_PARENT | PROGRAM_NEEDS_PARENT;
return j;
}
#endif /* 0 */
|
f00d01 | 2002-05-01 | Henrik Grubbström (Grubba) | |
|
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;
|
339c16 | 2002-05-01 | Henrik Grubbström (Grubba) | | int id, i, depth, last_inh;
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | |
|
aed42d | 1999-12-29 | Martin Stjernholm | | #if 0
|
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));
|
aed42d | 1999-12-29 | Martin Stjernholm | | #endif
|
66b674 | 1999-03-15 | Fredrik Hübinette (Hubbe) | |
|
5dbbf8 | 1999-07-01 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
if (!prog) {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_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 */
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | id = -1;
depth = 0;
|
339c16 | 2002-05-01 | Henrik Grubbström (Grubba) | | last_inh = prog->num_inherits;
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | i = (int)prog->num_identifier_references;
while(i--)
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | {
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)
{
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | struct inherit *inh = INHERIT_FROM_PTR(prog, funp);
|
baf400 | 2002-04-07 | Henrik Grubbström (Grubba) | | if ((funp->id_flags & ID_PRIVATE) && !(flags & SEE_PRIVATE)) continue;
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | if (!depth || (depth > inh->inherit_level)) {
|
339c16 | 2002-05-01 | Henrik Grubbström (Grubba) | | if (id != -1) {
int j;
int min_level = depth;
for (j=last_inh-1; j > funp->inherit_offset; j--) {
struct inherit *inh2 = prog->inherits + j;
if (inh2->inherit_level >= min_level) {
continue;
}
min_level = inh2->inherit_level;
}
if (!(inh->inherit_level < min_level)) {
continue;
}
}
last_inh = funp->inherit_offset;
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | depth = inh->inherit_level;
id = i;
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | }
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | } else {
return i;
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | }
}
|
ecd5bf | 2002-04-07 | Henrik Grubbström (Grubba) | | return id;
|
c0e446 | 1998-06-23 | Fredrik Hübinette (Hubbe) | | }
|
c0fb64 | 2000-08-10 | Henrik Grubbström (Grubba) | | int low_find_lfun(struct program *p, ptrdiff_t lfun)
|
abac4e | 2000-02-16 | Henrik Grubbström (Grubba) | | {
|
286afb | 2001-02-05 | Henrik Grubbström (Grubba) | | struct pike_string *lfun_name = lfun_strings[lfun];
|
abac4e | 2000-02-16 | Henrik Grubbström (Grubba) | | unsigned int flags = 0;
return
really_low_find_shared_string_identifier(lfun_name,
dmalloc_touch(struct program *,
p),
|
9a3e73 | 2000-06-26 | Henrik Grubbström (Grubba) | | SEE_STATIC);
|
abac4e | 2000-02-16 | Henrik Grubbström (Grubba) | | }
|
286afb | 2001-02-05 | Henrik Grubbström (Grubba) | | int lfun_lookup_id(struct pike_string *lfun_name)
{
struct svalue *id = low_mapping_string_lookup(lfun_ids, lfun_name);
if (!id) return -1;
if (id->type == T_INT) return id->u.integer;
my_yyerror("Bad entry in lfun lookup table for %s.", lfun_name->str);
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;
|
828815 | 2003-06-30 | Martin Stjernholm | | size_t val_n = PTR_TO_INT (name);
|
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(!funindex)
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("No funindex in fixed program\n");
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | #endif
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | max = prog->num_identifier_index;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | min = 0;
while(max != min)
{
|
828815 | 2003-06-30 | Martin Stjernholm | | size_t val_t;
|
ab9db5 | 2003-02-20 | Henrik Grubbström (Grubba) | |
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | tst=(max + min) >> 1;
fun = ID_FROM_INT(prog, funindex[tst]);
if(is_same_string(fun->name,name)) return funindex[tst];
|
828815 | 2003-06-30 | Martin Stjernholm | | val_t = PTR_TO_INT (fun->name);
if (val_n < val_t) {
|
ab9db5 | 2003-02-20 | Henrik Grubbström (Grubba) | | max = tst;
} else {
min = tst+1;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
}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) {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("find_shared_string_identifier(): No program!\n"
|
c55b91 | 1999-03-07 | Henrik Grubbström (Grubba) | | "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
|
5985c1 | 2000-10-25 | Fredrik Hübinette (Hubbe) | | if(prog -> flags & PROGRAM_FIXED
#if FIND_FUNCTION_HASH_TRESHOLD - 0
&& prog->num_identifier_index >= FIND_FUNCTION_HASH_TRESHOLD
#endif
)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
d3b06f | 2000-08-10 | Henrik Grubbström (Grubba) | | size_t hashval;
hashval = my_hash_string(name);
hashval += prog->id;
hashval %= FIND_FUNCTION_HASHSIZE;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | 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);
}
|
6f3ad0 | 2001-07-02 | Martin Stjernholm | | PMOD_EXPORT int find_identifier(const char *name,struct program *prog)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
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) {
|
b2d3e4 | 2000-12-01 | Fredrik Hübinette (Hubbe) | | Pike_error("Lookup of identifier %s in destructed object.\n", name);
|
0b9d1c | 1998-05-15 | Henrik Grubbström (Grubba) | | } else {
|
b2d3e4 | 2000-12-01 | Fredrik Hübinette (Hubbe) | | Pike_error("Lookup of long identifier in destructed object.\n");
|
0b9d1c | 1998-05-15 | Henrik Grubbström (Grubba) | | }
}
|
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;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | for (i=0;i<Pike_compiler->new_program->num_strings;i++)
if (Pike_compiler->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;
}
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | int store_constant(struct svalue *foo,
int equal,
struct pike_string *constant_name)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | | struct program_constant tmp;
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | JMP_BUF tmp2;
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | if(SETJMP(tmp2))
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | {
|
9036e8 | 2001-08-16 | Martin Stjernholm | | struct svalue zero, thrown = throw_value;
throw_value.type = T_INT;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
a6ded6 | 2003-05-16 | Henrik Grubbström (Grubba) | | dmalloc_touch_svalue(&thrown);
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | yyerror("Couldn't store constant.");
|
454d54 | 1999-09-18 | Fredrik Hübinette (Hubbe) | |
|
9036e8 | 2001-08-16 | Martin Stjernholm | | push_svalue(&thrown);
low_safe_apply_handler("compile_exception", error_handler, compat_handler, 1);
|
9f516a | 2001-12-16 | Martin Stjernholm | | if (SAFE_IS_ZERO(sp-1)) yy_describe_exception(&thrown);
|
b34c9f | 2001-08-15 | Martin Stjernholm | | pop_stack();
|
9036e8 | 2001-08-16 | Martin Stjernholm | | free_svalue(&thrown);
|
b34c9f | 2001-08-15 | Martin Stjernholm | |
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | zero.type = T_INT;
zero.subtype = NUMBER_NUMBER;
zero.u.integer=0;
|
6bee1c | 1999-12-14 | Fredrik Hübinette (Hubbe) | | UNSETJMP(tmp2);
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | return store_constant(&zero, equal, constant_name);
}else{
|
27ec27 | 2003-09-10 | Martin Stjernholm | | unsigned int e;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | for(e=0;e<Pike_compiler->new_program->num_constants;e++)
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | {
|
b5f5d6 | 2002-02-27 | Henrik Grubbström (Grubba) | | JMP_BUF tmp1;
|
8e4f2a | 2002-02-27 | Henrik Grubbström (Grubba) | |
|
b5f5d6 | 2002-02-27 | Henrik Grubbström (Grubba) | | if (!SETJMP(tmp1)) {
struct program_constant *c= Pike_compiler->new_program->constants+e;
if((equal ? is_equal(& c->sval,foo) : is_eq(& c->sval,foo)) &&
c->name == constant_name)
{
UNSETJMP(tmp1);
UNSETJMP(tmp2);
return e;
}
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | }
|
b5f5d6 | 2002-02-27 | Henrik Grubbström (Grubba) | | UNSETJMP(tmp1);
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | }
assign_svalue_no_free(&tmp.sval,foo);
if((tmp.name=constant_name)) add_ref(constant_name);
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
5d3fd9 | 1999-12-14 | Fredrik Hübinette (Hubbe) | | add_to_constants(tmp);
UNSETJMP(tmp2);
return e;
}
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
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)) {
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | if (id->func.offset >= 0) {
struct program *p2 = PROG_FROM_INT(p, e);
struct svalue *val = &p2->constants[id->func.offset].sval;
if ((val->type != T_PROGRAM) ||
!(val->u.program->flags & PROGRAM_USES_PARENT)) {
ref_push_string(ID_FROM_INT(p, e)->name);
n++;
}
} else {
|
afbda1 | 2001-12-06 | Henrik Grubbström (Grubba) | | ref_push_string(ID_FROM_INT(p, e)->name);
n++;
}
|
a36d82 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
}
f_aggregate(n);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | res = Pike_sp[-1].u.array;
|
a36d82 | 1998-05-25 | Henrik Grubbström (Grubba) | | 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)) {
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | if (id->func.offset >= 0) {
struct program *p2 = PROG_FROM_INT(p, e);
struct svalue *val = &p2->constants[id->func.offset].sval;
if ((val->type != T_PROGRAM) ||
!(val->u.program->flags & PROGRAM_USES_PARENT)) {
push_svalue(val);
n++;
}
} else {
push_int(0);
|
afbda1 | 2001-12-06 | Henrik Grubbström (Grubba) | | n++;
}
|
a36d82 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
}
f_aggregate(n);
|
cd8632 | 2000-07-06 | Fredrik Hübinette (Hubbe) | | res = Pike_sp[-1].u.array;
|
a36d82 | 1998-05-25 | Henrik Grubbström (Grubba) | | 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) {
|
b2d3e4 | 2000-12-01 | Fredrik Hübinette (Hubbe) | | Pike_error("Can't index a program with a %s (expected string)\n",
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | get_name_of_type(ind->type));
}
s = ind->u.string;
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | | e=find_shared_string_identifier(s, p);
if(e!=-1)
{
struct identifier *id;
id=ID_FROM_INT(p, e);
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | if (IDENTIFIER_IS_CONSTANT(id->identifier_flags)) {
|
4247e9 | 2003-08-20 | Henrik Grubbström (Grubba) | | if (id->func.offset >= 0) {
struct program *p2 = PROG_FROM_INT(p, e);
struct svalue *val = &p2->constants[id->func.offset].sval;
assign_svalue_no_free(to, val);
} else {
to->type = T_INT;
to->subtype = 0;
to->u.integer = 0;
}
|
abe2ac | 2001-12-06 | Henrik Grubbström (Grubba) | | return;
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
}
|
199425 | 1999-09-06 | Fredrik Hübinette (Hubbe) | |
to->type=T_INT;
to->subtype=NUMBER_UNDEFINED;
to->u.integer=0;
|
e43583 | 1998-05-25 | Henrik Grubbström (Grubba) | | }
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | |
|
606d79 | 2002-04-28 | Martin Stjernholm | | |
828a8a | 2003-09-03 | Martin Stjernholm | | * 2. short The number stored in big endian order.
|
606d79 | 2002-04-28 | Martin Stjernholm | | * Else:
* 1. char -128 (marker).
|
828a8a | 2003-09-03 | Martin Stjernholm | | * 2. int The number stored in big endian order.
|
606d79 | 2002-04-28 | Martin Stjernholm | | *
* Whenever the filename changes, a filename entry followed by a line
* number entry is stored. If only the line number changes, a line
* number entry is stored. The first stored entry (at pc 0) is the
* file and line where the program is defined, if they are known. The
* definition line for a top level program is set to 0.
*/
|
58ef5e | 1999-10-19 | Fredrik Hübinette (Hubbe) | | int get_small_number(char **q)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
bd2eee | 2000-03-28 | Fredrik Hübinette (Hubbe) | |
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | unsigned char *addr = (unsigned char *)*q;
int ret = *((signed char *)addr);
|
bd2eee | 2000-03-28 | Fredrik Hübinette (Hubbe) | | ret=*(signed char *)*q;
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | addr++;
|
bd2eee | 2000-03-28 | Fredrik Hübinette (Hubbe) | | switch(ret)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
case -127:
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | ret = (((signed char *)addr)[0]<<8) | addr[1];
addr += 2;
break;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
case -128:
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | ret = (((signed char *)addr)[0]<<24) | (addr[1]<<16) |
(addr[2]<<8) | addr[3];
addr += 4;
break;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | |
|
606d79 | 2002-04-28 | Martin Stjernholm | | #ifdef PIKE_DEBUG
case 127:
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("get_small_number used on filename entry\n");
|
606d79 | 2002-04-28 | Martin Stjernholm | | #endif
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | *q = (char *)addr;
return ret;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
void start_line_numbering(void)
{
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->last_file)
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | | {
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | free_string(Pike_compiler->last_file);
Pike_compiler->last_file=0;
|
ea32c1 | 1998-04-13 | Henrik Grubbström (Grubba) | | }
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->last_pc=Pike_compiler->last_line=0;
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | static void insert_small_number(INT32 a)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
4dba52 | 2001-07-11 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
int start = Pike_compiler->new_program->num_linenumbers;
#endif /* PIKE_DEBUG */
|
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);
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | add_to_linenumbers(a>>8);
add_to_linenumbers(a);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }else{
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(-128);
|
2659cf | 2002-05-10 | Henrik Grubbström (Grubba) | | add_to_linenumbers(a>>24);
add_to_linenumbers(a>>16);
add_to_linenumbers(a>>8);
add_to_linenumbers(a);
|
27ae84 | 2000-02-07 | Per Hedbor | | }
|
4dba52 | 2001-07-11 | Henrik Grubbström (Grubba) | | #ifdef PIKE_DEBUG
{
|
757128 | 2003-06-03 | Martin Stjernholm | | char *tmp = Pike_compiler->new_program->linenumbers + start;
INT32 res = get_small_number(&tmp);
|
4dba52 | 2001-07-11 | Henrik Grubbström (Grubba) | | if (a != res) {
tmp = Pike_compiler->new_program->linenumbers + start;
fprintf(stderr, "0x%p: %02x %02x %02x %02x %02x\n",
|
757128 | 2003-06-03 | Martin Stjernholm | | tmp, (unsigned char) tmp[0], (unsigned char) tmp[1],
(unsigned char) tmp[2], (unsigned char) tmp[3], (unsigned char) tmp[4]);
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("insert_small_number failed: %d (0x%08x) != %d (0x%08x)\n",
|
4dba52 | 2001-07-11 | Henrik Grubbström (Grubba) | | a, a, res, res);
}
}
#endif /* PIKE_DEBUG */
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
7c7a3f | 2002-12-01 | Martin Stjernholm | | static void ext_insert_small_number (char **ptr, INT32 a)
{
if(a>-127 && a<127)
{
*(*ptr)++ = a;
}else if(a>=-32768 && a<32768){
*(*ptr)++ = -127;
*(*ptr)++ = a>>8;
*(*ptr)++ = a;
}else{
*(*ptr)++ = -128;
*(*ptr)++ = a>>24;
*(*ptr)++ = a>>16;
*(*ptr)++ = a>>8;
*(*ptr)++ = a;
}
}
void ext_store_program_line (struct program *prog, INT32 line, struct pike_string *file)
{
char *ptr;
#ifdef PIKE_DEBUG
if (prog->linenumbers)
Pike_fatal ("Program already got linenumber info.\n");
if (Pike_compiler->new_program == prog)
Pike_fatal ("Use store_linenumber instead when the program is compiled.\n");
#endif
ptr = prog->linenumbers = xalloc (1 + 5 + 1 + (file->len << file->size_shift) + 5 + 5);
*ptr++ = 127;
ext_insert_small_number (&ptr, file->len);
*ptr++ = file->size_shift;
MEMCPY (ptr, file->str, file->len << file->size_shift);
ptr += file->len << file->size_shift;
*ptr++ = 0;
ext_insert_small_number (&ptr, line);
prog->num_linenumbers = ptr - prog->linenumbers;
}
|
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) | | {
|
5aad93 | 2002-08-15 | Marcus Comstedt | |
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | #ifdef PIKE_DEBUG
|
ae2d70 | 2001-10-06 | Fredrik Hübinette (Hubbe) | | if(a_flag)
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | {
INT32 line=0, off=0;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | size_t len = 0;
INT32 shift = 0;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | char *file=0;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | char *cnt=Pike_compiler->new_program->linenumbers;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | |
|
ae2d70 | 2001-10-06 | Fredrik Hübinette (Hubbe) | | if (a_flag > 50) {
|
aed520 | 2002-05-01 | Martin Stjernholm | | fprintf(stderr, "store_linenumber(%d, \"%s\") at pc %d\n",
current_line, current_file->str,
(INT32) PIKE_PC);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | fprintf(stderr, " last_line:%d last_file:\"%s\"\n",
Pike_compiler->last_line,
Pike_compiler->last_file?Pike_compiler->last_file->str:"");
}
while(cnt < Pike_compiler->new_program->linenumbers +
Pike_compiler->new_program->num_linenumbers)
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | {
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | char *start = cnt;
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | if(*cnt == 127)
{
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | cnt++;
len = get_small_number(&cnt);
shift = *cnt;
file = ++cnt;
|
1415ff | 2003-03-19 | Martin Stjernholm | | CHECK_FILE_ENTRY (Pike_compiler->new_program, cnt, len, shift);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | cnt += len<<shift;
|
64f913 | 2002-05-11 | Martin Stjernholm | | if (a_flag > 100) {
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | fprintf(stderr, "Filename entry:\n"
" len: %d, shift: %d\n",
len, shift);
}
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | }
off+=get_small_number(&cnt);
line+=get_small_number(&cnt);
|
ae2d70 | 2001-10-06 | Fredrik Hübinette (Hubbe) | | if (a_flag > 100) {
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | fprintf(stderr, " off: %d, line: %d\n"
" raw: ",
off, line);
for (;start < cnt; start++) {
fprintf(stderr, "%02x ", *((unsigned char *)start));
}
fprintf(stderr, "\n");
}
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | }
|
27ae84 | 2000-02-07 | Per Hedbor | |
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->last_line != line ||
Pike_compiler->last_pc != off ||
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | (Pike_compiler->last_file && file &&
memcmp(Pike_compiler->last_file->str, file, len<<shift)))
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | {
|
5aad93 | 2002-08-15 | Marcus Comstedt | | Pike_fatal("Line numbering out of whack\n"
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | " (line : %d ?= %d)!\n"
" ( pc : %d ?= %d)!\n"
" (shift: %d ?= %d)!\n"
" (len : %d ?= %d)!\n"
" (file : %s ?= %s)!\n",
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->last_line, line,
Pike_compiler->last_pc, off,
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | Pike_compiler->last_file?Pike_compiler->last_file->size_shift:0,
shift,
Pike_compiler->last_file?Pike_compiler->last_file->len:0, len,
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | Pike_compiler->last_file?Pike_compiler->last_file->str:"N/A",
|
101602 | 1999-10-28 | Fredrik Hübinette (Hubbe) | | file?file:"N/A");
}
}
#endif
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | if(Pike_compiler->last_line != current_line ||
Pike_compiler->last_file != current_file)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
|
606d79 | 2002-04-28 | Martin Stjernholm | | if(Pike_compiler->last_file != current_file)
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | {
char *tmp;
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | INT32 remain = DO_NOT_WARN((INT32)current_file->len)<<
current_file->size_shift;
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | if(Pike_compiler->last_file) free_string(Pike_compiler->last_file);
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(127);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | insert_small_number(DO_NOT_WARN((INT32)current_file->len));
add_to_linenumbers(current_file->size_shift);
for(tmp=current_file->str; remain-- > 0; tmp++)
|
b1f4eb | 1998-01-13 | Fredrik Hübinette (Hubbe) | | add_to_linenumbers(*tmp);
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | copy_shared_string(Pike_compiler->last_file, current_file);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
|
1302b1 | 2001-08-14 | Martin Stjernholm | | insert_small_number(DO_NOT_WARN((INT32)(PIKE_PC-Pike_compiler->last_pc)));
|
bad516 | 2000-06-23 | Fredrik Hübinette (Hubbe) | | insert_small_number(current_line-Pike_compiler->last_line);
|
50edc8 | 2001-07-13 | Henrik Grubbström (Grubba) | | Pike_compiler->last_line = current_line;
|
1302b1 | 2001-08-14 | Martin Stjernholm | | Pike_compiler->last_pc = DO_NOT_WARN((INT32)PIKE_PC);
|
5267b7 | 1995-08-09 | Fredrik Hübinette (Hubbe) | | }
}
|
90a1ad | 2003-03-29 | Martin Stjernholm | | #define FIND_PROGRAM_LINE(prog, file, len, shift, line) do { \
char *pos = prog->linenumbers; \
len = 0; \
shift = 0; \
file = NULL; \
\
if (pos < prog->linenumbers + prog->num_linenumbers) { \
if (*pos == 127) { \
pos++; \
len = get_small_number(&pos); \
shift = *pos; \
file = ++pos; \
CHECK_FILE_ENTRY (prog, pos, len, shift); \
pos += len<<shift; \
} \
get_small_number(&pos); /* Ignore the offset */ \
line = get_small_number(&pos); \
} \
} while (0)
|
7c7a3f | 2002-12-01 | Martin Stjernholm | | PMOD_EXPORT struct pike_string *low_get_program_line (struct program *prog,
INT32 *linep)
{
|
cbb2be | 2003-02-04 | Martin Stjernholm | | *linep = 0;
|
7c7a3f | 2002-12-01 | Martin Stjernholm | | if (prog->linenumbers) {
|
90a1ad | 2003-03-29 | Martin Stjernholm | | size_t len;
INT32 shift;
char *file;
|
7c7a3f | 2002-12-01 | Martin Stjernholm | |
|
90a1ad | 2003-03-29 | Martin Stjernholm | | FIND_PROGRAM_LINE (prog, file, len, shift, (*linep));
|
7c7a3f | 2002-12-01 | Martin Stjernholm | |
if (file) {
struct pike_string *str = begin_wide_shared_string(len, shift);
memcpy(str->str, file, len<<shift);
return end_shared_string(str);
}
}
return NULL;
}
|
90a1ad | 2003-03-29 | Martin Stjernholm | | static char *make_plain_file (char *file, size_t len, INT32 shift, int malloced)
{
if(shift)
{
static char buf[1000];
char *buffer = malloced ?
malloc (len + 1) : (len = NELEM(buf) - 1, buf);
PCHARP from=MKPCHARP(file, shift);
int chr;
size_t ptr=0;
|
a5d6a7 | 2003-03-30 | Martin Stjernholm | | for (; (chr = EXTRACT_PCHARP(from)); INC_PCHARP(from, 1))
|
90a1ad | 2003-03-29 | Martin Stjernholm | | {
size_t space = chr > 255 ? 20 : 1;
if (ptr + space > len) {
if (malloced)
buffer = realloc (buffer, (len = (len << 1) + space) + 1);
else
break;
}
if(chr > 255)
{
|
688b27 | 2003-10-20 | Martin Stjernholm | | sprintf(buffer+ptr,"\\u%04X",chr);
|
90a1ad | 2003-03-29 | Martin Stjernholm | | ptr+=strlen(buffer+ptr);
}else{
buffer[ptr++]=chr;
}
}
buffer[ptr]=0;
return buffer;
}
else{
char *buffer = malloc (len + 1);
MEMCPY (buffer, file, len);
buffer[len] = 0; |