diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2012-01-27 13:56:14 -0800 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2012-01-27 13:56:14 -0800 |
commit | 5bb09860276ee5a209abe526c922b838c01af549 (patch) | |
tree | 73d0bdf503b9a5aec74dcc169521d6aefb9becb5 | |
parent | 75df8bf9079c5edf23f6b6d3c4b1c5902ddf9653 (diff) | |
download | txr-5bb09860276ee5a209abe526c922b838c01af549.tar.gz txr-5bb09860276ee5a209abe526c922b838c01af549.tar.bz2 txr-5bb09860276ee5a209abe526c922b838c01af549.zip |
* hash.c (hash_begin): Missing type check added, otherwise
passing in an object that is not a hash results in corruption
or crashing behavior.
* lib.c (class_check): Improved to a one-step check with a clear
message.
-rw-r--r-- | ChangeLog | 9 | ||||
-rw-r--r-- | hash.c | 5 | ||||
-rw-r--r-- | lib.c | 5 |
3 files changed, 15 insertions, 4 deletions
@@ -1,3 +1,12 @@ +2012-01-27 Kaz Kylheku <kaz@kylheku.com> + + * hash.c (hash_begin): Missing type check added, otherwise + passing in an object that is not a hash results in corruption + or crashing behavior. + + * lib.c (class_check): Improved to a one-step check with a clear + message. + 2012-01-26 Kaz Kylheku <kaz@kylheku.com> Version 55 @@ -389,7 +389,10 @@ static struct cobj_ops hash_iter_ops = { val hash_begin(val hash) { val hi_obj; - struct hash_iter *hi = (struct hash_iter *) chk_malloc(sizeof *hi); + struct hash_iter *hi; + class_check (hash, hash_s); + + hi = (struct hash_iter *) chk_malloc(sizeof *hi); hi->hash = nil; hi->chain = -1; hi->cons = nil; @@ -169,9 +169,8 @@ val type_check3(val obj, int t1, int t2, int t3) val class_check(val cobj, val class_sym) { - type_check (cobj, COBJ); - type_assert (cobj->co.cls == class_sym, (lit("~a is not a cobj of class ~a"), - cobj, class_sym)); + type_assert (cobj && cobj->t.type == COBJ && cobj->co.cls == class_sym, + (lit("~a is not of type ~a"), cobj, class_sym, nao)); return t; } |