X-Git-Url: http://git.tuebingen.mpg.de/?p=osl.git;a=blobdiff_plain;f=Makefile;h=0674495fe2ad81c70686682a69796aaf809e26c3;hp=a65ba2d9a4d3cc0147198e86f845455a925a7957;hb=2dba3a38dcfe721842404f01e9b2adb59c302604;hpb=f0af855a393748664497a5503d0011e09daeffbc diff --git a/Makefile b/Makefile index a65ba2d..0674495 100644 --- a/Makefile +++ b/Makefile @@ -42,25 +42,8 @@ uname_rs := $(shell uname -rs) libname := osl -# On ELf-based systems, the following conventions apply (see dhweeler's Program -# Library HOWTO): -# -# The soname has the prefix ``lib'', the name of the library, the -# phrase ``.so'', followed by a period and a version number that is -# incremented whenever the interface changes. -soname := lib$(libname).so.$(x) - -# The real name adds to the soname a period, a minor number, another -# period, and the release number. -realname := $(soname).$(y).$(z) - -# In addition, there's the name that the compiler uses when requesting -# a library, (I'll call it the ``linker name''), which is simply the -# soname without any version number. -linkername := lib$(libname).so - ifeq ($(uname_s),Linux) - LDFLAGS += --shared + format := elf LDFLAGS += -Wl,-soname,$(soname) # disallow undefined symbols LDFLAGS += -Wl,-z,defs @@ -82,28 +65,59 @@ ifeq ($(uname_s),Darwin) LDFLAGS += -dynamiclib endif ifeq ($(uname_s),SunOS) + format := elf # Solaris needs another set of flags - LDFLAGS += --shared LDFLAGS += -z text LDFLAGS += -z defs CPPFLAGS += -I/opt/csw/include LDFLAGS += -lc endif +ifeq ($(uname_s),NetBSD) + format := elf + LDFLAGS += -Wl,-soname,$(soname) +endif + +ifeq ($(uname_s),FreeBSD) + format := elf + LDFLAGS += -Wl,-soname,$(soname) +endif + +ifeq ($(format),elf) + # On ELf-based systems, the following conventions apply (see dhweeler's + # Program Library HOWTO): + # + # The soname has the prefix ``lib'', the name of the library, the + # phrase ``.so'', followed by a period and a version number that is + # incremented whenever the interface changes. + soname := lib$(libname).so.$(x) + + # The real name adds to the soname a period, a minor number, another + # period, and the release number. + realname := $(soname).$(y).$(z) + + # In addition, there's the name that the compiler uses when requesting + # a library, (I'll call it the ``linker name''), which is simply the + # soname without any version number. + linkername := lib$(libname).so + LDFLAGS += --shared +endif + + all: $(realname) oslfsck Makefile.deps: $(wildcard *.c *.h) $(CC) -MM -MG *.c > $@ -osl.c fsck.c: errtab.h +osl.c fsck.c: -include Makefile.deps fsck.cmdline.o: fsck.cmdline.c fsck.cmdline.h $(CC) -c -DVERSION='"$(VERSION)"' $< -%.fsck.o: %.c Makefile fsck.cmdline.c fsck.cmdline.h osl.h +%.fsck.o: %.c Makefile fsck.cmdline.c fsck.cmdline.h osl.h errtab.h $(CC) -c -DVERSION='"$(VERSION)"' $(CPPFLAGS) $(CFLAGS) $< -o $@ -%.o: %.c Makefile +%.o: %.c Makefile errtab.h $(CC) -c $(CPPFLAGS) $(CFLAGS) $(LIBCFLAGS) $< fsck.cmdline.h fsck.cmdline.c: fsck.ggo Makefile @@ -131,12 +145,16 @@ osl_errors.h: errlist -e '$$s/$$/};/1' $< > $@ errtab.h: errlist - sed -e 's/^\([A-Z_]*\)\s*\(.*\)/_S(E_OSL_\1, \2)/g' $< > $@ + sed -e 's/^\([A-Z_]*\)\s*\(.*\)/OSL_ERROR(E_OSL_\1, \2)/g' $< > $@ osl.h: osl.h.in osl_errors.h Makefile - cat osl.h.in osl_errors.h > $@ + echo '#ifndef _OSL_H' > $@ + echo '#define _OSL_H' >> $@ + cat osl.h.in osl_errors.h >> $@ + echo '#endif /* _OSL_H */' >> $@ clean: - rm -f *.o $(realname) osl.h osl_errors.h errtab.h fsck.cmdline.h fsck.cmdline.c + rm -f *.o $(realname) osl.h osl_errors.h errtab.h fsck.cmdline.h \ + fsck.cmdline.c oslfsck install: all $(MKDIR) $(libdir) $(includedir)