summaryrefslogtreecommitdiffstats
path: root/eval.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2016-04-14 19:57:38 -0700
committerKaz Kylheku <kaz@kylheku.com>2016-04-14 19:57:38 -0700
commit424696dc09a91939c8c5fb66975be0f737fac9aa (patch)
tree4ca0b46aaecb188d9ffdcb0a70e434e011d5cd0c /eval.c
parentd790a3cca5309d86d752bb99a1eeaf3b6ee9c71b (diff)
downloadtxr-424696dc09a91939c8c5fb66975be0f737fac9aa.tar.gz
txr-424696dc09a91939c8c5fb66975be0f737fac9aa.tar.bz2
txr-424696dc09a91939c8c5fb66975be0f737fac9aa.zip
Fix proper-listp to proper-list-p.
This is really a gratuitous incompatibility with Common Lisp and other dialects. Let's fix it internally also, but keep the proper-listp function binding for backwards compatibility. * eval.c (dot_to_apply, me_op): Update proper_listp call to proper_list_p. (eval_init): Register proper-list-p to the same C function as proper-listp, and that C function is now called proper_list_p. * lib.c (proper_listp): Renamed to proper_list_p. * lib.h (proper_listp): Declaration updated. * parser.y (define_transform): Update proper_listp call. * txr.1: Replace all occurrences of proper-listp with proper-list-p. Add note explaining the rename situation.
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/eval.c b/eval.c
index daa795ba..25678510 100644
--- a/eval.c
+++ b/eval.c
@@ -2498,7 +2498,7 @@ static val imp_list_to_list(val list)
static val dot_to_apply(val form, val lisp1_p)
{
- if ((opt_compat && opt_compat <= 137) || proper_listp(form)) {
+ if ((opt_compat && opt_compat <= 137) || proper_list_p(form)) {
return form;
} else {
val sym = car(form);
@@ -2937,7 +2937,7 @@ static val me_op(val form, val menv)
uses_or2;
val dwim_body = rlcp_tree(cons(dwim_s,
if3(or4(is_op, has_rest, ssyms,
- null(proper_listp(body_trans))),
+ null(proper_list_p(body_trans))),
body_trans,
append2(body_trans, rest_gensym))),
body_trans);
@@ -4789,7 +4789,11 @@ void eval_init(void)
reg_fun(intern(lit("consp"), user_package), func_n1(consp));
reg_fun(intern(lit("lconsp"), user_package), func_n1(lconsp));
reg_fun(intern(lit("listp"), user_package), func_n1(listp));
- reg_fun(intern(lit("proper-listp"), user_package), func_n1(proper_listp));
+ {
+ val proper_list_p_f = func_n1(proper_list_p);
+ reg_fun(intern(lit("proper-listp"), user_package), proper_list_p_f);
+ reg_fun(intern(lit("proper-list-p"), user_package), proper_list_p_f);
+ }
reg_fun(intern(lit("length-list"), user_package), func_n1(length_list));
reg_fun(intern(lit("mapcar"), user_package), func_n1v(mapcarv));