Add missing dependency.
[osl.git] / Makefile
index 2f8f027929a1fb4010c65d3ef5ddfea302700093..0aff6beb99b3f42e4028cad88582457929d346fc 100644 (file)
--- 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,54 @@ 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 ($(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
+%.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,7 +140,7 @@ 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 > $@