--- parser3/src/main/compile.C 2001/02/22 10:43:45 1.13 +++ parser3/src/main/compile.C 2001/04/06 10:32:20 1.35 @@ -1,11 +1,17 @@ -/* - $Id: compile.C,v 1.13 2001/02/22 10:43:45 paf Exp $ +/** @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.35 2001/04/06 10:32:20 paf Exp $ */ +#include "code.h" #include "pa_request.h" #include "pa_string.h" #include "pa_array.h" -#include "code.h" #include "compile_tools.h" #include "pa_exception.h" @@ -14,15 +20,27 @@ extern int yydebug; extern int yyparse (void *); -Array& Request::real_compile(COMPILE_PARAMS) { +VStateless_class& Request::real_compile(COMPILE_PARAMS) { // prepare to parse struct parse_control pc; // input pc.pool=&pool(); - pc.methods=NEW Array(pool()); - if(!source) - return *pc.methods; + pc.request=this; + 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 + cclass=NEW VClass(pool()); + // defaulting base. may change with @BASE + if(base_class) + cclass->set_base(*base_class); + classes().put(*name, cclass); + cclass->set_name(*name); + } else + cclass=&OP; // until changed with @CLASS would consider operators loading + pc.cclass=cclass; pc.source=source; #ifndef NO_STRING_ORIGIN @@ -36,18 +54,18 @@ Array& Request::real_compile(COMPILE_PAR pc.sp=0; // parse=compile! - ///yydebug=1; +// yydebug=1; if(yyparse(&pc)) { // error? - if(pc.col==1) { - // step back from last char. -1 col means EOL + if(pc.col==0) { // expecting something after EOL means they've expected it BEFORE + // step back. -1 col means EOL pc.line--; pc.col=-1; - } + } THROW(0,0, 0, - "%s [%s:%d:%d]", pc.error, file, 1+pc.line, pc.col); + "%s(%d:%d): %s", file, 1+pc.line, pc.col, pc.error); } // result - return *pc.methods; + return *pc.cclass; }