--- parser3/src/classes/classes.h 2001/05/04 10:42:35 1.7 +++ parser3/src/classes/classes.h 2003/01/28 15:42:39 1.23.2.2 @@ -1,16 +1,14 @@ /** @file Parser: @b Methoded class decl. - Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) - - Author: Alexander Petrosyan (http://design.ru/paf) - - $Id: classes.h,v 1.7 2001/05/04 10:42:35 paf Exp $ + Copyright (c) 2001, 2003 ArtLebedev Group (http://www.artlebedev.com) + Author: Alexandr Petrosian (http://paf.design.ru) */ - #ifndef CLASSES_H #define CLASSES_H +static const char* IDENT_CLASSES_H="$Date: 2003/01/28 15:42:39 $"; + #include "pa_vstateless_class.h" #include "pa_array.h" @@ -18,6 +16,12 @@ @see Methoded_array */ class Methoded : public VStateless_class { +public: // Value + + /*override*/ bool put_element(const String& /*name*/, Value * /*value*/, bool /*replace*/) { + return false; // fewer useless Exceptions + } + public: // Methoded /** should Methoded_array::register_directly_used register this class in @@ -27,23 +31,26 @@ public: // Methoded */ virtual bool used_directly() =0; /// use this method to read parameters from root "auto.p"; access r.main_class - virtual void configure_admin(Request& r) {} + virtual void configure_admin(Request& ) {} /// use this method to read parameters from 'MAIN' class; access r.main_class - virtual void configure_user(Request& r) {} + virtual void configure_user(Request& ) {} + /// use it to construct static variables. check some static so that would be only ONCE! + virtual void construct_statics() {} public: // usage - Methoded(Pool& pool) : VStateless_class(pool) { + Methoded(const char *aname, VStateless_classPtr abase=VStateless_classPtrZero): + VStateless_class(ConstStringPtr(new String(aname)), abase) { } void register_directly_used(Request& r); }; -/// @relates Methoded -class Methoded_array : public Array { +/// all Methoded registered here in autogenerated classes.C +class Methoded_array: public Array { public: - Methoded_array(Pool& pool); + Methoded_array(); public: // Methoded for_each-es /// @see Methoded::configure_admin @@ -54,7 +61,6 @@ public: // Methoded for_each-es void register_directly_used(Request& r); }; -extern Methoded_array *methoded_array; -void init_methoded_array(Pool& pool); +extern Methoded_array methoded_array; #endif