Annotation of parser3/src/classes/int.C, revision 1.44
1.18 paf 1: /** @file
2: Parser: @b int parser class.
3:
1.39 paf 4: Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com)
1.40 paf 5: Author: Alexandr Petrosian <paf@design.ru> (http://paf.design.ru)
1.18 paf 6:
1.44 ! paf 7: $Id: int.C,v 1.43 2002/04/10 09:53:14 paf Exp $
1.1 paf 8: */
9:
1.22 paf 10: #include "classes.h"
1.1 paf 11: #include "pa_request.h"
12: #include "pa_vdouble.h"
13: #include "pa_vint.h"
14:
1.20 paf 15: // externs
1.1 paf 16:
1.20 paf 17: void _string_format(Request& r, const String& method_name, MethodParams *);
18:
19: // class
20:
21: class MInt : public Methoded {
22: public:
23: MInt(Pool& pool);
1.23 paf 24: public: // Methoded
1.25 parser 25: bool used_directly() { return true; }
1.20 paf 26: };
1.1 paf 27:
28: // methods
29:
1.42 paf 30: static void _int(Request& r, const String& method_name, MethodParams *params) {
1.1 paf 31: Pool& pool=r.pool();
1.44 ! paf 32: // just checking (default) syntax validity, never really using it here, just for string.int compatibility
! 33: if(params->size()>0)
! 34: params->as_junction(0, "default must be int");
1.42 paf 35:
1.1 paf 36: VInt *vint=static_cast<VInt *>(r.self);
1.44 ! paf 37: r.write_no_lang(*new(pool) VInt(pool, vint->get_int()));
1.1 paf 38: }
39:
1.42 paf 40: static void _double(Request& r, const String& method_name, MethodParams *params) {
1.1 paf 41: Pool& pool=r.pool();
1.44 ! paf 42: // just checking (default) syntax validity, never really using it here, just for string.doube compatibility
! 43: if(params->size()>0)
! 44: params->as_junction(0, "default must be double");
1.42 paf 45:
1.1 paf 46: VInt *vint=static_cast<VInt *>(r.self);
1.44 ! paf 47: r.write_no_lang(*new(pool) VDouble(pool, vint->as_double()));
1.1 paf 48: }
49:
1.13 paf 50: typedef void (*vint_op_func_ptr)(VInt& vint, double param);
51:
52: static void __inc(VInt& vint, double param) { vint.inc((int)param); }
53: static void __dec(VInt& vint, double param) { vint.inc((int)-param); }
54: static void __mul(VInt& vint, double param) { vint.mul(param); }
55: static void __div(VInt& vint, double param) { vint.div(param); }
56: static void __mod(VInt& vint, double param) { vint.mod((int)param); }
57:
1.19 paf 58: static void vint_op(Request& r, MethodParams *params,
1.13 paf 59: vint_op_func_ptr func) {
1.1 paf 60: VInt *vint=static_cast<VInt *>(r.self);
1.35 parser 61: double param=params->size()?params->as_double(0, "param must be numerical", r):1;
1.13 paf 62: (*func)(*vint, param);
1.1 paf 63: }
64:
1.19 paf 65: static void _inc(Request& r, const String&, MethodParams *params) { vint_op(r, params, &__inc); }
66: static void _dec(Request& r, const String&, MethodParams *params) { vint_op(r, params, &__dec); }
67: static void _mul(Request& r, const String&, MethodParams *params) { vint_op(r, params, &__mul); }
68: static void _div(Request& r, const String&, MethodParams *params) { vint_op(r, params, &__div); }
69: static void _mod(Request& r, const String&, MethodParams *params) { vint_op(r, params, &__mod); }
1.15 paf 70:
1.26 parser 71: // from string.C
1.25 parser 72: extern
1.36 parser 73: const String* sql_result_string(Request& r, const String& method_name, MethodParams *params,
74: Hash *& options, Value *& default_code);
1.25 parser 75:
76: static void _sql(Request& r, const String& method_name, MethodParams *params) {
77: Pool& pool=r.pool();
78:
1.31 parser 79: int val;
1.32 parser 80: Hash *options;
1.36 parser 81: Value *default_code;
82: if(const String *string=sql_result_string(r, method_name, params, options, default_code))
1.31 parser 83: val=string->as_int();
84: else
1.36 parser 85: if(default_code)
1.43 paf 86: val=r.process_to_value(*default_code).as_int();
1.36 parser 87: else {
1.41 paf 88: throw Exception("parser.runtime",
1.31 parser 89: &method_name,
1.36 parser 90: "produced no result, but no default option specified");
1.31 parser 91: val=0; //calm, compiler
92: }
1.44 ! paf 93: r.write_no_lang(*new(pool) VInt(pool, val));
1.25 parser 94: }
95:
1.20 paf 96: // constructor
97:
1.44 ! paf 98: MInt::MInt(Pool& apool) : Methoded(apool, "int") {
1.9 paf 99: // ^int.int[]
1.42 paf 100: add_native_method("int", Method::CT_DYNAMIC, _int, 0, 1);
1.9 paf 101:
102: // ^int.double[]
1.42 paf 103: add_native_method("double", Method::CT_DYNAMIC, _double, 0, 1);
1.9 paf 104:
105: // ^int.inc[]
106: // ^int.inc[offset]
1.20 paf 107: add_native_method("inc", Method::CT_DYNAMIC, _inc, 0, 1);
1.13 paf 108: // ^int.dec[]
109: // ^int.dec[offset]
1.20 paf 110: add_native_method("dec", Method::CT_DYNAMIC, _dec, 0, 1);
1.13 paf 111: // ^int.mul[k]
1.20 paf 112: add_native_method("mul", Method::CT_DYNAMIC, _mul, 1, 1);
1.13 paf 113: // ^int.div[d]
1.20 paf 114: add_native_method("div", Method::CT_DYNAMIC, _div, 1, 1);
1.13 paf 115: // ^int.mod[offset]
1.20 paf 116: add_native_method("mod", Method::CT_DYNAMIC, _mod, 1, 1);
1.13 paf 117:
1.12 paf 118:
1.18 paf 119: // ^int.format{format}
1.20 paf 120: add_native_method("format", Method::CT_DYNAMIC, _string_format, 1, 1);
1.26 parser 121:
1.32 parser 122: // ^sql[query]
123: // ^sql[query][$.limit(1) $.offset(2) $.default(0)]
1.30 parser 124: add_native_method("sql", Method::CT_STATIC, _sql, 1, 2);
1.20 paf 125: }
126: // global variable
127:
128: Methoded *int_class;
129:
130: // creator
131:
132: Methoded *MInt_create(Pool& pool) {
133: return int_class=new(pool) MInt(pool);
1.1 paf 134: }
E-mail: