--- parser3/src/main/compile_tools.C 2002/08/21 11:47:25 1.53 +++ parser3/src/main/compile_tools.C 2005/08/05 13:03:00 1.57.14.2 @@ -1,11 +1,11 @@ /** @file Parser: compiler support helper functions. - Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001-2005 ArtLebedev Group (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) */ -static const char* IDENT_COMPILE_TOOLS_C="$Date: 2002/08/21 11:47:25 $"; +static const char * const IDENT_COMPILE_TOOLS_C="$Date: 2005/08/05 13:03:00 $"; #include "compile_tools.h" #include "pa_string.h" @@ -14,70 +14,54 @@ static const char* IDENT_COMPILE_TOOLS_C #include "pa_vstring.h" #include "pa_vdouble.h" -void PV(Array/**/ *result, Value *value) { - // append OP_VALUE - Operation op; op.code=OP_VALUE; - *result+=op.cast; - - // append 'value' - *result+=value; -} - -Value *LA2V(Array *literal_string_array, int offset) { - Operation op; - op.cast=literal_string_array->get(offset+0); - return op.code==OP_VALUE? - static_cast(literal_string_array->get(offset+1)) +Value* LA2V(ArrayOperation& literal_string_array, int offset) { + return literal_string_array[offset+0].code==OP_VALUE?literal_string_array[offset+2/*skip opcode&origin*/].value :0; } -void change_string_literal_to_double_literal(Array *literal_string_array) { - Operation op; - op.cast=literal_string_array->get(0); - if(op.code==OP_VALUE) { - VString *vstring=static_cast(literal_string_array->get(1)); - Value *value=vstring->as_expr_result(); - literal_string_array->put(1, value); - } +void maybe_change_string_literal_to_double_literal(ArrayOperation& literal_array) { + assert(literal_array[0].code==OP_VALUE); + VString& vstring=*static_cast(literal_array[2/*opcode+origin*/].value); + if(isdigit(vstring.string().first_char())) + literal_array.put(2/*opcode+origin*/, &vstring.as_expr_result()); } -void change_string_literal_value(Array *literal_string_array, const String& new_value) { - Operation op; - op.cast=literal_string_array->get(0); - if(op.code==OP_VALUE) { // extra safety - VString *vstring=static_cast(literal_string_array->get(1)); - vstring->set_string(new_value); - } +void change_string_literal_value(ArrayOperation& literal_string_array, const String& new_value) { + assert(literal_string_array[0].code==OP_VALUE); + static_cast(literal_string_array[2/*opcode+origin*/].value)->set_string(new_value); } -void changetail_or_append(Array *opcodes, +void changetail_or_append(ArrayOperation& opcodes, OPCODE find, bool with_argument, OPCODE replace, OPCODE notfound) { - int tail=opcodes->size()-(with_argument?2:1); + int tail=opcodes.count()-(with_argument?2:1); if(tail>=0) { - Operation op; - op.cast=opcodes->get(tail); + Operation& op=opcodes.get_ref(tail); if(op.code==find) { op.code=replace; - opcodes->put(tail, op.cast); return; } } - Operation op; op.code=notfound; - *opcodes+=op.cast; + opcodes+=Operation(notfound); } -void push_LS(parse_control& pc, lexical_state new_state) { +void push_LS(Parse_control& pc, lexical_state new_state) { if(pc.ls_sp=0) pc.ls=pc.ls_stack[pc.ls_sp]; else - throw Exception(0, 0, "pop_LS: ls_stack underflow"); + throw Exception(0, 0, + "pop_LS: ls_stack underflow"); +} + +const String& Parse_control::alias_method(const String& name) { + return (main_alias && name==main_method_name)?*main_alias:name; }