Annotation of parser3/src/main/core.C, revision 1.48
1.18 paf 1: /*
1.48 ! paf 2: $Id: core.C,v 1.47 2001/03/09 08:19:50 paf Exp $
1.18 paf 3: */
4:
1.23 paf 5: #include "pa_request.h"
1.29 paf 6: #include "pa_wwrapper.h"
1.23 paf 7: #include "pa_common.h"
8: #include "pa_vclass.h"
9:
10: #include <stdio.h>
1.48 ! paf 11: #include "classes/_root.h"
1.46 paf 12: #include "classes/_string.h"
1.47 paf 13: #include "classes/_double.h"
14: #include "classes/_int.h"
1.23 paf 15:
16: void core() {
1.25 paf 17: Pool pool;
1.48 ! paf 18: initialize_string_class(pool, *(string_class=new(pool) VClass(pool)));
! 19: initialize_double_class(pool, *(double_class=new(pool) VClass(pool)));
! 20: initialize_int_class(pool, *(int_class=new(pool) VClass(pool)));
1.24 paf 21: Request request(pool);
22: request.core();
1.23 paf 23: }
24:
1.43 paf 25: Request::Request(Pool& apool) : Pooled(apool),
26: stack(apool),
1.45 paf 27: root_class(apool),
1.43 paf 28: fclasses(apool),
1.48 ! paf 29: fclasses_array(apool),
! 30: lang(String::Untaint_lang::HTML_TYPO)
1.43 paf 31: {
1.44 paf 32: // construct_root_class
1.48 ! paf 33: initialize_root_class(pool(), root_class);
1.44 paf 34:
35:
1.43 paf 36: // adding root superclass,
37: // parent of all classes,
38: // operators holder
39: String ROOT(pool()); ROOT.APPEND_CONST(ROOT_NAME);
1.45 paf 40: classes().put(ROOT, &root_class);
1.43 paf 41: }
42:
1.23 paf 43: void Request::core() {
1.24 paf 44: TRY {
1.35 paf 45: char *file="Y:\\parser3\\src\\test.p";
1.43 paf 46: String RUN(pool()); RUN.APPEND_CONST(RUN_NAME);
1.35 paf 47: use(file, &RUN);
48:
49: char *result=execute_MAIN();
1.34 paf 50: printf("result-----------------\n%sEOF----------------\n", result);
1.24 paf 51: }
52: CATCH(e) {
1.31 paf 53: printf("\nERROR: ");
54: const String *problem_source=e.problem_source();
55: if(problem_source) {
56: const Origin& origin=problem_source->origin();
57: if(origin.file)
58: printf("%s(%d): ",
59: origin.file, 1+origin.line);
1.32 paf 60: printf("'%s' ",
1.31 paf 61: problem_source->cstr());
62: }
63: printf("%s", e.comment());
1.23 paf 64: const String *type=e.type();
65: if(type) {
66: printf(" type: %s", type->cstr());
67: const String *code=e.code();
68: if(code)
69: printf(", code: %s", code->cstr());
70: }
1.31 paf 71: printf("\n");
1.23 paf 72: }
1.24 paf 73: END_CATCH
1.23 paf 74: }
75:
1.43 paf 76: void Request::use(char *file, String *name) {
1.42 paf 77: // TODO: обнаружить|решить cyclic dependences
1.23 paf 78: char *source=file_read(pool(), file);
1.37 paf 79: if(!source)
80: THROW(0,0,
81: 0,
82: "use: can not read '%s' file", file);
83:
1.43 paf 84: COMPILE(source, name, file);
85: // TODO: запустить @STATIC[], если есть
86:
87: // if(alias)
88: //classes().put(*alias, &vclass);
1.23 paf 89: }
90:
1.35 paf 91: char *Request::execute_MAIN() {
92: // locate class with @main & it's code
1.23 paf 93: String name_main(pool());
94: name_main.APPEND_CONST(MAIN_METHOD_NAME);
95:
1.35 paf 96: // looking for latest known @main
97: for(int i=classes_array().size(); --i>=0;) {
98: VClass *vclass=static_cast<VClass *>(classes_array().get(i));
99: Value *main=vclass->get_element(name_main);
100: if(main) { // found some 'main' element
101: Junction *junction=main->get_junction();
1.36 paf 102: if(junction) {// it even has junction!
103: const Method *method=junction->method;
104: if(method) { // and junction is method-junction! call it
105: // initialize contexts
1.41 paf 106: root=rcontext=self=vclass;
1.40 paf 107: wcontext=NEW WWrapper(pool(), vclass, false /* not constructing */);
1.36 paf 108:
109: // execute!
1.44 paf 110: execute(*method->parser_code);
1.36 paf 111:
112: // return chars
113: return wcontext->get_string()->cstr();
114: }
1.35 paf 115: }
116: }
117: }
118:
119: THROW(0,0,
120: 0,
121: "'"MAIN_METHOD_NAME"' method not found");
122: return 0;
1.23 paf 123: }
E-mail: