--- parser3/src/main/execute.C 2001/05/17 09:21:55 1.158 +++ parser3/src/main/execute.C 2001/06/28 07:41:59 1.168 @@ -5,16 +5,16 @@ Author: Alexander Petrosyan (http://design.ru/paf) - $Id: execute.C,v 1.158 2001/05/17 09:21:55 parser Exp $ + $Id: execute.C,v 1.168 2001/06/28 07:41:59 parser Exp $ */ +static char *RCSId="$Id: execute.C,v 1.168 2001/06/28 07:41:59 parser Exp $"; -#include "pa_config_includes.h" #include "pa_opcode.h" #include "pa_array.h" #include "pa_request.h" #include "pa_vstring.h" #include "pa_vhash.h" -#include "pa_vunknown.h" +#include "pa_vvoid.h" #include "pa_vcode_frame.h" #include "pa_vmethod_frame.h" #include "pa_vobject.h" @@ -26,10 +26,7 @@ //#define DEBUG_EXECUTE - -#define PUSH(value) stack.push(value) -#define POP() static_cast(stack.pop()) -#define POP_NAME() static_cast(stack.pop())->as_string() +const uint ANTI_ENDLESS_EXECUTE_RECOURSION=500; #ifdef DEBUG_EXECUTE char *opcode_name[]={ @@ -109,6 +106,10 @@ void debug_dump(Pool& pool, int level, c } #endif +#define PUSH(value) stack.push(value) +#define POP() static_cast(stack.pop()) +#define POP_NAME() static_cast(stack.pop())->as_string() + void Request::execute(const Array& ops) { #ifdef DEBUG_EXECUTE debug_printf(pool(), "source----------------------------\n"); @@ -300,7 +301,7 @@ void Request::execute(const Array& ops) if(string) value=NEW VString(*string); else - value=NEW VUnknown(pool()); + value=NEW VVoid(pool()); wcontext=static_cast(POP()); rcontext=POP(); PUSH(value); @@ -321,7 +322,7 @@ void Request::execute(const Array& ops) if(string) value=NEW VString(*string); else - NEW VUnknown(pool()); + NEW VVoid(pool()); wcontext=static_cast(POP()); PUSH(value); break; @@ -415,11 +416,20 @@ void Request::execute(const Array& ops) method.check_actual_numbered_params(pool(), frame->junction.self, frame->name(), frame->numbered_params()); - (*method.native_code)( + method.native_code( *this, frame->name(), frame->numbered_params()); // execute it - } else // parser code + } else { // parser code + if(++anti_endless_execute_recoursion==ANTI_ENDLESS_EXECUTE_RECOURSION) { + anti_endless_execute_recoursion=0; // give @exception a chance + THROW(0, 0, + &frame->name(), + "endless recursion detected"); + } + execute(*method.parser_code); // execute it + anti_endless_execute_recoursion--; + } else THROW(0, 0, &frame->name(), @@ -696,15 +706,14 @@ Value *Request::get_element() { if(value) value=&process(*value, &name); // process possible code-junction else { - value=NEW VUnknown(pool()); + value=NEW VVoid(pool()); value->set_name(name); } return value; } -/** - intercept_string: +/** @param intercept_string - true: they want result=string value, possible object result goes to wcontext