--- parser3/src/classes/Attic/root.C 2001/03/10 11:18:13 1.8 +++ parser3/src/classes/Attic/root.C 2001/03/11 08:44:39 1.13 @@ -1,5 +1,9 @@ /* -$Id: root.C,v 1.8 2001/03/10 11:18:13 paf Exp $ + Parser + Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexander Petrosyan (http://design.ru/paf) + + $Id: root.C,v 1.13 2001/03/11 08:44:39 paf Exp $ */ #include "pa_request.h" @@ -9,26 +13,17 @@ static void _if(Request& r, Array *param bool condition= r.autocalc( *static_cast(params->get(0)), + 0/*no name*/, false/*don't make it string*/).get_bool(); if(condition) { Value& value=r.autocalc(*static_cast(params->get(1))); - r.wcontext->write(value); + r.wcontext->write(value, String::Untaint_lang::PASS_APPENDED); } else if(params->size()==3) { Value& value=r.autocalc(*static_cast(params->get(2))); - r.wcontext->write(value); + r.wcontext->write(value, String::Untaint_lang::PASS_APPENDED); } } void initialize_root_class(Pool& pool, VClass& vclass) { - String& IF_NAME=*new(pool) String(pool); - IF_NAME.APPEND_CONST("if"); - - Method& IF_METHOD=*new(pool) Method(pool, - IF_NAME, - 2, 3, // min,max numbered_params_count - 0/*params_names*/, 0/*locals_names*/, - 0/*parser_code*/, _if - ); - - vclass.add_method(IF_NAME, IF_METHOD); + vclass.add_native_method("if", _if, 2, 3); // ^if(c){t} ^if(c){t}{f} }