aboutsummaryrefslogtreecommitdiff
path: root/build-jim-ext.in
diff options
context:
space:
mode:
authorSteve Bennett <steveb@workware.net.au>2011-12-10 08:20:32 +1000
committerSteve Bennett <steveb@workware.net.au>2011-12-12 13:44:43 +1000
commitbdc3729473a79b144cbdf49fddeb288b05ccc8f5 (patch)
treeb219fc22b5ec26688c04281f9fda9d9839a67c2e /build-jim-ext.in
parent9798fcccedb779101becaac5313afb80dbbd283d (diff)
downloadjimtcl-bdc3729473a79b144cbdf49fddeb288b05ccc8f5.zip
jimtcl-bdc3729473a79b144cbdf49fddeb288b05ccc8f5.tar.gz
jimtcl-bdc3729473a79b144cbdf49fddeb288b05ccc8f5.tar.bz2
Better dynamic extension building
If libjim is built shared, ensure that all symbols are resolved. This can't be done if libjim is built static. Also, build-jim-ext now shows stderr from the compiler and linker Signed-off-by: Steve Bennett <steveb@workware.net.au>
Diffstat (limited to 'build-jim-ext.in')
-rw-r--r--build-jim-ext.in66
1 files changed, 51 insertions, 15 deletions
diff --git a/build-jim-ext.in b/build-jim-ext.in
index 8eb42fa..9566b83 100644
--- a/build-jim-ext.in
+++ b/build-jim-ext.in
@@ -12,6 +12,16 @@ proc usage {{msg {}}} {
exit 1
}
+proc readfile {filename {default_value ""}} {
+ set result $default_value
+ catch {
+ set f [open $filename]
+ set result [$f read -nonewline]
+ $f close
+ }
+ return $result
+}
+
set linker "@CC@"
set testmod 1
set install 0
@@ -101,11 +111,19 @@ lappend includepaths -I@prefix@/include
set CPPFLAGS "-D_GNU_SOURCE"
-if {"@JIM_STATICLIB@" eq "1" && !$static} {
- puts stderr "Warning: libjim is static. Dynamic module may not work on some platforms.\n"
- set ljim ""
-} else {
- set ljim -ljim
+set ljim ""
+set shobj_cflags ""
+set shobj_ldflags ""
+if {!$static} {
+ set shobj_cflags "@SHOBJ_CFLAGS@"
+ if {"@JIM_STATICLIB@" eq "1"} {
+ puts stderr "Warning: libjim is static. Dynamic module may not work on some platforms.\n"
+ set shobj_ldflags "@SHOBJ_LDFLAGS@"
+ } else {
+ # If shared, link against the shared libjim to resolve symbols
+ set ljim -ljim
+ set shobj_ldflags "@SHOBJ_LDFLAGS_R@"
+ }
}
set objs {}
@@ -116,25 +134,34 @@ foreach source $sources {
} else {
set compiler "@CXX@"
}
- if {$static} {
- set shobj_cflags ""
- } else {
- set shobj_cflags "@SHOBJ_CFLAGS@"
- }
set compile "$compiler @CFLAGS@ $CPPFLAGS $shobj_cflags $includepaths $opts -c -o $obj $source"
puts "Compile: $obj"
lappend objs $obj
+ flush stdout
set rc [catch {
- exec {*}$compile
if {$verbose} {
- puts stderr $compile
+ puts $compile
}
+ exec 2>jimerr.out {*}$compile
} msg]
+
+ set errmsg [readfile jimerr.out]
+ file delete jimerr.out
+
if {$rc} {
- puts stderr $compile
+ if {!$verbose} {
+ puts stderr $compile
+ }
puts stderr $msg
+ if {$errmsg ne ""} {
+ puts stderr $errmsg
+ }
file delete {*}$objs
exit 1
+ } else {
+ if {$errmsg ne ""} {
+ puts $errmsg
+ }
}
}
@@ -165,16 +192,19 @@ if {$static} {
# Add the standard location after any user lib paths
lappend libpaths -L@prefix@/lib
- set link "$linker @CFLAGS@ @LDFLAGS@ @SHOBJ_LDFLAGS@ $libpaths $opts -o $target $objs $ljim @LIBS@ $libs"
+ set link "$linker @CFLAGS@ @LDFLAGS@ $shobj_ldflags $libpaths $opts -o $target $objs $ljim @LIBS@ $libs"
puts "Link: $target"
set rc [catch {
- exec {*}$link
if {$verbose} {
puts stderr $link
}
+ exec 2>jimerr.out {*}$link
} msg]
+ set errmsg [readfile jimerr.out]
+ file delete jimerr.out
+
if {!$keep} {
file delete {*}$objs
}
@@ -183,8 +213,14 @@ if {$static} {
file delete $target
puts stderr $link
puts stderr $msg
+ if {$errmsg ne ""} {
+ puts stderr $errmsg
+ }
exit 1
}
+ if {$errmsg ne ""} {
+ puts $errmsg
+ }
if {$testmod} {
# Now, is testing even possible?