From 568214ddf4c8ecc881caec98e20848d017974ec0 Mon Sep 17 00:00:00 2001 From: Nikodemus Siivola Date: Sun, 3 Jul 2005 13:51:06 +0000 Subject: [PATCH] 0.9.2.18: various error &co reporting improvements and build tweaks * print the cell name for CELL-ERRORs when *PRINT-ESCAPE* is true. * print just the filename, not the SHARED-OBJECT structure for failed LOAD-SHARED-OBJECT. * improve our Darwin dlerror(3)-shim reporting; also clean up warnings from ppc-darwin-dlsim.c and reindent it for 80 columns. * move reporting of failed contribs to make-target-contrib.sh, and re-add --disable-debugger, which had accidentally fallen off. --- make-target-contrib.sh | 18 +++++- make.sh | 17 ------ src/code/condition.lisp | 6 ++ src/code/foreign-load.lisp | 4 +- src/runtime/ppc-darwin-dlshim.c | 115 +++++++++++++++++++++++++-------------- version.lisp-expr | 2 +- 6 files changed, 100 insertions(+), 62 deletions(-) diff --git a/make-target-contrib.sh b/make-target-contrib.sh index 28945a9..af56892 100644 --- a/make-target-contrib.sh +++ b/make-target-contrib.sh @@ -26,7 +26,7 @@ find_gnumake SBCL_HOME=`pwd`/contrib export SBCL_HOME -SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit /dev/null --sysinit /dev/null" # --disable-debugger" +SBCL="`pwd`/src/runtime/sbcl --noinform --core `pwd`/output/sbcl.core --userinit /dev/null --sysinit /dev/null --disable-debugger" SBCL_BUILDING_CONTRIB=1 export SBCL SBCL_BUILDING_CONTRIB @@ -52,3 +52,19 @@ for i in contrib/*; do test -f $i/test-passed && rm $i/test-passed $GNUMAKE -C $i test && touch $i/test-passed done + +# Sometimes people used to see the "No tests failed." output from the last +# DEFTEST in contrib self-tests and think that's all that is. So... +HEADER_HAS_BEEN_PRINTED=false +for dir in contrib/* +do + if [ -d "$dir" -a -f "$dir/Makefile" -a ! -f "$dir/test-passed" ]; then + if $HEADER_HAS_BEEN_PRINTED; then + echo > /dev/null + else + echo "Failed contribs:" + HEADER_HAS_BEEN_PRINTED=true + fi + echo " `basename $dir`" + fi +done diff --git a/make.sh b/make.sh index 3a81875..31cd52f 100755 --- a/make.sh +++ b/make.sh @@ -105,25 +105,8 @@ time sh make-host-2.sh || exit 1 time sh make-target-2.sh || exit 1 time sh make-target-contrib.sh || exit 1 -# Sometimes people used to see the "No tests failed." output from the last -# DEFTEST in contrib self-tests and think that's all that is. So... -HEADER_HAS_BEEN_PRINTED=false -for dir in contrib/* -do - if [ -d "$dir" -a -f "$dir/Makefile" -a ! -f "$dir/test-passed" ]; then - if $HEADER_HAS_BEEN_PRINTED; then - echo > /dev/null - else - echo "Failed contribs:" - HEADER_HAS_BEEN_PRINTED=true - fi - echo " `basename $dir`" - fi -done - NCONTRIBS=`find contrib -name Makefile -print | wc -l` NPASSED=`find contrib -name test-passed -print | wc -l` - echo echo "The build seems to have finished successfully, including $NPASSED (out of $NCONTRIBS)" echo "contributed modules. If you would like to run more extensive tests on" diff --git a/src/code/condition.lisp b/src/code/condition.lisp index 29c854a..b89d6d8 100644 --- a/src/code/condition.lisp +++ b/src/code/condition.lisp @@ -648,6 +648,12 @@ (define-condition cell-error (error) ((name :reader cell-error-name :initarg :name))) +(def!method print-object ((condition cell-error) stream) + (if *print-escape* + (print-unreadable-object (condition stream :type t :identity t) + (princ (cell-error-name condition) stream)) + (call-next-method))) + (define-condition unbound-variable (cell-error) () (:report (lambda (condition stream) diff --git a/src/code/foreign-load.lisp b/src/code/foreign-load.lisp index 95a9ecf..8986c97 100644 --- a/src/code/foreign-load.lisp +++ b/src/code/foreign-load.lisp @@ -57,8 +57,8 @@ (if objp (setf (shared-object-sap obj) nil) (setf *runtime-dlhandle* nil)) - (error "Could not open ~:[runtime~;~:*shared object ~S~]: ~A" - obj (dlerror))) + (error "Error opening ~:[runtime~;shared object ~:*~S~]:~% ~A." + file (dlerror))) (when objp (setf (shared-object-sap obj) sap)) sap)) diff --git a/src/runtime/ppc-darwin-dlshim.c b/src/runtime/ppc-darwin-dlshim.c index c6c16f3..dee6dd1 100644 --- a/src/runtime/ppc-darwin-dlshim.c +++ b/src/runtime/ppc-darwin-dlshim.c @@ -33,15 +33,21 @@ static char dl_self; /* I'm going to abuse this */ static int callback_count; static struct mach_header* last_header; -static int last_was_error = 0; -void dlshim_image_callback(struct mach_header* ptr, unsigned long phooey) +#define DLSYM_ERROR 1 +#define DLOPEN_ERROR 2 + +static int last_error = 0; + +void +dlshim_image_callback(struct mach_header* ptr, unsigned long phooey) { callback_count++; last_header = ptr; } -int lib_path_count(void) +int +lib_path_count(void) { char* libpath; int i; @@ -56,7 +62,8 @@ int lib_path_count(void) return count; } -const char* lib_path_prefixify(int index, const char* filename) +const char* +lib_path_prefixify(int index, const char* filename) { static char* retbuf = NULL; int fi, li, i, count; @@ -82,7 +89,8 @@ const char* lib_path_prefixify(int index, const char* filename) } if (li - fi > 0) { if (li - fi + 1 > 1022 - strlen(filename)) { - retbuf = (char*) realloc(retbuf, (li - fi + 3 + strlen(filename))*sizeof(char)); + retbuf = + (char*) realloc(retbuf, (li - fi + 3 + strlen(filename))*sizeof(char)); } memcpy(retbuf, libpath + fi, (li - fi + 1)*sizeof(char)); retbuf[li - fi + 1] = '/'; @@ -93,7 +101,8 @@ const char* lib_path_prefixify(int index, const char* filename) } } -void* dlopen(const char* filename, int flags) +const void* +dlopen(const char* filename, int flags) { static char has_callback = 0; if (!has_callback) { @@ -102,36 +111,52 @@ void* dlopen(const char* filename, int flags) if (!filename) { return &dl_self; } else { - struct mach_header* img = NULL; - if (!img) img = NSAddImage(filename, NSADDIMAGE_OPTION_RETURN_ON_ERROR); - if (!img) img = NSAddImage(filename, NSADDIMAGE_OPTION_RETURN_ON_ERROR | NSADDIMAGE_OPTION_WITH_SEARCHING); + const struct mach_header* img = NULL; + if (!img) + img = NSAddImage(filename, NSADDIMAGE_OPTION_RETURN_ON_ERROR); + if (!img) + img = NSAddImage(filename, + NSADDIMAGE_OPTION_RETURN_ON_ERROR | + NSADDIMAGE_OPTION_WITH_SEARCHING); if (!img) { NSObjectFileImage fileImage; callback_count = 0; last_header = NULL; - if (NSCreateObjectFileImageFromFile(filename, &fileImage) == NSObjectFileImageSuccess) { - NSLinkModule(fileImage, filename, NSLINKMODULE_OPTION_BINDNOW | ((flags & RTLD_GLOBAL)?NSLINKMODULE_OPTION_PRIVATE:0) | NSLINKMODULE_OPTION_RETURN_ON_ERROR); - if (callback_count && last_header) img = last_header; + if (NSCreateObjectFileImageFromFile(filename, &fileImage) + == NSObjectFileImageSuccess) { + NSLinkModule(fileImage, filename, + NSLINKMODULE_OPTION_BINDNOW | + ((flags & RTLD_GLOBAL)?NSLINKMODULE_OPTION_PRIVATE:0) | + NSLINKMODULE_OPTION_RETURN_ON_ERROR); + if (callback_count && last_header) + img = last_header; } } if (!img) { NSObjectFileImage fileImage; int i, maxi; - char* prefixfilename; + const char* prefixfilename; maxi = lib_path_count(); for (i = 0; i < maxi && !img; i++) { prefixfilename = lib_path_prefixify(i, filename); callback_count = 0; last_header = NULL; - if (NSCreateObjectFileImageFromFile(prefixfilename, &fileImage) == NSObjectFileImageSuccess) { - NSLinkModule(fileImage, filename, NSLINKMODULE_OPTION_BINDNOW | ((flags & RTLD_GLOBAL)?NSLINKMODULE_OPTION_PRIVATE:0) | NSLINKMODULE_OPTION_RETURN_ON_ERROR); - if (callback_count && last_header) img = last_header; + if (NSCreateObjectFileImageFromFile(prefixfilename, &fileImage) + == NSObjectFileImageSuccess) { + NSLinkModule(fileImage, filename, + NSLINKMODULE_OPTION_BINDNOW | + ((flags & RTLD_GLOBAL)?NSLINKMODULE_OPTION_PRIVATE:0) | + NSLINKMODULE_OPTION_RETURN_ON_ERROR); + if (callback_count && last_header) + img = last_header; } } } if (img) { if (flags & RTLD_NOW) { - NSLookupSymbolInImage(img, "", NSLOOKUPSYMBOLINIMAGE_OPTION_BIND_FULLY | NSLOOKUPSYMBOLINIMAGE_OPTION_RETURN_ON_ERROR); + NSLookupSymbolInImage(img, "", + NSLOOKUPSYMBOLINIMAGE_OPTION_BIND_FULLY | + NSLOOKUPSYMBOLINIMAGE_OPTION_RETURN_ON_ERROR); } if (NSIsSymbolNameDefinedInImage(img, "__init")) { NSSymbol* initsymbol; @@ -140,35 +165,42 @@ void* dlopen(const char* filename, int flags) initfunc = NSAddressOfSymbol(initsymbol); initfunc(); } - } + } else + last_error = DLOPEN_ERROR; return img; } } -const char* dlerror() +const char* +dlerror() { - static char* errbuf = NULL; - NSLinkEditErrors a; - int b; - char *c, *d; - NSLinkEditError(&a, &b, &c, &d); - if (!errbuf) { - errbuf = (char*) malloc(256*sizeof(char)); - } - if (!(c || d)) { - last_was_error = 0; - snprintf(errbuf, 255, "%s in %s: %d %d", c, d, a, b); - return errbuf; - } else if (last_was_error) { - last_was_error = 0; - snprintf(errbuf, 255, "Can't find symbol"); - return errbuf; + NSLinkEditErrors c; + int errorNumber; + const char *fileName, *errorString; + char *result = NULL; + + if (last_error) { + NSLinkEditError(&c, &errorNumber, &fileName, &errorString); + /* The errorString obtained by the above is too verbose for + * our needs, so we just translate the errno. + * + * We also have simple fallbacks in case we've somehow lost + * the context before this point. */ + if (errorNumber) { + result = strerror(errorNumber); + } else if (DLSYM_ERROR == last_error) { + result = "dlsym(3) failed"; + } else if (DLOPEN_ERROR == last_error) { + result = "dlopen(3) failed"; + } + last_error = 0; } - last_was_error = 0; - return NULL; + + return result; } -void* dlsym(void* handle, char* symbol) +void* +dlsym(void* handle, char* symbol) { if (handle == &dl_self) { if (NSIsSymbolNameDefined(symbol)) { @@ -176,7 +208,7 @@ void* dlsym(void* handle, char* symbol) retsym = NSLookupAndBindSymbol(symbol); return NSAddressOfSymbol(retsym); } else { - last_was_error = 1; + last_error = DLSYM_ERROR; return NULL; } } else { @@ -185,13 +217,14 @@ void* dlsym(void* handle, char* symbol) retsym = NSLookupSymbolInImage(handle, symbol, 0); return NSAddressOfSymbol(retsym); } else { - last_was_error = 1; + last_error = DLSYM_ERROR; return NULL; } } } -int dlclose(void *handle) +int +dlclose(void *handle) { /* dlclose is not implemented, and never will be for dylibs. * return -1 to signal an error; it's not used by SBCL anyhow */ diff --git a/version.lisp-expr b/version.lisp-expr index 65b491c..0a68216 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -17,4 +17,4 @@ ;;; checkins which aren't released. (And occasionally for internal ;;; versions, especially for internal versions off the main CVS ;;; branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".) -"0.9.2.17" +"0.9.2.18" -- 1.7.10.4