[0054948] | 1 | Submitted By: Jim Gifford <jim at cross-lfs dot org>
|
---|
| 2 | Originally Submitted By: Tushar Teredesai <tushar@linuxfromscratch.org>
|
---|
| 3 | Date: 2009-05-7
|
---|
[69cde8d] | 4 | Initial Package Version: 1.2.2
|
---|
| 5 | Origin: Gentoo ebuild?
|
---|
| 6 | Upstream Status: Not submitted
|
---|
| 7 | Description:
|
---|
| 8 | 1. Build shared and static lib in one pass
|
---|
| 9 | 2. Always add -fPIC when building shared lib, don't expect the user to set it.
|
---|
| 10 |
|
---|
| 11 | To build the shared and static library:
|
---|
| 12 | ./configure --prefix=<prefix> --shared &&
|
---|
| 13 | make &&
|
---|
| 14 | make install
|
---|
| 15 | Remove the --shared if you don't want the shared lib.
|
---|
| 16 |
|
---|
[0054948] | 17 | diff -Naur zlib-1.2.3.orig/configure zlib-1.2.3/configure
|
---|
| 18 | --- zlib-1.2.3.orig/configure 2005-07-11 13:11:57.000000000 -0700
|
---|
| 19 | +++ zlib-1.2.3/configure 2009-05-07 12:09:31.000000000 -0700
|
---|
| 20 | @@ -23,7 +23,7 @@
|
---|
| 21 | VER=`sed -n -e '/VERSION "/s/.*"\(.*\)".*/\1/p' < zlib.h`
|
---|
| 22 | VER2=`sed -n -e '/VERSION "/s/.*"\([0-9]*\\.[0-9]*\)\\..*/\1/p' < zlib.h`
|
---|
| 23 | VER1=`sed -n -e '/VERSION "/s/.*"\([0-9]*\)\\..*/\1/p' < zlib.h`
|
---|
| 24 | -AR=${AR-"ar rc"}
|
---|
| 25 | +AR=${AR-"ar"}
|
---|
| 26 | RANLIB=${RANLIB-"ranlib"}
|
---|
| 27 | prefix=${prefix-/usr/local}
|
---|
| 28 | exec_prefix=${exec_prefix-'${prefix}'}
|
---|
[69cde8d] | 29 | @@ -73,7 +73,11 @@
|
---|
| 30 |
|
---|
| 31 | if test "$gcc" -eq 1 && ($cc -c $cflags $test.c) 2>/dev/null; then
|
---|
| 32 | CC="$cc"
|
---|
| 33 | - SFLAGS=${CFLAGS-"-fPIC -O3"}
|
---|
| 34 | + #SFLAGS=${CFLAGS-"-fPIC -O3"}
|
---|
| 35 | + # the above is horribly wrong on a few archs where -fPIC should ALWAYS be
|
---|
| 36 | + # used in the creation of shared libraries. without the following, the
|
---|
| 37 | + # shared lib test will sometimes fail even when shared libs -can- be created.
|
---|
| 38 | + SFLAGS="${CFLAGS-"-O3"} -fPIC"
|
---|
| 39 | CFLAGS="$cflags"
|
---|
| 40 | case `(uname -s || echo unknown) 2>/dev/null` in
|
---|
| 41 | Linux | linux | GNU | GNU/*) LDSHARED=${LDSHARED-"$cc -shared -Wl,-soname,libz.so.1"};;
|
---|
[0054948] | 42 | @@ -174,7 +178,7 @@
|
---|
[69cde8d] | 43 | if test "`($CC -c $SFLAGS $test.c) 2>&1`" = "" &&
|
---|
| 44 | test "`($LDSHARED -o $test$shared_ext $test.o) 2>&1`" = ""; then
|
---|
| 45 | CFLAGS="$SFLAGS"
|
---|
| 46 | - LIBS="$SHAREDLIBV"
|
---|
| 47 | + LIBS="$LIBS $SHAREDLIBV"
|
---|
| 48 | echo Building shared library $SHAREDLIBV with $CC.
|
---|
| 49 | elif test -z "$old_cc" -a -z "$old_cflags"; then
|
---|
| 50 | echo No shared library support.
|
---|
[0054948] | 51 | diff -Naur zlib-1.2.3.orig/Makefile.in zlib-1.2.3/Makefile.in
|
---|
| 52 | --- zlib-1.2.3.orig/Makefile.in 2005-07-17 19:25:21.000000000 -0700
|
---|
| 53 | +++ zlib-1.2.3/Makefile.in 2009-05-07 12:10:15.000000000 -0700
|
---|
[69cde8d] | 54 | @@ -49,6 +49,8 @@
|
---|
| 55 | OBJS = adler32.o compress.o crc32.o gzio.o uncompr.o deflate.o trees.o \
|
---|
| 56 | zutil.o inflate.o infback.o inftrees.o inffast.o
|
---|
| 57 |
|
---|
| 58 | +PIC_OBJS = $(OBJS:%.o=%.lo)
|
---|
| 59 | +
|
---|
| 60 | OBJA =
|
---|
| 61 | # to use the asm code: make OBJA=match.o
|
---|
| 62 |
|
---|
[0054948] | 63 | @@ -68,7 +70,7 @@
|
---|
| 64 | fi
|
---|
| 65 |
|
---|
| 66 | libz.a: $(OBJS) $(OBJA)
|
---|
| 67 | - $(AR) $@ $(OBJS) $(OBJA)
|
---|
| 68 | + $(AR) rc $@ $(OBJS) $(OBJA)
|
---|
| 69 | -@ ($(RANLIB) $@ || true) >/dev/null 2>&1
|
---|
| 70 |
|
---|
| 71 | match.o: match.S
|
---|
[69cde8d] | 72 | @@ -77,8 +79,11 @@
|
---|
| 73 | mv _match.o match.o
|
---|
| 74 | rm -f _match.s
|
---|
| 75 |
|
---|
| 76 | -$(SHAREDLIBV): $(OBJS)
|
---|
| 77 | - $(LDSHARED) -o $@ $(OBJS)
|
---|
| 78 | +%.lo: %.c
|
---|
| 79 | + $(CC) $(CFLAGS) -DPIC -fPIC -c $< -o $@
|
---|
| 80 | +
|
---|
| 81 | +$(SHAREDLIBV): $(PIC_OBJS)
|
---|
| 82 | + $(LDSHARED) -o $@ $(PIC_OBJS) -lc
|
---|
| 83 | rm -f $(SHAREDLIB) $(SHAREDLIBM)
|
---|
| 84 | ln -s $@ $(SHAREDLIB)
|
---|
| 85 | ln -s $@ $(SHAREDLIBM)
|
---|
| 86 | @@ -89,13 +94,10 @@
|
---|
| 87 | minigzip$(EXE): minigzip.o $(LIBS)
|
---|
| 88 | $(CC) $(CFLAGS) -o $@ minigzip.o $(LDFLAGS)
|
---|
| 89 |
|
---|
| 90 | -install: $(LIBS)
|
---|
| 91 | +install-libs: $(LIBS)
|
---|
| 92 | -@if [ ! -d $(exec_prefix) ]; then mkdir -p $(exec_prefix); fi
|
---|
| 93 | - -@if [ ! -d $(includedir) ]; then mkdir -p $(includedir); fi
|
---|
| 94 | -@if [ ! -d $(libdir) ]; then mkdir -p $(libdir); fi
|
---|
| 95 | -@if [ ! -d $(man3dir) ]; then mkdir -p $(man3dir); fi
|
---|
| 96 | - cp zlib.h zconf.h $(includedir)
|
---|
| 97 | - chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h
|
---|
| 98 | cp $(LIBS) $(libdir)
|
---|
| 99 | cd $(libdir); chmod 755 $(LIBS)
|
---|
| 100 | -@(cd $(libdir); $(RANLIB) libz.a || true) >/dev/null 2>&1
|
---|
| 101 | @@ -110,6 +112,11 @@
|
---|
| 102 | # The ranlib in install is needed on NeXTSTEP which checks file times
|
---|
| 103 | # ldconfig is for Linux
|
---|
| 104 |
|
---|
| 105 | +install: install-libs
|
---|
| 106 | + -@if [ ! -d $(includedir) ]; then mkdir $(includedir); fi
|
---|
| 107 | + cp zlib.h zconf.h $(includedir)
|
---|
| 108 | + chmod 644 $(includedir)/zlib.h $(includedir)/zconf.h
|
---|
| 109 | +
|
---|
| 110 | uninstall:
|
---|
| 111 | cd $(includedir); \
|
---|
| 112 | cd $(libdir); rm -f libz.a; \
|
---|