diff options
-rw-r--r-- | Python/bltinmodule.c | 65 |
1 files changed, 42 insertions, 23 deletions
diff --git a/Python/bltinmodule.c b/Python/bltinmodule.c index 25e8f42..5bdf5d9 100644 --- a/Python/bltinmodule.c +++ b/Python/bltinmodule.c @@ -54,6 +54,21 @@ builtin_abs(self, v) } static object * +builtin_apply(self, v) + object *self; + object *v; +{ + object *func, *args; + if (v == NULL || !is_tupleobject(v) || gettuplesize(v) != 2) { + err_setstr(TypeError, "apply() requires (func,args)"); + return NULL; + } + func = gettupleitem(v, 0); + args = gettupleitem(v, 1); + return call_object(func, args); +} + +static object * builtin_chr(self, v) object *self; object *v; @@ -550,29 +565,30 @@ builtin_type(self, v) } static struct methodlist builtin_methods[] = { - {"abs", builtin_abs}, - {"chr", builtin_chr}, - {"dir", builtin_dir}, - {"divmod", builtin_divmod}, - {"eval", builtin_eval}, - {"exec", builtin_exec}, - {"float", builtin_float}, - {"hex", builtin_hex}, - {"input", builtin_input}, - {"int", builtin_int}, - {"len", builtin_len}, - {"long", builtin_long}, - {"max", builtin_max}, - {"min", builtin_min}, - {"oct", builtin_oct}, - {"open", builtin_open}, /* XXX move to OS module */ - {"ord", builtin_ord}, - {"pow", builtin_pow}, - {"range", builtin_range}, - {"raw_input", builtin_raw_input}, - {"reload", builtin_reload}, - {"type", builtin_type}, - {NULL, NULL}, + {"abs", builtin_abs}, + {"apply", builtin_apply}, + {"chr", builtin_chr}, + {"dir", builtin_dir}, + {"divmod", builtin_divmod}, + {"eval", builtin_eval}, + {"exec", builtin_exec}, + {"float", builtin_float}, + {"hex", builtin_hex}, + {"input", builtin_input}, + {"int", builtin_int}, + {"len", builtin_len}, + {"long", builtin_long}, + {"max", builtin_max}, + {"min", builtin_min}, + {"oct", builtin_oct}, + {"open", builtin_open}, /* XXX move to OS module */ + {"ord", builtin_ord}, + {"pow", builtin_pow}, + {"range", builtin_range}, + {"raw_input", builtin_raw_input}, + {"reload", builtin_reload}, + {"type", builtin_type}, + {NULL, NULL}, }; static object *builtin_dict; @@ -602,6 +618,7 @@ object *IndexError; object *ValueError; object *KeyError; object *OverflowError; +object *SyntaxError; static object * newstdexception(name, message) @@ -636,6 +653,8 @@ initerrors() KeyError = newstdexception("KeyError", "invalid key"); OverflowError = newstdexception("OverflowError", "arithmetic overflow"); + SyntaxError = + newstdexception("SyntaxError", "syntax error"); } void |