diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2017-03-17 22:09:20 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2017-03-17 22:09:20 -0700 |
commit | 1417fd8d7b07bba0ffe574d42e3c787ce067f9c5 (patch) | |
tree | a01dc6f5515fcac5c7382d5ae6fa7e7c715847b2 /lib.c | |
parent | 3f4586d1ee813ecd23456956d5f2c7f4759a5922 (diff) | |
download | txr-1417fd8d7b07bba0ffe574d42e3c787ce067f9c5.tar.gz txr-1417fd8d7b07bba0ffe574d42e3c787ce067f9c5.tar.bz2 txr-1417fd8d7b07bba0ffe574d42e3c787ce067f9c5.zip |
Sandboxing support via *package-alist*.
* eval.c (eval_init): Register *package-alist* variable,
taking on the contents of the packages variable.
* lib.c (package_alist_s): New symbol variable.
(make_package, packagep, find_package, package_alist); Work
with dynamic package alist variable via cur_package_alist_loc
macro.
(get_current_package_alist_loc): New function.
* lib.h (cur_package_alist_loc): New macro.
(packages, package_alist_s, get_current_package_alist_loc):
Declared.
* txr.1: Documented *package-alist* along with notes about
sandboxing. Documented that the package-alist function is
now obsolescent.
Diffstat (limited to 'lib.c')
-rw-r--r-- | lib.c | 22 |
1 files changed, 17 insertions, 5 deletions
@@ -79,6 +79,7 @@ int async_sig_enabled = 0; val packages; val system_package_var, keyword_package_var, user_package_var; +val package_alist_s; val package_s, system_package_s, keyword_package_s, user_package_s; val null_s, t, cons_s, str_s, chr_s, fixnum_s, sym_s, pkg_s, fun_s, vec_s; @@ -4840,7 +4841,7 @@ val make_package(val name) obj->pk.symhash = make_hash(nil, nil, lit("t")); /* don't have t yet! */ obj->pk.hidhash = make_hash(nil, nil, lit("t")); - push(cons(name, obj), &packages); + mpush(cons(name, obj), cur_package_alist_loc); return obj; } } @@ -4852,7 +4853,7 @@ val packagep(val obj) static val lookup_package(val name) { - return cdr(assoc(name, packages)); + return cdr(assoc(name, deref(cur_package_alist_loc))); } val find_package(val package) @@ -4883,15 +4884,16 @@ val delete_package(val package_in) { val package = get_package(lit("delete-package"), package_in, nil); val iter; - packages = alist_nremove1(packages, package->pk.name); - for (iter = packages; iter; iter = cdr(iter)) + loc cpll = cur_package_alist_loc; + set(cpll, alist_nremove1(deref(cpll), package->pk.name)); + for (iter = deref(cpll); iter; iter = cdr(iter)) unuse_package(package, cdar(iter)); return nil; } val package_alist(void) { - return packages; + return deref(cur_package_alist_loc); } val package_name(val package) @@ -5253,6 +5255,16 @@ val get_current_package(void) return pkg; } +loc get_current_package_alist_loc(void) +{ + if (package_alist_s) { + loc var_loc = lookup_var_l(nil, package_alist_s); + if (!nullocp(var_loc)) + return var_loc; + } + return mkcloc(packages); +} + val func_f0(val env, val (*fun)(val)) { val obj = make_obj(); |