Annotation of parser3/src/types/pa_vstring.h, revision 1.81
1.23 paf 1: /** @file
2: Parser: @b string parser class decl.
1.13 paf 3:
1.81 ! moko 4: Copyright (c) 2001-2024 Art. Lebedev Studio (http://www.artlebedev.com)
1.76 moko 5: Authors: Konstantin Morshnev <moko@design.ru>, Alexandr Petrosian <paf@design.ru>
1.1 paf 6: */
7:
8: #ifndef PA_VSTRING_H
9: #define PA_VSTRING_H
1.47 paf 10:
1.81 ! moko 11: #define IDENT_PA_VSTRING_H "$Id: pa_vstring.h,v 1.80 2024/03/14 02:52:43 moko Exp $"
1.1 paf 12:
1.55 paf 13: // includes
1.1 paf 14:
1.4 paf 15: #include "pa_vstateless_object.h"
1.1 paf 16: #include "pa_vdouble.h"
1.24 paf 17:
1.55 paf 18: // externs
19:
20: extern Methoded* string_class;
1.1 paf 21:
1.13 paf 22: /// value of type 'string'. implemented with @c String
1.55 paf 23: class VString: public VStateless_object {
1.1 paf 24: public: // Value
25:
1.55 paf 26: override const char* type() const { return "string"; }
27: override VStateless_class *get_class() { return string_class; }
1.31 parser 28: /// VString: eq ''=false, ne ''=true
1.55 paf 29: override bool is_defined() const { return !fstring->is_empty(); }
1.32 parser 30: /// VString: 0 or !0
1.55 paf 31: override bool as_bool() const { return as_double()!=0; }
1.16 paf 32: /// VString: true
1.55 paf 33: override bool is_string() const { return true; }
1.69 moko 34:
35: /// VString: VDouble
36: override Value& as_expr_result() { return *new VDouble(fstring->as_double()); }
1.13 paf 37: /// VString: fstring
1.55 paf 38: override const String* get_string() { return fstring; };
1.13 paf 39: /// VString: fstring
1.55 paf 40: override double as_double() const { return fstring->as_double(); }
1.26 parser 41: /// VString: fstring
1.55 paf 42: override int as_int() const { return fstring->as_int(); }
1.20 paf 43:
44: /// VString: vfile
1.61 misha 45: override VFile* as_vfile(String::Language lang, const Request_charsets *charsets=0);
1.9 paf 46:
1.63 misha 47: /// VString: json string
1.70 moko 48: override const String* get_json_string(Json_options&) {
1.63 misha 49: String* result = new String();
50: result->append_quoted(fstring);
51: return result;
52: }
53:
1.21 paf 54: /// VString: $method
1.62 misha 55: override Value* get_element(const String& aname) {
1.78 moko 56: #if !defined(FEATURE_GET_ELEMENT4CALL) || !defined(OPTIMIZE_BYTECODE_GET_ELEMENT__SPECIAL)
57: // CLASS, CLASS_NAME and normally hidden $method
1.62 misha 58: if(Value* result=VStateless_object::get_element(aname))
1.9 paf 59: return result;
1.78 moko 60: #endif
61: // void, empty or whitespace string are hash compatible
1.73 moko 62: if (fstring->is_empty() || fstring->trim().is_empty())
63: return 0;
1.9 paf 64:
1.73 moko 65: // bad $string.field
1.71 moko 66: return Value::get_element(aname);
67: }
1.64 moko 68:
1.1 paf 69: public: // usage
70:
1.80 moko 71: VString(): fstring(&String::Empty) {}
1.55 paf 72: VString(const String& avalue): fstring(&avalue) {}
1.1 paf 73:
1.45 paf 74: const String& string() const { return *fstring; }
1.38 paf 75: void set_string(const String& astring) { fstring=&astring; }
1.1 paf 76:
1.68 moko 77: inline static VString *empty(){
78: static VString singleton;
79: return &singleton;
80: }
81:
1.1 paf 82: private:
1.55 paf 83: const String* fstring;
1.1 paf 84:
85: };
86:
87: #endif
E-mail: