Diff for /parser3/src/main/compile.C between versions 1.11 and 1.67

version 1.11, 2001/02/21 17:50:02 version 1.67, 2002/10/14 15:22:42
Line 1 Line 1
 /*  /** @file
   $Id$          Parser: compiler part of request class.
   
           Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com)
           Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
 */  */
   
   static const char* IDENT_COMPILE_C="$Date$";
   
   #include "pa_opcode.h"
 #include "pa_request.h"  #include "pa_request.h"
 #include "pa_string.h"  #include "pa_string.h"
 #include "pa_array.h"  #include "pa_array.h"
 #include "code.h"  
 #include "compile_tools.h"  #include "compile_tools.h"
 #include "pa_exception.h"  #include "pa_exception.h"
   
 #include <stdio.h>  
   
 extern int yydebug;  extern int yydebug;
 extern int yyparse (void *);  extern int yyparse (void *);
   
 Array& Request::real_compile(COMPILE_PARAMS) {  VStateless_class& Request::real_compile(COMPILE_PARAMS) {
         // prepare to parse          // prepare to parse
         struct parse_control pc;          struct parse_control pc;
   
         // input           // input 
         pc.pool=&pool();          pc.pool=&pool();
         pc.methods=new(pool()) Array(pool());          pc.request=this;
         if(!source)          VStateless_class *cclass;
                 return *pc.methods;          // we were told the class to compile to?
           pc.cclass=&aclass; // until changed with @CLASS would consider operators loading
   
         pc.source=source;          pc.source=source;
 #ifndef NO_STRING_ORIGIN  #ifndef NO_STRING_ORIGIN
         pc.file=file;          pc.file=file;
         pc.line=pc.col=0;  
 #endif  #endif
           pc.line=pc.col=0; // off the check, 'col' used in compile
   
         // initialise state          // initialise state
           pc.trim_bof=true;
         pc.pending_state=0;          pc.pending_state=0;
         pc.string=new(pool()) String(pool());             pc.string=NEW String(pool());   
         pc.ls=LS_USER;          pc.ls=LS_USER;
         pc.sp=0;          pc.ls_sp=0;
           pc.in_call_value=false;
                   
         // parse!           // parse=compile! 
         yydebug=1;          //yydebug=1;
         if(yyparse(&pc)) { // error?          if(yyparse(&pc)) { // error?
                 if(pc.col==1) {                  if(pc.col==0) { // expecting something after EOL means they've expected it BEFORE
                         // step back from last char.  -1 col means EOL                          // step back.  -1 col means EOL
                         pc.line--;                          pc.line--;
                         pc.col=-1;                          pc.col=-1;
                 }                  } 
                 exception().raise(0,0,                  throw Exception("parser.compile",
                         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          // result
         return *pc.methods;          return *pc.cclass;
 }  }

Removed from v.1.11  
changed lines
  Added in v.1.67


E-mail: