Diff for /parser3/src/main/compile.C between versions 1.39 and 1.82

version 1.39, 2001/06/28 07:41:59 version 1.82, 2012/03/16 09:24:12
Line 1 Line 1
 /** @file  /** @file
         Parser: compiler part of request class.          Parser: compiler part of request class.
   
         Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com)          Copyright (c) 2001-2012 Art. Lebedev Studio (http://www.artlebedev.com)
           Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
         Author: Alexander Petrosyan <paf@design.ru> (http://design.ru/paf)  
   
         $Id$  
 */  */
 static char *RCSId="$Id$";   
   
 #include "pa_opcode.h"  volatile const char * IDENT_COMPILE_C="$Id$";
   
 #include "pa_request.h"  #include "pa_request.h"
 #include "pa_string.h"  
 #include "pa_array.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 *);
   
 VStateless_class& Request::real_compile(COMPILE_PARAMS) {  ArrayClass& 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;  
         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  
                 // 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  
                 cclass=&OP; // until changed with @CLASS would consider operators loading  
         pc.cclass=cclass;  
   
         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.cclass;          return *pc.cclasses;
 }  }

Removed from v.1.39  
changed lines
  Added in v.1.82


E-mail: