From b6e0f0180b99d321bc92c85f6c64f2334b4aa799 Mon Sep 17 00:00:00 2001
From: Joe Groff <arcata@gmail.com>
Date: Mon, 12 Sep 2011 12:27:34 -0700
Subject: [PATCH] alien.libraries, compiler.cfg.builder.alien: include the
 result of dlerror/GetLastError in the linkage-error for missing symbols

---
 basis/alien/libraries/libraries.factor        |  9 +++++++++
 basis/alien/libraries/unix/unix.factor        |  5 +++++
 basis/alien/libraries/windows/windows.factor  |  5 +++++
 basis/compiler/cfg/builder/alien/alien.factor |  4 ++--
 basis/compiler/errors/errors.factor           | 12 ++++++------
 5 files changed, 27 insertions(+), 8 deletions(-)
 create mode 100644 basis/alien/libraries/unix/unix.factor
 create mode 100644 basis/alien/libraries/windows/windows.factor

diff --git a/basis/alien/libraries/libraries.factor b/basis/alien/libraries/libraries.factor
index 37ac47307d..e24105651a 100755
--- a/basis/alien/libraries/libraries.factor
+++ b/basis/alien/libraries/libraries.factor
@@ -5,12 +5,21 @@ kernel namespaces destructors sequences strings
 system io.pathnames fry ;
 IN: alien.libraries
 
+ERROR: unknown-dlsym-platform ;
+<< {
+    { [ os windows? ] [ "alien.libraries.windows" ] }
+    { [ os unix? ] [ "alien.libraries.unix" ] }
+    [ unknown-dlsym-platform ]
+} cond use-vocab >>
+
 : dlopen ( path -- dll ) native-string>alien (dlopen) ;
 
 : dlsym ( name dll -- alien ) [ string>symbol ] dip (dlsym) ;
 
 : dlsym-raw ( name dll -- alien ) [ string>symbol ] dip (dlsym-raw) ;
 
+: dlerror ( -- message/f ) (dlerror) ;
+
 SYMBOL: libraries
 
 libraries [ H{ } clone ] initialize
diff --git a/basis/alien/libraries/unix/unix.factor b/basis/alien/libraries/unix/unix.factor
new file mode 100644
index 0000000000..8db779d013
--- /dev/null
+++ b/basis/alien/libraries/unix/unix.factor
@@ -0,0 +1,5 @@
+USING: alien.c-types alien.syntax io.encodings.utf8 ;
+IN: alien.libraries.unix
+
+FUNCTION-ALIAS: (dlerror)
+    c-string[utf8] dlerror ( ) ;
diff --git a/basis/alien/libraries/windows/windows.factor b/basis/alien/libraries/windows/windows.factor
new file mode 100644
index 0000000000..9a595c8a09
--- /dev/null
+++ b/basis/alien/libraries/windows/windows.factor
@@ -0,0 +1,5 @@
+USING: windows.errors ;
+IN: alien.libraries.windows
+
+: (dlerror) ( -- message )
+    win32-error-string ;
diff --git a/basis/compiler/cfg/builder/alien/alien.factor b/basis/compiler/cfg/builder/alien/alien.factor
index d0a4d19723..114d1deb3e 100644
--- a/basis/compiler/cfg/builder/alien/alien.factor
+++ b/basis/compiler/cfg/builder/alien/alien.factor
@@ -70,8 +70,8 @@ M: array dlsym-valid? '[ _ dlsym ] any? ;
 : check-dlsym ( symbols dll -- )
     dup dll-valid? [
         dupd dlsym-valid?
-        [ drop ] [ cfg get word>> no-such-symbol ] if
-    ] [ dll-path cfg get word>> no-such-library drop ] if ;
+        [ drop ] [ dlerror cfg get word>> no-such-symbol ] if
+    ] [ dll-path "" cfg get word>> no-such-library drop ] if ;
 
 : decorated-symbol ( params -- symbols )
     [ function>> ] [ parameters>> [ stack-size ] map-sum number>string ] bi
diff --git a/basis/compiler/errors/errors.factor b/basis/compiler/errors/errors.factor
index 3881439fc0..3c00c5173e 100644
--- a/basis/compiler/errors/errors.factor
+++ b/basis/compiler/errors/errors.factor
@@ -44,7 +44,7 @@ T{ error-type
 : <linkage-error> ( error word -- linkage-error )
     \ linkage-error <definition-error> ;
 
-: linkage-error ( error word class -- )
+: linkage-error ( name message word class -- )
     '[ _ boa ] dip <linkage-error> dup asset>> linkage-errors get set-at ; inline
 
 T{ error-type
@@ -57,16 +57,16 @@ T{ error-type
    { fatal? f }
 } define-error-type
 
-TUPLE: no-such-library name ;
+TUPLE: no-such-library name message ;
 
 M: no-such-library summary drop "Library not found" ;
 
-: no-such-library ( name word -- ) \ no-such-library linkage-error ;
+: no-such-library ( name message word -- ) \ no-such-library linkage-error ;
 
-TUPLE: no-such-symbol name ;
+TUPLE: no-such-symbol name message ;
 
 M: no-such-symbol summary drop "Symbol not found" ;
 
-: no-such-symbol ( name word -- ) \ no-such-symbol linkage-error ;
+: no-such-symbol ( name message word -- ) \ no-such-symbol linkage-error ;
 
-ERROR: not-compiled word error ;
\ No newline at end of file
+ERROR: not-compiled word error ;