File:  [parser3project] / parser3 / src / main / compile.C
Revision 1.10: download - view: text, annotated - select for diffs - revision graph
Wed Feb 21 17:36:58 2001 UTC (25 years, 3 months ago) by paf
Branches: MAIN
CVS tags: HEAD
get put -1 [just compiled]

/*
  $Id: compile.C,v 1.10 2001/02/21 17:36:58 paf Exp $
*/

#include "pa_request.h"
#include "pa_string.h"
#include "pa_array.h"
#include "code.h"
#include "compile_tools.h"
#include "pa_exception.h"

#include <stdio.h>

extern int yydebug;
extern int yyparse (void *);

Array& Request::real_compile(COMPILE_PARAMS) {
	// prepare to parse
	struct parse_control pc;

	// input 
	pc.pool=&pool();
	pc.methods=new(pool()) Array(pool());
	if(!source)
		return *pc.methods;

	pc.source=source;
#ifndef NO_STRING_ORIGIN
	pc.file=file;
	pc.line=pc.col=0;
#endif
	// initialise state
	pc.pending_state=0;
	String string(pool());	pc.string=&string;
	pc.ls=LS_USER;
	pc.sp=0;
	
	// parse! 
	yydebug=1;
	if(yyparse(&pc)) { // error?
		if(pc.col==1) {
			// step back from last char.  -1 col means EOL
			pc.line--;
			pc.col=-1;
		}
		exception().raise(0,0,
			0,
			"%s [%s:%d:%d]", pc.error, file, 1+pc.line, pc.col);
	}

	// result
	return *pc.methods;
}

E-mail: