X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fsearch.c;h=12e1c61220c458aed634d05854b79763ecea8272;hb=0e3c4b4db102bd204a30402d7e5a0de44aea57ce;hp=e2d642bd90477d740926a88d209e2ea07cc59f35;hpb=3c65762b927af861c9c8bc416e4cbac9a14ec0c3;p=sbcl.git diff --git a/src/runtime/search.c b/src/runtime/search.c index e2d642b..12e1c61 100644 --- a/src/runtime/search.c +++ b/src/runtime/search.c @@ -9,19 +9,22 @@ * files for more information. */ -#include "runtime.h" +#include + #include "sbcl.h" +#include "runtime.h" #include "os.h" #include "search.h" +#include "thread.h" +#include "genesis/primitive-objects.h" boolean search_for_type(int type, lispobj **start, int *count) { - lispobj obj, *addr; + lispobj obj; while ((*count == -1 || (*count > 0)) && - is_valid_lisp_addr((os_vm_address_t)*start)) { + is_valid_lisp_addr((os_vm_address_t)*start)) { obj = **start; - addr = *start; if (*count != -1) *count -= 2; @@ -40,13 +43,15 @@ boolean search_for_symbol(char *name, lispobj **start, int *count) while (search_for_type(SYMBOL_HEADER_WIDETAG, start, count)) { symbol = (struct symbol *)native_pointer((lispobj)*start); - if (lowtag_of(symbol->name) == OTHER_POINTER_LOWTAG) { + if (lowtag_of(symbol->name) == OTHER_POINTER_LOWTAG) { symbol_name = (struct vector *)native_pointer(symbol->name); if (is_valid_lisp_addr((os_vm_address_t)symbol_name) && - widetag_of(symbol_name->header) == SIMPLE_STRING_WIDETAG && - strcmp((char *)symbol_name->data, name) == 0) + /* FIXME: Broken with more than one type of string + (i.e. even broken given (VECTOR NIL) */ + widetag_of(symbol_name->header) == SIMPLE_BASE_STRING_WIDETAG && + strcmp((char *)symbol_name->data, name) == 0) return 1; - } + } (*start) += 2; } return 0;