--- a/bzip2.c +++ b/bzip2.c @@ -54,7 +54,7 @@ #include #include #include -#include "bzlib.h" +#include #define ERROR_IF_EOF(i) { if ((i) == EOF) ioError(); } #define ERROR_IF_NOT_ZERO(i) { if ((i) != 0) ioError(); } --- a/bzlib_private.h +++ b/bzlib_private.h @@ -30,7 +30,7 @@ #include #endif -#include "bzlib.h" +#include --- a/Makefile +++ b/Makefile @@ -21,11 +21,38 @@ LDFLAGS= BIGFILES=-D_FILE_OFFSET_BITS=64 -CFLAGS=-Wall -Winline -O2 -g $(BIGFILES) +CFLAGS_COMMON=-Wall -Winline -O2 -g $(BIGFILES) -I. +CFLAGS_NOPIC=$(filter-out -O%,$(CFLAGS)) $(CFLAGS_COMMON) +CFLAGS_PIC=$(filter-out -O%,$(CFLAGS)) -fpic -fPIC $(CFLAGS_COMMON) # Where you want it installed when you do 'make install' -PREFIX=/usr/local - +PREFIX?=/usr/local +ENABLE_BIN_STATIC?=1 +ENABLE_BIN_SHARED?=1 +ENABLE_LIB_STATIC?=1 +ENABLE_LIB_SHARED?=1 +ENABLE_DEV?=1 +ENABLE_DOCS?=1 +ENABLE_TESTS?=1 + +ifeq ($(ENABLE_BIN_STATIC),1) + ENABLE_BIN=1 + ifneq ($(ENABLE_LIB_STATIC),1) + ENABLE_LIB_STATIC=1 + endif +endif +ifeq ($(ENABLE_BIN_SHARED),1) + ENABLE_BIN=1 + ifneq ($(ENABLE_LIB_SHARED),1) + ENABLE_LIB_STATIC=1 + endif +endif +ifeq ($(ENABLE_LIB_STATIC),1) + ENABLE_LIB=1 +endif +ifeq ($(ENABLE_LIB_SHARED),1) + ENABLE_LIB=1 +endif OBJS= blocksort.o \ huffman.o \ @@ -35,15 +62,38 @@ decompress.o \ bzlib.o -all: libbz2.a bzip2 bzip2recover test - -bzip2: libbz2.a bzip2.o - $(CC) $(CFLAGS) $(LDFLAGS) -o bzip2 bzip2.o -L. -lbz2 +TGTS_all:= +TGTS_bzip2:=bzip2.o +TGTS_check:= +TGTS_install:= +ifeq ($(ENABLE_LIB),1) + TGTS_all+=libbz2 + TGTS_bzip2+=libbz2 +endif +ifeq ($(ENABLE_BIN),1) + TGTS_all+=bzip2 bzip2recover + TGTS_install+=bzip2 bzip2recover +endif +ifeq ($(ENABLE_TESTS),1) + TGTS_all+=test + TGTS_check+=test +endif + +all: $(TGTS_all) + +bzip2: $(TGTS_bzip2) +ifeq ($(ENABLE_BIN_STATIC),1) + $(CC) $(CFLAGS_NOPIC) $(LDFLAGS) -o bzip2 bzip2.o -L. -lbz2 +endif +ifeq ($(ENABLE_BIN_SHARED),1) + $(CC) $(CFLAGS_PIC) -o bzip2-shared bzip2.o libbz2.so.1.0 +endif bzip2recover: bzip2recover.o - $(CC) $(CFLAGS) $(LDFLAGS) -o bzip2recover bzip2recover.o + $(CC) $(CFLAGS_NOPIC) $(LDFLAGS) -o bzip2recover bzip2recover.o -libbz2.a: $(OBJS) +libbz2: $(OBJS) +ifeq ($(ENABLE_LIB_STATIC),1) rm -f libbz2.a $(AR) cq libbz2.a $(OBJS) @if ( test -f $(RANLIB) -o -f /usr/bin/ranlib -o \ @@ -51,8 +101,18 @@ echo $(RANLIB) libbz2.a ; \ $(RANLIB) libbz2.a ; \ fi +endif +ifeq ($(ENABLE_LIB_SHARED),1) + $(CC) -shared -Wl,-soname -Wl,libbz2.so.1.0 $(LDFLAGS) -o libbz2.so.1.0.8 $(OBJS) + rm -f libbz2.so.1.0 + rm -f libbz2.so.1 + rm -f libbz2.so + ln -s libbz2.so.1.0.8 libbz2.so.1.0 + ln -s libbz2.so.1.0 libbz2.so.1 + ln -s libbz2.so.1 libbz2.so +endif -check: test +check: $(TGTS_check) test: bzip2 @cat words1 ./bzip2 -1 < sample1.ref > sample1.rb2 @@ -69,69 +129,153 @@ cmp sample3.tst sample3.ref @cat words3 -install: bzip2 bzip2recover +install: $(TGTS_install) +ifeq ($(ENABLE_BIN),1) if ( test ! -d $(PREFIX)/bin ) ; then mkdir -p $(PREFIX)/bin ; fi +endif +ifeq ($(ENABLE_LIB),1) if ( test ! -d $(PREFIX)/lib ) ; then mkdir -p $(PREFIX)/lib ; fi +endif +ifeq ($(ENABLE_DEV),1) + if ( test ! -d $(PREFIX)/include ) ; then mkdir -p $(PREFIX)/include ; fi +endif +ifeq ($(ENABLE_DOCS),1) if ( test ! -d $(PREFIX)/man ) ; then mkdir -p $(PREFIX)/man ; fi if ( test ! -d $(PREFIX)/man/man1 ) ; then mkdir -p $(PREFIX)/man/man1 ; fi - if ( test ! -d $(PREFIX)/include ) ; then mkdir -p $(PREFIX)/include ; fi +endif +ifeq ($(ENABLE_BIN),1) + ifeq ($(ENABLE_BIN_STATIC),1) cp -f bzip2 $(PREFIX)/bin/bzip2 - cp -f bzip2 $(PREFIX)/bin/bunzip2 - cp -f bzip2 $(PREFIX)/bin/bzcat + chmod a+rx $(PREFIX)/bin/bzip2 + endif + ifeq ($(ENABLE_BIN_SHARED),1) + ifeq ($(ENABLE_BIN_STATIC),1) + cp -f bzip2-shared $(PREFIX)/bin/bzip2-shared + chmod a+rx $(PREFIX)/bin/bzip2-shared + else + cp -f bzip2-shared $(PREFIX)/bin/bzip2 + endif + endif + rm -f $(PREFIX)/bin/bunzip2 + rm -f $(PREFIX)/bin/bzcat + ( cd $(PREFIX)/bin && ln -s bzip2 bunzip2 ) + ( cd $(PREFIX)/bin && ln -s bzip2 bzcat ) + rm -f $(PREFIX)/bin/bunzip2-shared + rm -f $(PREFIX)/bin/bzcat-shared + ifeq ($(ENABLE_BIN_SHARED),1) + ifeq ($(ENABLE_BIN_STATIC),1) + ( cd $(PREFIX)/bin && ln -s bzip2-shared bunzip2-shared ) + ( cd $(PREFIX)/bin && ln -s bzip2-shared bzcat-shared ) + endif + endif cp -f bzip2recover $(PREFIX)/bin/bzip2recover - chmod a+x $(PREFIX)/bin/bzip2 - chmod a+x $(PREFIX)/bin/bunzip2 - chmod a+x $(PREFIX)/bin/bzcat - chmod a+x $(PREFIX)/bin/bzip2recover - cp -f bzip2.1 $(PREFIX)/man/man1 - chmod a+r $(PREFIX)/man/man1/bzip2.1 - cp -f bzlib.h $(PREFIX)/include - chmod a+r $(PREFIX)/include/bzlib.h - cp -f libbz2.a $(PREFIX)/lib - chmod a+r $(PREFIX)/lib/libbz2.a + chmod a+rx $(PREFIX)/bin/bzip2recover cp -f bzgrep $(PREFIX)/bin/bzgrep - ln -s -f $(PREFIX)/bin/bzgrep $(PREFIX)/bin/bzegrep - ln -s -f $(PREFIX)/bin/bzgrep $(PREFIX)/bin/bzfgrep - chmod a+x $(PREFIX)/bin/bzgrep + chmod a+rx $(PREFIX)/bin/bzgrep + rm -f $(PREFIX)/bin/bzegrep + rm -f $(PREFIX)/bin/bzfgrep + ( cd $(PREFIX)/bin && ln -s bzgrep bzegrep ) + ( cd $(PREFIX)/bin && ln -s bzgrep bzfgrep ) cp -f bzmore $(PREFIX)/bin/bzmore - ln -s -f $(PREFIX)/bin/bzmore $(PREFIX)/bin/bzless - chmod a+x $(PREFIX)/bin/bzmore + chmod a+rx $(PREFIX)/bin/bzmore + rm -f $(PREFIX)/bin/bzless + ( cd $(PREFIX)/bin && ln -s bzmore bzless ) + rm -f $(PREFIX)/bin/bzcmp cp -f bzdiff $(PREFIX)/bin/bzdiff - ln -s -f $(PREFIX)/bin/bzdiff $(PREFIX)/bin/bzcmp - chmod a+x $(PREFIX)/bin/bzdiff - cp -f bzgrep.1 bzmore.1 bzdiff.1 $(PREFIX)/man/man1 - chmod a+r $(PREFIX)/man/man1/bzgrep.1 - chmod a+r $(PREFIX)/man/man1/bzmore.1 - chmod a+r $(PREFIX)/man/man1/bzdiff.1 + chmod a+rx $(PREFIX)/bin/bzdiff + ( cd $(PREFIX)/bin && ln -s bzdiff bzcmp ) +endif +ifeq ($(ENABLE_DEV),1) + cp -f bzlib.h $(PREFIX)/include + chmod a+r $(PREFIX)/include/bzlib.h +endif +ifeq ($(ENABLE_DOCS),1) + cp -f bzip2.1 bzgrep.1 bzmore.1 bzdiff.1 $(PREFIX)/man/man1 echo ".so man1/bzgrep.1" > $(PREFIX)/man/man1/bzegrep.1 echo ".so man1/bzgrep.1" > $(PREFIX)/man/man1/bzfgrep.1 echo ".so man1/bzmore.1" > $(PREFIX)/man/man1/bzless.1 echo ".so man1/bzdiff.1" > $(PREFIX)/man/man1/bzcmp.1 + chmod a+r $(PREFIX)/man/man1/bzip2.1 + chmod a+r $(PREFIX)/man/man1/bzgrep.1 + chmod a+r $(PREFIX)/man/man1/bzmore.1 + chmod a+r $(PREFIX)/man/man1/bzdiff.1 + chmod a+r $(PREFIX)/man/man1/bzegrep.1 + chmod a+r $(PREFIX)/man/man1/bzfgrep.1 + chmod a+r $(PREFIX)/man/man1/bzless.1 + chmod a+r $(PREFIX)/man/man1/bzcmp.1 +endif +ifeq ($(ENABLE_LIB_SHARED),1) + cp -f libbz2.so.1.0.8 $(PREFIX)/lib + chmod a+r $(PREFIX)/lib/libbz2.so.1.0.8 + rm -f $(PREFIX)/lib/libbz2.so.1.0 + rm -f $(PREFIX)/lib/libbz2.so.1 + rm -f $(PREFIX)/lib/libbz2.so + ( cd $(PREFIX)/lib && ln -s libbz2.so.1.0.8 libbz2.so.1.0 ) + ( cd $(PREFIX)/lib && ln -s libbz2.so.1.0 libbz2.so.1 ) + ( cd $(PREFIX)/lib && ln -s libbz2.so.1 libbz2.so ) +endif +ifeq ($(ENABLE_LIB_STATIC),1) + cp -f libbz2.a $(PREFIX)/lib + chmod a+r $(PREFIX)/lib/libbz2.a +endif + +uninstall: + rm -f $(PREFIX)/bin/bzip2 + rm -f $(PREFIX)/bin/bzip2-shared + rm -f $(PREFIX)/bin/bunzip2 + rm -f $(PREFIX)/bin/bzcat + rm -f $(PREFIX)/bin/bunzip2-shared + rm -f $(PREFIX)/bin/bzcat-shared + rm -f $(PREFIX)/bin/bzip2recover + rm -f $(PREFIX)/bin/bzgrep + rm -f $(PREFIX)/bin/bzegrep + rm -f $(PREFIX)/bin/bzfgrep + rm -f $(PREFIX)/bin/bzmore + rm -f $(PREFIX)/bin/bzless + rm -f $(PREFIX)/bin/bzdiff + rm -f $(PREFIX)/bin/bzcmp + rm -f $(PREFIX)/include/bzlib.h + rm -f $(PREFIX)/lib/libbz2.so.1.0.8 + rm -f $(PREFIX)/lib/libbz2.so.1.0 + rm -f $(PREFIX)/lib/libbz2.so.1 + rm -f $(PREFIX)/lib/libbz2.so + rm -f $(PREFIX)/lib/libbz2.a + rm -f $(PREFIX)/man/man1/bzip2.1 + rm -f $(PREFIX)/man/man1/bzgrep.1 + rm -f $(PREFIX)/man/man1/bzmore.1 + rm -f $(PREFIX)/man/man1/bzdiff.1 + rm -f $(PREFIX)/man/man1/bzegrep.1 + rm -f $(PREFIX)/man/man1/bzfgrep.1 + rm -f $(PREFIX)/man/man1/bzless.1 + rm -f $(PREFIX)/man/man1/bzcmp.1 + (rmdir $(PREFIX)/bin $(PREFIX)/include $(PREFIX)/lib $(PREFIX)/man/man1 $(PREFIX)/man || true ) 2> /dev/null clean: - rm -f *.o libbz2.a bzip2 bzip2recover \ + rm -f $(OBJS) bzip2.o \ + libbz2.so.1.0.8 libbz2.so.1.0 libbz2.so.1 libbz2.so \ + libbz2.a bzip2 bzip2-shared bzip2recover \ sample1.rb2 sample2.rb2 sample3.rb2 \ sample1.tst sample2.tst sample3.tst blocksort.o: blocksort.c @cat words0 - $(CC) $(CFLAGS) -c blocksort.c + $(CC) $(CFLAGS_NOPIC) -c blocksort.c huffman.o: huffman.c - $(CC) $(CFLAGS) -c huffman.c + $(CC) $(CFLAGS_NOPIC) -c huffman.c crctable.o: crctable.c - $(CC) $(CFLAGS) -c crctable.c + $(CC) $(CFLAGS_NOPIC) -c crctable.c randtable.o: randtable.c - $(CC) $(CFLAGS) -c randtable.c + $(CC) $(CFLAGS_NOPIC) -c randtable.c compress.o: compress.c - $(CC) $(CFLAGS) -c compress.c + $(CC) $(CFLAGS_NOPIC) -c compress.c decompress.o: decompress.c - $(CC) $(CFLAGS) -c decompress.c + $(CC) $(CFLAGS_NOPIC) -c decompress.c bzlib.o: bzlib.c - $(CC) $(CFLAGS) -c bzlib.c + $(CC) $(CFLAGS_NOPIC) -c bzlib.c bzip2.o: bzip2.c - $(CC) $(CFLAGS) -c bzip2.c + $(CC) $(CFLAGS_NOPIC) -c bzip2.c bzip2recover.o: bzip2recover.c - $(CC) $(CFLAGS) -c bzip2recover.c + $(CC) $(CFLAGS_NOPIC) -c bzip2recover.c distclean: clean @@ -189,7 +333,6 @@ $(DISTNAME)/bzmore.1 \ $(DISTNAME)/bzgrep \ $(DISTNAME)/bzgrep.1 \ - $(DISTNAME)/Makefile-libbz2_so \ $(DISTNAME)/bz-common.xsl \ $(DISTNAME)/bz-fo.xsl \ $(DISTNAME)/bz-html.xsl \ --- a/Makefile-libbz2_so +++ b/Makefile-libbz2_so @@ -1,59 +0,0 @@ - -# This Makefile builds a shared version of the library, -# libbz2.so.1.0.8, with soname libbz2.so.1.0, -# at least on x86-Linux (RedHat 7.2), -# with gcc-2.96 20000731 (Red Hat Linux 7.1 2.96-98). -# Please see the README file for some important info -# about building the library like this. - -# ------------------------------------------------------------------ -# This file is part of bzip2/libbzip2, a program and library for -# lossless, block-sorting data compression. -# -# bzip2/libbzip2 version 1.0.8 of 13 July 2019 -# Copyright (C) 1996-2019 Julian Seward -# -# Please read the WARNING, DISCLAIMER and PATENTS sections in the -# README file. -# -# This program is released under the terms of the license contained -# in the file LICENSE. -# ------------------------------------------------------------------ - - -SHELL=/bin/sh -CC=gcc -BIGFILES=-D_FILE_OFFSET_BITS=64 -CFLAGS=-fpic -fPIC -Wall -Winline -O2 -g $(BIGFILES) - -OBJS= blocksort.o \ - huffman.o \ - crctable.o \ - randtable.o \ - compress.o \ - decompress.o \ - bzlib.o - -all: $(OBJS) - $(CC) -shared -Wl,-soname -Wl,libbz2.so.1.0 -o libbz2.so.1.0.8 $(OBJS) - $(CC) $(CFLAGS) -o bzip2-shared bzip2.c libbz2.so.1.0.8 - rm -f libbz2.so.1.0 - ln -s libbz2.so.1.0.8 libbz2.so.1.0 - -clean: - rm -f $(OBJS) bzip2.o libbz2.so.1.0.8 libbz2.so.1.0 bzip2-shared - -blocksort.o: blocksort.c - $(CC) $(CFLAGS) -c blocksort.c -huffman.o: huffman.c - $(CC) $(CFLAGS) -c huffman.c -crctable.o: crctable.c - $(CC) $(CFLAGS) -c crctable.c -randtable.o: randtable.c - $(CC) $(CFLAGS) -c randtable.c -compress.o: compress.c - $(CC) $(CFLAGS) -c compress.c -decompress.o: decompress.c - $(CC) $(CFLAGS) -c decompress.c -bzlib.o: bzlib.c - $(CC) $(CFLAGS) -c bzlib.c --- a/unzcrash.c +++ b/unzcrash.c @@ -30,7 +30,7 @@ #include #include -#include "bzlib.h" +#include #define M_BLOCK 1000000