summaryrefslogtreecommitdiffstats
path: root/lib.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2017-03-17 22:09:20 -0700
committerKaz Kylheku <kaz@kylheku.com>2017-03-17 22:09:20 -0700
commit1417fd8d7b07bba0ffe574d42e3c787ce067f9c5 (patch)
treea01dc6f5515fcac5c7382d5ae6fa7e7c715847b2 /lib.c
parent3f4586d1ee813ecd23456956d5f2c7f4759a5922 (diff)
downloadtxr-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.c22
1 files changed, 17 insertions, 5 deletions
diff --git a/lib.c b/lib.c
index 358bda30..5d2724fe 100644
--- a/lib.c
+++ b/lib.c
@@ -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();