2007-12-30 17:41:49 +01:00
|
|
|
/***************************************************************************
|
|
|
|
|
|
|
|
exec.h
|
|
|
|
|
|
|
|
Subroutines for the interpreter : executing methods, native methods,
|
|
|
|
the NEW operator, the casting operator, etc.
|
|
|
|
|
|
|
|
(c) 2000-2007 Benoit Minisini <gambas@users.sourceforge.net>
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 1, or (at your option)
|
|
|
|
any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __GBX_EXEC_H
|
|
|
|
#define __GBX_EXEC_H
|
|
|
|
|
|
|
|
#include "gb_alloc.h"
|
|
|
|
#include "gb_error.h"
|
|
|
|
#include "gbx_class.h"
|
|
|
|
#include "gbx_value.h"
|
|
|
|
#include "gb_pcode.h"
|
|
|
|
#include "gbx_stack.h"
|
|
|
|
|
|
|
|
#include "gbx_string.h"
|
|
|
|
#include "gbx_object.h"
|
|
|
|
#include "gbx_variant.h"
|
|
|
|
#include "gbx_array.h"
|
|
|
|
|
|
|
|
#include "gbx_c_enum.h"
|
|
|
|
|
|
|
|
|
|
|
|
typedef
|
|
|
|
void (*EXEC_FUNC)();
|
|
|
|
|
|
|
|
typedef
|
|
|
|
struct {
|
|
|
|
CLASS *class;
|
|
|
|
OBJECT *object;
|
2008-01-17 22:39:26 +01:00
|
|
|
int index;
|
2007-12-30 17:41:49 +01:00
|
|
|
//FUNCTION *func;
|
|
|
|
CLASS_DESC_METHOD *desc;
|
|
|
|
int nparam;
|
|
|
|
int nparvar;
|
|
|
|
bool drop;
|
|
|
|
bool native;
|
|
|
|
bool use_stack;
|
|
|
|
bool property;
|
|
|
|
const char *unknown;
|
|
|
|
}
|
|
|
|
EXEC_FUNCTION;
|
|
|
|
|
|
|
|
typedef
|
|
|
|
struct {
|
|
|
|
void (*main)();
|
|
|
|
void (*loop)();
|
|
|
|
void (*wait)();
|
|
|
|
void (*timer)();
|
|
|
|
void (*lang)();
|
|
|
|
void (*watch)();
|
|
|
|
void (*post)();
|
|
|
|
void (*quit)();
|
|
|
|
void (*error)();
|
|
|
|
int (*image)();
|
|
|
|
int (*picture)();
|
|
|
|
}
|
|
|
|
EXEC_HOOK;
|
|
|
|
|
|
|
|
#ifndef __GBX_EXEC_C
|
|
|
|
|
|
|
|
EXTERN STACK_CONTEXT EXEC_current;
|
|
|
|
EXTERN PCODE EXEC_code;
|
|
|
|
EXTERN VALUE *SP;
|
|
|
|
EXTERN VALUE TEMP;
|
|
|
|
EXTERN VALUE RET;
|
|
|
|
EXTERN EXEC_FUNCTION EXEC;
|
|
|
|
|
|
|
|
EXTERN VALUE *EXEC_super;
|
2008-03-19 15:32:30 +01:00
|
|
|
|
2007-12-30 17:41:49 +01:00
|
|
|
EXTERN bool EXEC_debug;
|
|
|
|
EXTERN bool EXEC_arch;
|
|
|
|
EXTERN bool EXEC_fifo;
|
2009-05-22 16:52:36 +02:00
|
|
|
EXTERN const char *EXEC_fifo_name;
|
2008-03-19 15:32:30 +01:00
|
|
|
EXTERN bool EXEC_keep_library;
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
EXTERN EXEC_HOOK EXEC_Hook;
|
|
|
|
|
|
|
|
EXTERN CENUM *EXEC_enum;
|
|
|
|
|
|
|
|
EXTERN bool EXEC_big_endian;
|
|
|
|
EXTERN bool EXEC_main_hook_done;
|
|
|
|
EXTERN int EXEC_return_value;
|
2008-01-25 16:01:02 +01:00
|
|
|
EXTERN bool EXEC_got_error;
|
2007-12-30 17:41:49 +01:00
|
|
|
/*EXTERN long EXEC_const[];*/
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Local variables base pointer */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define BP EXEC_current.bp
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Current class */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define CP EXEC_current.cp
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Current object */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define OP EXEC_current.op
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Paramters base pointer */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define PP EXEC_current.pp
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Save stack pointer for a TRY */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define EP EXEC_current.ep
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Current function */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define FP EXEC_current.fp
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Program counter */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define PC EXEC_current.pc
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Where to go if there is an error */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define EC EXEC_current.ec
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Save register for TRY */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define ET EXEC_current.et
|
|
|
|
/* Last break in the function */
|
|
|
|
#define TC EXEC_current.tc
|
|
|
|
/* Stack at the last break in the function */
|
|
|
|
#define TP EXEC_current.tp
|
|
|
|
|
2009-07-12 23:49:13 +02:00
|
|
|
/* Function return value pointer */
|
2007-12-30 17:41:49 +01:00
|
|
|
#define RP (&RET)
|
|
|
|
|
|
|
|
#define HOOK(func) (!EXEC_Hook.func) ? 0 : (*EXEC_Hook.func)
|
|
|
|
#define HOOK_DEFAULT(func, def) (*((!EXEC_Hook.func) ? def : EXEC_Hook.func))
|
|
|
|
|
|
|
|
#define GET_NPARAM(var) short var = *PC & 0x3F
|
|
|
|
#define GET_PARAM(var, nparam) VALUE *var = &SP[-nparam]
|
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_init(void);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_enter_check(bool defined);
|
|
|
|
void EXEC_enter(void);
|
|
|
|
void EXEC_enter_quick(void);
|
|
|
|
void EXEC_leave(bool drop);
|
|
|
|
void EXEC_loop(void);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_object(VALUE *SP, CLASS **pclass, OBJECT **pobject, bool *pdefined);
|
|
|
|
void *EXEC_auto_create(CLASS *class, bool ref);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
bool EXEC_call_native(void (*exec)(), void *object, TYPE type, VALUE *param);
|
2008-01-27 15:00:04 +01:00
|
|
|
void EXEC_native_check(bool defined);
|
|
|
|
void EXEC_native_quick(void);
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_native();
|
2008-05-10 17:17:07 +02:00
|
|
|
void EXEC_function_real();
|
|
|
|
void EXEC_function_loop();
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-05-10 17:17:07 +02:00
|
|
|
#define EXEC_function() EXEC_function_real(), EXEC_release_return_value()
|
|
|
|
#define EXEC_function_keep() EXEC_function_real()
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_public(CLASS *class, void *object, const char *name, int nparam);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2009-07-08 21:57:50 +02:00
|
|
|
bool EXEC_spec(int spec, CLASS *class, void *object, int nparam, bool drop);
|
2007-12-30 17:41:49 +01:00
|
|
|
#define EXEC_special EXEC_spec
|
|
|
|
|
2009-07-08 21:57:50 +02:00
|
|
|
void EXEC_special_inheritance(int special, CLASS *class, OBJECT *object, int nparam, bool drop);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_nop(void);
|
|
|
|
void EXEC_ILLEGAL(void);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_push_unknown(ushort code);
|
2008-01-24 02:36:20 +01:00
|
|
|
void EXEC_push_array(ushort code);
|
2008-01-17 22:39:26 +01:00
|
|
|
//void EXEC_push_special(void);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_pop_unknown(void);
|
2008-01-24 02:36:20 +01:00
|
|
|
void EXEC_pop_array(ushort code);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void EXEC_enum_first(PCODE code);
|
|
|
|
bool EXEC_enum_next(PCODE code);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-01-17 22:39:26 +01:00
|
|
|
void *EXEC_create_object(CLASS *class, int np, char *event);
|
|
|
|
void EXEC_new(void);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-03-11 14:29:47 +01:00
|
|
|
void EXEC_release_return_value(void);
|
|
|
|
void EXEC_quit(void);
|
|
|
|
|
|
|
|
void EXEC_dup(int n);
|
|
|
|
|
|
|
|
void EXEC_borrow(TYPE type, VALUE *val);
|
2008-01-17 22:39:26 +01:00
|
|
|
void UNBORROW(VALUE *val);
|
2008-03-11 14:29:47 +01:00
|
|
|
void EXEC_release(TYPE type, VALUE *val);
|
2008-01-17 22:39:26 +01:00
|
|
|
void RELEASE_many(VALUE *val, int n);
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-03-11 14:29:47 +01:00
|
|
|
#define BORROW(_value) \
|
|
|
|
{ \
|
|
|
|
VALUE *_v = (_value); \
|
|
|
|
TYPE type = _v->type; \
|
|
|
|
if (TYPE_is_object(type)) \
|
|
|
|
{ \
|
|
|
|
OBJECT_REF(_v->_object.object, "BORROW"); \
|
|
|
|
} \
|
|
|
|
else if (type == T_STRING) \
|
|
|
|
STRING_ref(_v->_string.addr); \
|
|
|
|
else \
|
|
|
|
EXEC_borrow(type, _v); \
|
|
|
|
}
|
|
|
|
|
|
|
|
#define RELEASE(_value) \
|
2008-05-12 18:09:33 +02:00
|
|
|
do { \
|
2008-03-11 14:29:47 +01:00
|
|
|
VALUE *_v = (_value); \
|
|
|
|
TYPE type = _v->type; \
|
|
|
|
if (TYPE_is_object(type)) \
|
|
|
|
{ \
|
2008-08-14 21:42:27 +02:00
|
|
|
OBJECT_UNREF(_v->_object.object, "RELEASE"); \
|
2008-03-11 14:29:47 +01:00
|
|
|
} \
|
|
|
|
else if (type == T_STRING) \
|
|
|
|
STRING_unref(&_v->_string.addr); \
|
|
|
|
else \
|
|
|
|
EXEC_release(type, _v); \
|
2008-05-12 18:09:33 +02:00
|
|
|
} while (0)
|
2008-03-11 14:29:47 +01:00
|
|
|
|
2007-12-30 17:41:49 +01:00
|
|
|
#define RELEASE_MANY(_val, _n) \
|
2008-05-12 18:09:33 +02:00
|
|
|
do { \
|
2007-12-30 17:41:49 +01:00
|
|
|
if (_n) \
|
|
|
|
{ \
|
|
|
|
if ((_n) == 1) \
|
|
|
|
{ \
|
|
|
|
_val--; \
|
|
|
|
RELEASE((_val)); \
|
|
|
|
} \
|
|
|
|
else \
|
|
|
|
{ \
|
|
|
|
RELEASE_many((_val), (_n)); \
|
|
|
|
_val -= (_n); \
|
|
|
|
} \
|
|
|
|
} \
|
2008-05-12 18:09:33 +02:00
|
|
|
} while (0)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-03-11 14:29:47 +01:00
|
|
|
#define PUSH() \
|
2008-05-12 18:09:33 +02:00
|
|
|
do { \
|
2008-03-11 14:29:47 +01:00
|
|
|
BORROW(SP); \
|
|
|
|
SP++; \
|
2008-05-12 18:09:33 +02:00
|
|
|
} while (0)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-03-11 14:29:47 +01:00
|
|
|
#define POP() \
|
2008-05-12 18:09:33 +02:00
|
|
|
do { \
|
2008-03-11 14:29:47 +01:00
|
|
|
SP--; \
|
|
|
|
RELEASE(SP); \
|
2008-05-12 18:09:33 +02:00
|
|
|
} while (0)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
2008-03-19 15:32:30 +01:00
|
|
|
#define COPY_VALUE(_dst, _src) VALUE_copy(_dst, _src)
|
2007-12-30 17:41:49 +01:00
|
|
|
|
|
|
|
#endif /* */
|