summaryrefslogtreecommitdiffstats
path: root/regex.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2012-03-17 20:30:15 -0700
committerKaz Kylheku <kaz@kylheku.com>2012-03-17 20:30:15 -0700
commitd268addccbf0cfdb19f84103f85874daf410e1a6 (patch)
tree4db5ade3b4a64ccf06d6a9b344e8a0625096fb07 /regex.c
parent302c1d3aeb9e05c3d2888529589217292f7e1c02 (diff)
downloadtxr-d268addccbf0cfdb19f84103f85874daf410e1a6.tar.gz
txr-d268addccbf0cfdb19f84103f85874daf410e1a6.tar.bz2
txr-d268addccbf0cfdb19f84103f85874daf410e1a6.zip
Changing type function to not blow up on nil, which makes a lot of code
simpler. A pseudo type code is introduced called NIL with value 0. * lib.h (enum type): New enumeration value, NIL. (type): Function accepts object nil and maps it to code NIL. * eval.c (dwim_loc, op_dwim): test for nil obj and goto hack is gone, just handle NIL in the switch. * gc.c (make_obj, mark): Handle new NIL type code in switch. * hash.c (equal_hash): Handle NIL in the switch instead of nil test. * lib.c (code2type): Map new NIL type code to null. (typeof, typecheck): Code simplified. (class_check, car): Move nil test into switch. (eql, equal, consp, bignump, stringp, lazy_stringp, symbolp, functionp, vectorp, cobjp): Simplified. (length, sub, ref, refset, replace, obj_print, obj_pprint): Handle NIL in switch instead of nil test. goto hack removed from refset. * match.c (do_match_line, do_output_line): switch condition simplified. * regex.c (regexp): Simplified. (regex_nfa): Assert condition simplified.
Diffstat (limited to 'regex.c')
-rw-r--r--regex.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/regex.c b/regex.c
index 9d07f411..2fc08c64 100644
--- a/regex.c
+++ b/regex.c
@@ -1511,13 +1511,12 @@ val regexp(val obj)
if (consp(obj))
return if2(eq(car(obj), compiled_regex_s), t);
- return (is_ptr(obj) && obj->co.type == COBJ && obj->co.cls == regex_s)
- ? t : nil;
+ return typeof(obj) == regex_s ? t : nil;
}
static nfa_t *regex_nfa(val reg)
{
- assert (reg->co.type == COBJ && reg->co.cls == regex_s);
+ assert (typeof(reg) == regex_s);
return (nfa_t *) reg->co.handle;
}