Annotation of parser3/src/types/pa_vobject.h, revision 1.52
1.6 paf 1: /** @file
1.7 paf 2: Parser: @b object class decl.
3:
1.50 misha 4: Copyright (c) 2001-2009 ArtLebedev Group (http://www.artlebedev.com)
1.16 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.1 paf 6: */
7:
8: #ifndef PA_VOBJECT_H
9: #define PA_VOBJECT_H
10:
1.52 ! misha 11: static const char * const IDENT_VOBJECT_H="$Date: 2009-07-06 12:10:09 $";
1.39 paf 12:
13: // includes
1.19 paf 14:
1.1 paf 15: #include "pa_vjunction.h"
16: #include "pa_vclass.h"
1.4 paf 17: #include "pa_vstateless_object.h"
1.39 paf 18: #include "pa_vfile.h"
1.6 paf 19:
1.23 paf 20: // defines
21:
22: #define BASE_NAME "BASE"
23:
1.26 paf 24: /** parser class instance, stores
25: - class VObject::fclass;
26: - fields VObject::ffields (dynamic, not static, which are stored in class).
27: - links to base/derived instances [VObject::fbase, VObject::fderived]
1.6 paf 28: */
1.24 paf 29: class VObject: public VStateless_object {
1.39 paf 30:
31: VStateless_class& fclass;
1.45 paf 32: HashStringValue& ffields;
1.39 paf 33: VObject* fderived;
34: Value* fbase;
35:
1.1 paf 36: public: // Value
37:
1.39 paf 38: const char* type() const { return fclass.name_cstr(); }
39: override Value* as(const char* atype, bool looking_up);
1.12 parser 40:
1.25 paf 41: /// VObject: fclass
1.39 paf 42: override VStateless_class *get_class() { return &fclass; }
43: override VStateless_class *get_last_derived_class() { return get_last_derived().get_class(); }
44: override Value* base() { return fbase; }
45:
46: override bool is_defined() const;
47: override Value& as_expr_result(bool);
48: override int as_int() const;
1.49 misha 49: override double as_double() const;
1.39 paf 50: override bool as_bool() const;
1.52 ! misha 51: override VFile* as_vfile(String::Language lang, const Request_charsets *charsets=0);
1.33 paf 52:
1.39 paf 53: override HashStringValue* get_hash();
54: override Table *get_table();
1.33 paf 55:
1.48 misha 56: override Value* get_element(const String& aname, Value& aself, bool alooking_up);
1.46 paf 57: override const VJunction* put_element(Value& self, const String& name, Value* value, bool replace);
1.1 paf 58:
1.37 paf 59: /// VObject: remember derived [the only client]
1.39 paf 60: override VObject* set_derived(VObject* aderived) {
61: VObject* result=fderived;
1.25 paf 62: fderived=aderived;
1.34 paf 63: return result;
1.24 paf 64: }
65:
1.1 paf 66: public: // creation
67:
1.50 misha 68: VObject(Pool& apool, VStateless_class& aclass, HashStringValue* afields): fclass(aclass), ffields(*afields), fderived(0) {
1.39 paf 69: if(VStateless_class* base_class=fclass.base_class())
1.45 paf 70: (fbase=base_class->create_new_value(apool, afields))->set_derived(this);
1.1 paf 71: }
72:
73: private:
74:
1.37 paf 75: VObject& get_last_derived() {
76: return fderived?fderived->get_last_derived():*this;
1.26 paf 77: }
1.37 paf 78:
1.45 paf 79: Value* stateless_object__get_element(const String& aname, Value& aself) {
80: return VStateless_object::get_element(aname, aself, false);
81: }
82:
1.49 misha 83: Value* get_scalar_value() const;
84:
1.46 paf 85: const VJunction* stateless_object__put_element(Value& aself, const String& aname, Value* avalue) {
1.45 paf 86: return VStateless_object::put_element(aself, aname, avalue, true/*try to replace! NEVER overwrite*/);
87: }
88:
89: struct Prevent_append_if_exists_in_static_or_base_info {
90: VObject* _this;
91: const String* name;
92: };
1.46 paf 93: static const VJunction* prevent_append_if_exists_in_static_or_base(Value* value,
1.45 paf 94: Prevent_append_if_exists_in_static_or_base_info* info);
95:
1.25 paf 96: };
97:
98: class Temp_derived {
99: Value& fvalue;
1.39 paf 100: VObject* fsaved_derived;
1.25 paf 101: public:
1.39 paf 102: Temp_derived(Value& avalue, VObject* aderived) :
1.25 paf 103: fvalue(avalue),
104: fsaved_derived(avalue.set_derived(aderived)) {}
105: ~Temp_derived() { fvalue.set_derived(fsaved_derived); }
1.1 paf 106: };
107:
108: #endif
E-mail: