diff options
author | Kaz Kyheku <kaz@kylheku.com> | 2020-01-29 05:30:17 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2020-01-29 05:30:17 -0800 |
commit | 4491cf924ada98bc939e51d18ec81751cac0f5f2 (patch) | |
tree | 2e6bf956ac8e36a4eb94f1e9aa6031dacff359ca /lib.c | |
parent | 1c19f40086b23d28280334783679d00b119d8b61 (diff) | |
download | txr-4491cf924ada98bc939e51d18ec81751cac0f5f2.tar.gz txr-4491cf924ada98bc939e51d18ec81751cac0f5f2.tar.bz2 txr-4491cf924ada98bc939e51d18ec81751cac0f5f2.zip |
New function: merge-delete-package.
This is a useful function which supports the use of temporary
packages over the scope of file compilation units.
A file can be read under a temporary package which provides
usefully customized symbol visibility consisting of
an arrangement of symbols from various other packages.
Then, in a single operation, thanks to this new function,
that packag can be deleted and all of its local symbols
(those having been newly interned over the course of the
file) are transferred to some other, more permanent package.
* eval.c (eval_init): merge-delete-package intrinsic
registered.
* lib.c (merge_delete_package): New function.
* lib.h (merge_delete_package): Declared.
* txr.1: Documented.
Diffstat (limited to 'lib.c')
-rw-r--r-- | lib.c | 19 |
1 files changed, 19 insertions, 0 deletions
@@ -5177,6 +5177,25 @@ val delete_package(val package_in) return nil; } +val merge_delete_package(val to_in, val victim_in) +{ + val self = lit("merge-delete-package"); + val to = get_package(self, to_in, nil); + val victim = get_package(self, victim_in, t); + struct hash_iter hi; + val cell; + + us_hash_iter_init(&hi, victim->pk.symhash); + + while ((cell = hash_iter_next(&hi))) { + val sym = us_cdr(cell); + if (symbol_package(sym) == victim) + rehome_sym(sym, to); + } + + return delete_package(victim); +} + val package_alist(void) { return deref(cur_package_alist_loc); |