--- parser3/src/main/Attic/core.C 2001/02/12 13:26:55 1.4 +++ parser3/src/main/Attic/core.C 2001/03/10 11:44:42 1.50 @@ -1,134 +1,25 @@ -void process(Pool& pool, - Value& self, - RContext& rcontext, WContext& wcontext, - StringIterator& code, char char_to_stop_before) { - - // $ on code? - process_dollar(pool, rcontext, wcontext, code, char_to_stop_before); - - // ^ on code? - process_bird(pool, rcontext, wcontext, code, char_to_stop_before); - - // TODO - // 1. случаи :: и this. в начале - // 2. вызовы статических методов -} - -void process_dollar(Pool& pool, - Value& self, - RContext& rcontext, WContext& wcontext, - StringIterator& iter, char char_to_stop_before) { - - // $name.field.subfield -- read - // $name.field.subfield(constructor code) -- construct - // $name.field.subfield[usage code & if none existed autoconstructed as VHash] -- use OR auto-VHash construct - - Array/**/ names(pool); // what.they.refer.to left-to-right list - char names_ended_before; // the char after long name - get_names( - iter, " ([", - &names, &names_ended_before); // must return count()>0 - - bool read_mode=name_ended_before==' '; - Value *context=read_mode?rcontext:wcontext; - - if(read_mode) { - // 'context' dive into dotted path - for(int i=0; iget_element(static_cast(names.get[i])); - if(!context) // no such object field, nothing bad, just ignore that - return; - } - wcontext.write(context); - } else { // write mode - iter++; // skip '(' '[' - - bool construct_mode=names_ended_before=='('; - - // 'context' dive into dotted path, - int steps=names.count(); - // if constructing then "excluding last .name" - if(construct_mode) - steps--; - for(int i=0; i(names.get[i]); - Value *next_current=context->get_element(name); - if(next_current) - next_current=context->put_element(name, new(pool) VHash(pool)); - context=new_current; - } - - if(construct_mode) { - // .name(construct-code), processing on rcontext in empty temp wcontext - // pure side effect, no wcontext.write here - // last .name - String& name=static_cast(names.get[steps]); - WContext local_wcontext(pool /* empty */); - process(pool, rcontext, local_wcontext, iter, ')'); - context->put_element(name, local_wcontext.value()); - } else { // =='[' - // .name[with-code], processing on 'context' - WContext local_context(pool, context); - process(pool, local_context, local_context, iter, ']'); - wcontext.write(local_context); - } - - iter++; // skip ')' ']' - } +/* +$Id: core.C,v 1.50 2001/03/10 11:44:42 paf Exp $ +*/ + +#include "core.h" +#include "classes/_string.h" +#include "classes/_double.h" +#include "classes/_int.h" +#include "pa_request.h" + +String *unnamed_name; +String *empty_string; + +void core() { + Pool pool; + unnamed_name=new(pool) String(pool); unnamed_name->APPEND_CONST("unnamed"); + empty_string=new(pool) String(pool); + + initialize_string_class(pool, *(string_class=new(pool) VClass(pool))); + initialize_double_class(pool, *(double_class=new(pool) VClass(pool))); + initialize_int_class(pool, *(int_class=new(pool) VClass(pool))); + Request request(pool); + request.core(); } -void process_bird(Pool& pool, - Value& self, - RContext& rcontext, WContext& wcontext, - StringIterator& iter, char char_to_stop_before) { - - // ^name.field.subfield.method[..] -- plain call - // ^name.field.subfield.method_ref[..] -- method ref call, when .get_method()!=0 - - Array/**/ names(pool); // what.they.refer.to left-to-right list - char names_ended_before; // the char after long name - get_names( - iter, "[", - &names, &names_ended_before); // must return count()>0 - - Value *context=rcontext; - iter++; // skip '[' - - // 'context' dive into dotted path, excluding last .name - Value *local_self=context; - int steps=names.count()-1; - for(int i=0; i(names.get[i]); - context=(local_self=context)->get_element(name); - if(!context) // no such object field, sad story: can't call method of void - pool.exception().raise(name, "call: to void.method"); - } - - // last .name - String& name=static_cast(names.get[steps]); - // first we're trying to locate method with that 'name' - Method *method=context.get_method(name); - if(!method) { // no such method: try to locate method ref field - Value *value=context.get_element(name); - if(!value) // failed: no element of that 'name' - pool.exception().raise(name, "call: no method field found"); - method=value->get_method(); - if(!method) // failed: that field wasn't method_ref - pool.exception().raise(name, "call: this field is not a method reference"); - local_self=value->get_self(); - } - - - Array/**/ param_values(pool); - get_params( - iter, "]", - ¶m_values); - iter++; // skip ']' - - Method_self_n_params local_rcontext(pool, - local_self, - method->param_names, param_values); - WContext local_wcontext(pool /* empty */); - process(pool, local_rcontext, local_wcontext, iter, ']'); - wcontext.write(local_wcontext); -} \ No newline at end of file