--- parser3/src/classes/classes.h 2003/11/20 16:34:23 1.25 +++ parser3/src/classes/classes.h 2016/04/06 16:08:19 1.38 @@ -1,14 +1,14 @@ /** @file Parser: @b Methoded class decl. - Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001-2015 Art. Lebedev Studio (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) */ #ifndef CLASSES_H #define CLASSES_H -static const char * const IDENT_CLASSES_H="$Date: 2003/11/20 16:34:23 $"; +#define IDENT_CLASSES_H "$Id: classes.h,v 1.38 2016/04/06 16:08:19 moko Exp $" // include @@ -20,10 +20,8 @@ static const char * const IDENT_CLASSES_ */ class Methoded: public VStateless_class { public: // Value - - override bool put_element(const String& /*name*/, Value * /*value*/, bool /*replace*/) { - return false; // fewer useless Exceptions - } + + override const char* type() const { return ftype; } public: // Methoded @@ -32,7 +30,7 @@ public: // Methoded if not - global variable with Methoded descendant is used in VStateless_class parameter */ - virtual bool used_directly() =0; + virtual bool used_directly() { return true; } /// use this method to read parameters from root "auto.p"; access r.main_class virtual void configure_admin(Request& ) {} /// use this method to read parameters from 'MAIN' class; access r.main_class @@ -40,11 +38,13 @@ public: // Methoded /// use it to construct static variables. check some static so that would be only ONCE! virtual void construct_statics() {} +private: + + const char* ftype; + public: // usage - Methoded(const char* aname, VStateless_class* abase=0): - VStateless_class(new String(aname), abase) { - } + Methoded(const char* atype): ftype(atype){} void register_directly_used(Request& r); @@ -70,8 +70,7 @@ Methoded_array& methoded_array(); // defines -#define DECLARE_CLASS_VAR(name, self, base) \ - Methoded* name##_class=self; \ - Methoded* name##_base_class=base +#define DECLARE_CLASS_VAR(name, self) \ + Methoded* name##_class=self #endif