about summary refs log tree commit diff
path: root/zshconfig.ac
diff options
context:
space:
mode:
authorBart Schaefer <barts@users.sourceforge.net>2001-09-13 18:47:02 +0000
committerBart Schaefer <barts@users.sourceforge.net>2001-09-13 18:47:02 +0000
commit2c8fa27f6f3fc1ffc63ca98193f8713d0fe17da7 (patch)
treee953697b24001ba70be4710618fa896e19817265 /zshconfig.ac
parentfc89b8135a73fe02ea72b3b4ded24367be50109b (diff)
downloadzsh-2c8fa27f6f3fc1ffc63ca98193f8713d0fe17da7.tar.gz
zsh-2c8fa27f6f3fc1ffc63ca98193f8713d0fe17da7.tar.xz
zsh-2c8fa27f6f3fc1ffc63ca98193f8713d0fe17da7.zip
David Lebel: Shared object linkage on OpenBSD.
Diffstat (limited to 'zshconfig.ac')
-rw-r--r--zshconfig.ac29
1 files changed, 27 insertions, 2 deletions
diff --git a/zshconfig.ac b/zshconfig.ac
index 92afdb1ca..c01421c41 100644
--- a/zshconfig.ac
+++ b/zshconfig.ac
@@ -1612,7 +1612,14 @@ char *argv[];
   else
     case "$host" in
       *openbsd*)
-	DLLD="${DLLD=$CC}"
+	case "$host_os" in
+	  openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
+	    DLLD="${DLLD=ld}"
+	  ;;
+	  *)
+	    DLLD="${DLLD=$CC}"
+	  ;;
+	esac
 	DLLDARG="${LDARG}"
       ;;
       * )
@@ -1638,11 +1645,29 @@ char *argv[];
     netbsd*)      DLLDFLAGS="${DLLDFLAGS=${DLLDARG}-x -shared --whole-archive}" ;;
     aix*)         DLLDFLAGS="${DLLDFLAGS=-G -bexpall -lc}" ;;
     solaris*|sysv4*|esix*) DLLDFLAGS="${DLLDFLAGS=-G}" ;;
-    openbsd*)     DLLDFLAGS="${DLLDFLAGS=-shared -fPIC}" ;;
+    openbsd*)
+      if test $zsh_cv_sys_elf = yes; then
+	DLLDFLAGS="${DLLDFLAGS=-shared -fPIC}"
+      else
+	case "$host_os" in
+	  openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
+	   DLLDFLAGS="${DLLDFLAGS=-Bshareable}"
+	  ;;
+	  *)
+	    DLLDFLAGS="${DLLDFLAGS=-shared -fPIC}"
+	  ;;
+	esac
+      fi
+    ;;
   esac
   case "$host" in
     *-hpux*)  EXTRA_LDFLAGS="${EXTRA_LDFLAGS=-Wl,-E}" ;;
     *-freebsd[3-9]*|*-linux*) EXTRA_LDFLAGS="${EXTRA_LDFLAGS=-rdynamic}" ;;
+    *openbsd*)
+       if test $zsh_cv_sys_elf = yes; then
+	 EXTRA_LDFLAGS="${EXTRA_LDFLAGS=-Wl,-E}"
+       fi
+    ;;
     mips-sni-sysv4)
       #
       # unfortunately, we have different compilers