aboutsummaryrefslogtreecommitdiff
path: root/model.cpp
diff options
context:
space:
mode:
authorTeddy <ted.sybil@gmail.com>2013-08-07 00:56:37 +0800
committerTeddy <ted.sybil@gmail.com>2013-08-07 00:56:37 +0800
commitcecd643ab2de3e4dbd69e76c58b928ab2aa2a80f (patch)
tree773d94e7a4309b32d61ee724b8dfd82e2e460221 /model.cpp
parentdd6394d93dc21305e26232891daf5b19c226dd3a (diff)
list checking fix
Diffstat (limited to 'model.cpp')
-rw-r--r--model.cpp16
1 files changed, 11 insertions, 5 deletions
diff --git a/model.cpp b/model.cpp
index 4cfdca0..67db5fe 100644
--- a/model.cpp
+++ b/model.cpp
@@ -146,12 +146,18 @@ Cons *ProcObj::call(ArgList *args, Environment * &genvt,
Environment *_envt = new Environment(envt);
// static_cast<SymObj*> because the para_list is already checked
Cons *ptr, *ppar;
- for (ptr = TO_CONS(args->cdr), ppar = para_list;
- ptr != empty_list && ppar != empty_list;
- ptr = TO_CONS(ptr->cdr), ppar = TO_CONS(ppar->cdr))
+ EvalObj *nptr;
+ for (ptr = TO_CONS(args->cdr), ppar = para_list;
+ ppar != empty_list;
+ ppar = TO_CONS(ppar->cdr))
+ {
_envt->add_binding(static_cast<SymObj*>(ppar->car), ptr->car);
+ if ((nptr = ptr->cdr)->is_cons_obj())
+ ptr = TO_CONS(nptr);
+ else break;
+ }
- if (ptr != empty_list || ppar != empty_list)
+ if (ptr->cdr != empty_list || ppar->cdr != empty_list)
throw TokenError("", RUN_ERR_WRONG_NUM_OF_ARGS);
genvt = _envt;
@@ -166,7 +172,7 @@ string ProcObj::ext_repr() { return string("#<Procedure>"); }
string ProcObj::_debug_repr() { return ext_repr(); }
#endif
-SpecialOptObj::SpecialOptObj() : OptObj() {}
+SpecialOptObj::SpecialOptObj(string _name) : OptObj(), name(_name) {}
BoolObj::BoolObj(bool _val) : EvalObj(CLS_SIM_OBJ | CLS_BOOL_OBJ), val(_val) {}