--- parser3/src/classes/double.C 2001/11/05 11:46:20 1.41 +++ parser3/src/classes/double.C 2002/04/09 06:47:05 1.45 @@ -1,10 +1,10 @@ /** @file Parser: @b double parser class. - Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) - Author: Alexander Petrosyan (http://paf.design.ru) + Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexandr Petrosian (http://paf.design.ru) - $Id: double.C,v 1.41 2001/11/05 11:46:20 paf Exp $ + $Id: double.C,v 1.45 2002/04/09 06:47:05 paf Exp $ */ #include "classes.h" @@ -31,16 +31,22 @@ public: // Methoded // methods -static void _int(Request& r, const String& method_name, MethodParams *) { +static void _int(Request& r, const String& method_name, MethodParams *params) { Pool& pool=r.pool(); + Value *default_code=params->size()>0? + default_code=¶ms->as_junction(0, "default must be int"):0; // (default) + VDouble *vdouble=static_cast(r.self); Value& result=*new(pool) VInt(pool, vdouble->as_int()); result.set_name(method_name); r.write_no_lang(result); } -static void _double(Request& r, const String& method_name, MethodParams *) { +static void _double(Request& r, const String& method_name, MethodParams *params) { Pool& pool=r.pool(); + Value *default_code=params->size()>0? + default_code=¶ms->as_junction(0, "default must be double"):0; // (default) + VDouble *vdouble=static_cast(r.self); Value& result=*new(pool) VDouble(pool, vdouble->as_double()); result.set_name(method_name); @@ -86,7 +92,7 @@ static void _sql(Request& r, const Strin if(default_code) val=r.process(*default_code).as_double(); else { - throw Exception(0, 0, + throw Exception("parser.runtime", &method_name, "produced no result, but no default option specified"); val=0; //calm, compiler @@ -103,10 +109,10 @@ MDouble::MDouble(Pool& apool) : Methoded // ^double.int[] - add_native_method("int", Method::CT_DYNAMIC, _int, 0, 0); + add_native_method("int", Method::CT_DYNAMIC, _int, 0, 1); // ^double.double[] - add_native_method("double", Method::CT_DYNAMIC, _double, 0, 0); + add_native_method("double", Method::CT_DYNAMIC, _double, 0, 1); // ^double.inc[] // ^double.inc[offset]