--- parser3/src/main/compile.C 2001/03/11 12:04:44 1.26 +++ parser3/src/main/compile.C 2001/07/25 12:18:23 1.44 @@ -1,15 +1,16 @@ -/* - Parser +/** @file + Parser: compiler part of request class. + Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) - Author: Alexander Petrosyan (http://design.ru/paf) - $Id: compile.C,v 1.26 2001/03/11 12:04:44 paf Exp $ + Author: Alexander Petrosyan (http://design.ru/paf) */ +static const char *RCSId="$Id: compile.C,v 1.44 2001/07/25 12:18:23 parser Exp $"; +#include "pa_opcode.h" #include "pa_request.h" #include "pa_string.h" #include "pa_array.h" -#include "code.h" #include "compile_tools.h" #include "pa_exception.h" @@ -18,26 +19,28 @@ extern int yydebug; extern int yyparse (void *); -VClass& Request::real_compile(COMPILE_PARAMS) { +VStateless_class& Request::real_compile(COMPILE_PARAMS) { // prepare to parse struct parse_control pc; // input pc.pool=&pool(); pc.request=this; - VClass *vclass; - if(name) { // we were told the name of compiled class? + VStateless_class *cclass; + if(aclass) // we were told the class to compile to? + cclass=aclass; // yes, remember it [used in ^process] + else if(name) { // we were told the name of compiled class? // yes. create it - vclass=NEW VClass(pool()); + cclass=NEW VClass(pool()); // defaulting base. may change with @BASE - vclass->set_base(base_class?*base_class:root_class); - // append to request's classes - classes_array()+=vclass; - classes().put(*name, vclass); - vclass->set_name(*name); + // dont use ?: for there would be getting & of temp object + if(base_class) + cclass->set_base(*base_class); + classes().put(*name, cclass); + cclass->set_name(*name); } else - vclass=&root_class; // until changed with @CLASS would consider operators loading - pc.vclass=vclass; + cclass=&OP; // until changed with @CLASS would consider operators loading + pc.cclass=cclass; pc.source=source; #ifndef NO_STRING_ORIGIN @@ -45,6 +48,7 @@ VClass& Request::real_compile(COMPILE_PA pc.line=pc.col=0; #endif // initialise state + pc.trim_bof=true; pc.pending_state=0; pc.string=NEW String(pool()); pc.ls=LS_USER; @@ -64,5 +68,5 @@ VClass& Request::real_compile(COMPILE_PA } // result - return *pc.vclass; + return *pc.cclass; }