summaryrefslogtreecommitdiffstats
path: root/tests/002/proc/2354
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2019-06-28 07:54:35 -0700
committerKaz Kylheku <kaz@kylheku.com>2019-06-28 07:54:35 -0700
commit43323e1431d5919b8e296b37c38affe1228c27d1 (patch)
tree49a6bb7cdc3e5de1dbad3ec7136bdf1535309d51 /tests/002/proc/2354
parentdc7842296466eba508f791ef1f9a9c3b16f7d4da (diff)
downloadtxr-43323e1431d5919b8e296b37c38affe1228c27d1.tar.gz
txr-43323e1431d5919b8e296b37c38affe1228c27d1.tar.bz2
txr-43323e1431d5919b8e296b37c38affe1228c27d1.zip
seq_info: nullify bugfix.
A change in the nullify function to support hash tables has broken various functions which classify an object using seq_info, obtainig a SEQ_HASHLIKE kind, and then work with si.obj using hash functions. But si.obj has been nullified. An example of a broken function is find-max. Basically, this can be attributed to a careless use of nullify in seq_info. The purpose of nullify is to support code which treats any sequence as if it were a list. But seq_info doesn't do that; it classifies sequences and treats them according to their kind. Under seq_info, the only non-list objects that get treated as lists are list-like structures. For these it makes sense to call nullify, in case they have a nullify method. * lib.c (seq_info): Don't unconditionally call nullify on all COBJ objects. Only call nullify on struct objects. If that returns nil, then treat the object as SEQ_NIL; and if it returns an object different from the original, then recurse.
Diffstat (limited to 'tests/002/proc/2354')
0 files changed, 0 insertions, 0 deletions