--- parser3/src/include/pa_opcode.h 2009/06/02 10:08:47 1.38 +++ parser3/src/include/pa_opcode.h 2009/06/14 00:34:21 1.43 @@ -11,18 +11,23 @@ namespace OP { -static const char * const IDENT_OPCODE_H="$Date: 2009/06/02 10:08:47 $"; +static const char * const IDENT_OPCODE_H="$Date: 2009/06/14 00:34:21 $"; #define OPTIMIZE_BYTECODE_GET_CLASS #define OPTIMIZE_BYTECODE_GET_ELEMENT // $a ^a #define OPTIMIZE_BYTECODE_GET_OBJECT_ELEMENT // $a.b ^a.b #define OPTIMIZE_BYTECODE_GET_OBJECT_VAR_ELEMENT // $a.$b ^a.$b -//#define OPTIMIZE_BYTECODE_STRING_POOL +#define OPTIMIZE_BYTECODE_STRING_POOL #define OPTIMIZE_BYTECODE_CUT_REM_OPERATOR // cut rem with all params #ifdef OPTIMIZE_BYTECODE_GET_ELEMENT -#define OPTIMIZE_BYTECODE_CONSTRUCT // $a(expr), $.a(expr), $a[value], $.a[value] -#endif +#define OPTIMIZE_BYTECODE_CONSTRUCT // $a(expr), $a[value] +#endif // $.a(expr), $.a[value] + // $self.a(expr), $self.a[value] + +#define OPTIMIZE_BYTECODE_GET_SELF_ELEMENT // $self.a ^self.a +#define OPTIMIZE_BYTECODE_CONSTRUCT_OBJECT // ^class::constructor + /// Compiled operation code enum OPCODE { @@ -48,6 +53,12 @@ enum OPCODE { OP_GET_ELEMENT_OR_OPERATOR, #endif OP_GET_ELEMENT, + OP_GET_ELEMENT__WRITE, +#ifdef OPTIMIZE_BYTECODE_GET_ELEMENT + OP_VALUE__GET_ELEMENT, + OP_VALUE__GET_ELEMENT__WRITE, + OP_WITH_ROOT__VALUE__GET_ELEMENT, +#endif #ifdef OPTIMIZE_BYTECODE_GET_OBJECT_ELEMENT OP_GET_OBJECT_ELEMENT, // $a.b & ^a.b OP_GET_OBJECT_ELEMENT__WRITE, // $a.b & ^a.b @@ -56,15 +67,17 @@ enum OPCODE { OP_GET_OBJECT_VAR_ELEMENT, // $a.$b & ^a.$b OP_GET_OBJECT_VAR_ELEMENT__WRITE, // $a.$b & ^a.$b #endif -#ifdef OPTIMIZE_BYTECODE_GET_ELEMENT - OP_VALUE__GET_ELEMENT, -#endif - OP_GET_ELEMENT__WRITE, -#ifdef OPTIMIZE_BYTECODE_GET_ELEMENT - OP_VALUE__GET_ELEMENT__WRITE, +#ifdef OPTIMIZE_BYTECODE_GET_SELF_ELEMENT + OP_WITH_SELF__VALUE__GET_ELEMENT, + OP_WITH_SELF__VALUE__GET_ELEMENT__WRITE, #endif OP_OBJECT_POOL, OP_STRING_POOL, - OP_PREPARE_TO_CONSTRUCT_OBJECT, OP_PREPARE_TO_EXPRESSION, + OP_PREPARE_TO_CONSTRUCT_OBJECT, +#ifdef OPTIMIZE_BYTECODE_CONSTRUCT_OBJECT + OP_CONSTRUCT_OBJECT, + OP_CONSTRUCT_OBJECT__WRITE, +#endif + OP_PREPARE_TO_EXPRESSION, OP_CALL, OP_CALL__WRITE, #ifdef OPTIMIZE_BYTECODE_CONSTRUCT @@ -72,6 +85,8 @@ enum OPCODE { OP_WITH_ROOT__VALUE__CONSTRUCT_VALUE, OP_WITH_WRITE__VALUE__CONSTRUCT_EXPR, OP_WITH_WRITE__VALUE__CONSTRUCT_VALUE, + OP_WITH_SELF__VALUE__CONSTRUCT_EXPR, + OP_WITH_SELF__VALUE__CONSTRUCT_VALUE, #endif //@}