diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2017-01-23 22:40:52 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2017-01-23 22:40:52 -0800 |
commit | 2f4e1ba3ba68c2b5c0f92778352866d6ed9959b0 (patch) | |
tree | 1a0e294cd0bbc4f1c1fe09c2bec2f856d724d845 /lisplib.c | |
parent | 519c0c3622417251d6cdff828547a6bb74e6b4b9 (diff) | |
download | txr-2f4e1ba3ba68c2b5c0f92778352866d6ed9959b0.tar.gz txr-2f4e1ba3ba68c2b5c0f92778352866d6ed9959b0.tar.bz2 txr-2f4e1ba3ba68c2b5c0f92778352866d6ed9959b0.zip |
Support keyword params via :key param list macro.
* eval.c (expand_param_macro): Use lisplib_try_load to retry
failed parameter macro lookup, thereby supporting auto-loading
of modules that define parameter macros.
* lisplib.c (keyparams_set_entries, keyparams_instantiate): New static
functions.
(lisplib_init): Support autoloading of keyparams.tl via new
functions.
* share/txr/stdlib/keyparams.tl: New file.
* txr.1: Documented :key param list macro.
* checkman.txr: Support "Parameter list macro" documentation
section type.
Diffstat (limited to 'lisplib.c')
-rw-r--r-- | lisplib.c | 18 |
1 files changed, 18 insertions, 0 deletions
@@ -498,6 +498,23 @@ static val error_instantiate(val set_fun) return nil; } +static val keyparams_set_entries(val dlt, val fun) +{ + val key_k = intern(lit("key"), keyword_package); + if (fun) + sethash(dlt, key_k, fun); + else + remhash(dlt, key_k); + return nil; +} + +static val keyparams_instantiate(val set_fun) +{ + funcall1(set_fun, nil); + load(format(nil, lit("~akeyparams.tl"), stdlib_path, nao)); + return nil; +} + val dlt_register(val dlt, val (*instantiate)(val), val (*set_entries)(val, val)) @@ -536,6 +553,7 @@ void lisplib_init(void) dlt_register(dl_table, tagbody_instantiate, tagbody_set_entries); dlt_register(dl_table, pmac_instantiate, pmac_set_entries); dlt_register(dl_table, error_instantiate, error_set_entries); + dlt_register(dl_table, keyparams_instantiate, keyparams_set_entries); } val lisplib_try_load(val sym) |