Diff for /parser3/src/main/compile.C between versions 1.22 and 1.75

version 1.22, 2001/03/09 08:28:34 version 1.75, 2004/04/06 09:01:20
Line 1 Line 1
 /*  /** @file
   $Id$          Parser: compiler part of request class.
   
           Copyright (c) 2001-2004 ArtLebedev Group (http://www.artlebedev.com)
           Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
 */  */
   
   static const char * const IDENT_COMPILE_C="$Date$";
   
   #include "pa_opcode.h"
 #include "pa_request.h"  #include "pa_request.h"
 #include "pa_string.h"  
 #include "pa_array.h"  
 #include "code.h"  
 #include "compile_tools.h"  #include "compile_tools.h"
 #include "pa_exception.h"  
   
 #include <stdio.h>  
   
 extern int yydebug;  extern int yydebug;
 extern int yyparse (void *);  extern int yyparse (void *);
   
 VClass& Request::real_compile(COMPILE_PARAMS) {  VStateless_class& Request::compile(VStateless_class* aclass, 
                                      const char* source, const String* main_alias, 
                                      uint file_no,
                                      int line_no_offset) {
         // prepare to parse          // prepare to parse
         struct parse_control pc;          Parse_control pc(*this, aclass, source, main_alias, file_no, line_no_offset);
   
         // input   
         pc.pool=&pool();  
         pc.request=this;  
         VClass *vclass;  
         if(name) { // we were told the name of a class?  
                 // yes. create it  
                 vclass=NEW VClass(pool());  
                 // defaulting base. may change with @BASE  
                 vclass->set_base(root_class);  
                 // append to request's classes  
                 classes_array()+=vclass;  
                 classes().put(*name, vclass);  
                 vclass->set_name(*name);  
         } else  
                 vclass=&root_class; // until changed with @CLASS would consider operators loading  
         pc.vclass=vclass;  
   
         pc.source=source;  
 #ifndef NO_STRING_ORIGIN  
         pc.file=file;  
         pc.line=pc.col=0;  
 #endif  
         // initialise state  
         pc.pending_state=0;  
         pc.string=NEW String(pool());     
         pc.ls=LS_USER;  
         pc.sp=0;  
           
         // parse=compile!           // parse=compile! 
         yydebug=1;          //yydebug=1;
         if(yyparse(&pc)) { // error?          if(yyparse(&pc)) { // error?
                 if(pc.col==0) { // expecting something after EOL means they've expected it BEFORE                  pc.pos_prev_c();
                         // step back.  -1 col means EOL                  if(!pc.explicit_result)
                         pc.line--;                          if(pc.pos.col==0) // expecting something after EOL means they've expected it BEFORE
                         pc.col=-1;                                  pc.pos_prev_c();
                 }   
                 THROW(0,0,                  throw Exception("parser.compile",
                         0,                          0,
                         "%s(%d:%d): %s", file, 1+pc.line, pc.col, pc.error);                          "%s(%d:%d): %s",  file_list[file_no].cstr(), 1+pc.pos.line, 1+pc.pos.col,  pc.error);
         }          }
   
         // result          // result
         return *pc.vclass;          return *pc.cclass;
 }  }

Removed from v.1.22  
changed lines
  Added in v.1.75


E-mail: