Diff for /parser3/src/main/compile.C between versions 1.6 and 1.55

version 1.6, 2001/02/21 07:31:41 version 1.55, 2002/02/07 11:16:27
Line 1 Line 1
 /*  /** @file
   $Id$          Parser: compiler part of request class.
   
           Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com)
           Author: Alexander Petrosyan <paf@design.ru> (http://paf.design.ru)
   
           $Id$
 */  */
   
   #include "pa_opcode.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 "compile.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 *real_compile(COMPILE_PARAMS) {  VStateless_class& Request::real_compile(COMPILE_PARAMS) {
         if(!source)          // prepare to parse
                 return 0;          struct parse_control pc;
   
         Pool& pool=request.pool();          // 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;
   
         yydebug=1;  
         struct parse_control pc;  
         /* input */  
         pc.pool=&pool;  
         pc.source=source;          pc.source=source;
 #ifndef NO_STRING_ORIGIN  #ifndef NO_STRING_ORIGIN
         pc.file=file;          pc.file=file;
         pc.line=pc.col=1;          pc.line=pc.col=0;
 #endif  #endif
         /* state to initial */          // 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;
         /* parse! */          pc.object_constructor_allowed=false;
         if(yyparse(&pc)) // parse, error?  
                 request.exception().raise(0,0,  
                         0,  
                         "%s @%s[%d:%d]", pc.error, file, pc.line, pc.col-1);  
                   
         /* result */          // parse=compile! 
         return pc.result;          //yydebug=1;
           if(yyparse(&pc)) { // error?
                   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 Exception(0,0,
                           0,
   #ifndef NO_STRING_ORIGIN
                           "%s(%d:%d): "
   #endif
                           "%s", 
   #ifndef NO_STRING_ORIGIN
                           file, 1+pc.line, pc.col, 
   #endif
                           pc.error);
           }
   
           // result
           return *pc.cclass;
 }  }

Removed from v.1.6  
changed lines
  Added in v.1.55


E-mail: