Annotation of parser3/src/types/pa_vdouble.h, revision 1.34
1.11 paf 1: /** @file
1.16 paf 2: Parser: @b double parser class decl.
1.11 paf 3:
1.31 paf 4: Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com)
1.32 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.1 paf 6:
1.34 ! paf 7: $Id: pa_vdouble.h,v 1.33 2002/02/18 15:33:38 paf Exp $
1.1 paf 8: */
9:
10: #ifndef PA_VDOUBLE_H
11: #define PA_VDOUBLE_H
12:
1.19 paf 13: #include "classes.h"
1.9 paf 14: #include "pa_common.h"
1.5 paf 15: #include "pa_vstateless_object.h"
1.17 paf 16:
17: extern Methoded *double_class;
1.1 paf 18:
1.11 paf 19: /// value of type 'double'. implemented with @c double
1.4 paf 20: class VDouble : public VStateless_object {
1.1 paf 21: public: // Value
22:
23: const char *type() const { return "double"; }
1.24 parser 24: /// VDouble: clone
1.27 parser 25: Value *as_expr_result(bool ) { return NEW VDouble(pool(), fdouble); }
1.1 paf 26:
1.30 paf 27: /** VDouble: fdouble
28: */
1.1 paf 29: const String *get_string() {
1.6 paf 30: char *buf=(char *)pool().malloc(MAX_NUMBER);
1.22 parser 31: String *result=NEW String(pool());
1.23 parser 32: result->APPEND_CLEAN(
1.33 paf 33: buf, snprintf(buf, MAX_NUMBER, "%g", fdouble),
1.23 parser 34: name().origin().file, name().origin().line);
1.22 parser 35: return result;
1.1 paf 36: }
1.11 paf 37: /// VDouble: fdouble
1.25 parser 38: double as_double() const { return fdouble; }
1.21 parser 39: /// VDouble: fdouble
1.25 parser 40: int as_int() const { return (int)fdouble; }
1.11 paf 41: /// VDouble: 0 or !0
1.25 parser 42: bool as_bool() const { return fdouble!=0; }
1.10 paf 43:
44: protected: // VAliased
45:
1.13 paf 46: /// disable .CLASS element. @see VAliased::get_element
1.15 paf 47: bool hide_class() { return true; }
1.1 paf 48:
49: public: // usage
50:
1.4 paf 51: VDouble(Pool& apool, double adouble) : VStateless_object(apool, *double_class),
1.1 paf 52: fdouble(adouble) {
53: }
54:
55: void inc(double increment) { fdouble+=increment; }
1.7 paf 56: void mul(double k) { fdouble*=k; }
57: void div(double d) { fdouble/=d; }
58: void mod(int d) { fdouble=((int)fdouble)%d; }
1.1 paf 59:
60: private:
61:
62: double fdouble;
63:
64: };
65:
66: #endif
E-mail: