summaryrefslogtreecommitdiffstats
path: root/unwind.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2016-12-20 07:57:46 -0800
committerKaz Kylheku <kaz@kylheku.com>2016-12-20 07:57:46 -0800
commit6bb45477014c490a6f6d9fac3a73020ce284145f (patch)
tree0250cf7b342922fd5a2c7174c0b96539252181af /unwind.c
parent7c5b70d7d17faf6543350dffe56292e3f7dff679 (diff)
downloadtxr-6bb45477014c490a6f6d9fac3a73020ce284145f.tar.gz
txr-6bb45477014c490a6f6d9fac3a73020ce284145f.tar.bz2
txr-6bb45477014c490a6f6d9fac3a73020ce284145f.zip
New function: find-frames.
* unwind.c (uw_find_frames_impl): New static function, made from uw_find_frame. (uw_find_frame): Reduced to wrapper around uw_find_frames_impl. (uw_find_frames): New function. (uw_late_init): Register find-frames intrinsic. * unwind.h (uw_find_frames): Declared. * txr.1: Documented.
Diffstat (limited to 'unwind.c')
-rw-r--r--unwind.c20
1 files changed, 17 insertions, 3 deletions
diff --git a/unwind.c b/unwind.c
index 056cdb50..5a880acc 100644
--- a/unwind.c
+++ b/unwind.c
@@ -335,10 +335,11 @@ val uw_get_frames(void)
return out;
}
-val uw_find_frame(val extype, val frtype)
+static val uw_find_frames_impl(val extype, val frtype, val just_one)
{
uw_frame_t *ex;
uw_frtype_t et;
+ list_collect_decl (out, ptail);
extype = default_bool_arg(extype);
frtype = default_arg_strict(frtype, catch_frame_type);
@@ -373,12 +374,24 @@ val uw_find_frame(val extype, val frtype)
slotset(fr, jump_s, cptr(coerce(mem_t *, ex)));
else
slotset(fr, fun_s, ex->ha.fun);
- return fr;
+ if (just_one)
+ return fr;
+ ptail = list_collect(ptail, fr);
}
}
}
- return nil;
+ return out;
+}
+
+val uw_find_frame(val extype, val frtype)
+{
+ return uw_find_frames_impl(extype, frtype, t);
+}
+
+val uw_find_frames(val extype, val frtype)
+{
+ return uw_find_frames_impl(extype, frtype, nil);
}
val uw_invoke_catch(val catch_frame, val sym, struct args *args)
@@ -987,6 +1000,7 @@ void uw_late_init(void)
reg_fun(intern(lit("exception-subtype-map"), user_package), func_n0(exception_subtype_map));
reg_fun(intern(lit("get-frames"), user_package), func_n0(uw_get_frames));
reg_fun(intern(lit("find-frame"), user_package), func_n2o(uw_find_frame, 0));
+ reg_fun(intern(lit("find-frames"), user_package), func_n2o(uw_find_frames, 0));
reg_fun(intern(lit("invoke-catch"), user_package),
func_n2v(uw_invoke_catch));
reg_fun(sys_capture_cont_s = intern(lit("capture-cont"), system_package),