Remove unnecessary $O from gengetopt target.
[osl.git] / Makefile
index 0a44111620483a6989690843c43495ae630083b1..3ce4567c36a98edb1ccdd20308d92f3605dffd63 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -2,9 +2,14 @@
 prefix := /usr/local
 libdir := $(prefix)/lib
 includedir := $(prefix)/include
 prefix := /usr/local
 libdir := $(prefix)/lib
 includedir := $(prefix)/include
+bindir := $(prefix)/bin
+mandir := $(prefix)/man/man1
 
 
-objects := osl.o fd.o rbtree.o sha1.o
+objects := osl.o util.o rbtree.o sha1.o
+fsck_objects := fsck.fsck.o osl.fsck.o util.fsck.o rbtree.fsck.o sha1.fsck.o fsck.cmdline.o
 headers := osl.h
 headers := osl.h
+executables := oslfsck
+man_pages := oslfsck.1
 
 INSTALL := install
 CC := gcc
 
 INSTALL := install
 CC := gcc
@@ -17,6 +22,7 @@ LN := ln
 x := 0
 y := 1
 z := 0
 x := 0
 y := 1
 z := 0
+VERSION := $(x).$(y).$(z)
 
 # common flags
 CFLAGS += -Wno-sign-compare -g -Wunused -Wundef -W
 
 # common flags
 CFLAGS += -Wno-sign-compare -g -Wunused -Wundef -W
@@ -30,39 +36,24 @@ CFLAGS += -Werror-implicit-function-declaration
 CFLAGS += -Wmissing-format-attribute
 CFLAGS += -Wunused-macros
 CFLAGS += -Wbad-function-cast
 CFLAGS += -Wmissing-format-attribute
 CFLAGS += -Wunused-macros
 CFLAGS += -Wbad-function-cast
-CFLAGS += -fPIC
-CFLAGS += -fvisibility=hidden
+
+# cflags used only for building library objects
+LIBCFLAGS += -fPIC
+LIBCFLAGS += -fvisibility=hidden
 
 uname_s := $(shell uname -s 2>/dev/null || echo "UNKNOWN_OS")
 uname_rs := $(shell uname -rs)
 
 libname := osl
 
 uname_s := $(shell uname -s 2>/dev/null || echo "UNKNOWN_OS")
 uname_rs := $(shell uname -rs)
 
 libname := osl
-ifeq ($(uname_s),Linux)
-       # On Linux, 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
+ifeq ($(uname_s),Linux)
+       format := elf
        LDFLAGS += -Wl,-soname,$(soname)
        # disallow undefined symbols
        LDFLAGS += -Wl,-z,defs
 endif
 ifeq ($(uname_s),Darwin)
        # Darwin has its own idea on version numbers:
        LDFLAGS += -Wl,-soname,$(soname)
        # disallow undefined symbols
        LDFLAGS += -Wl,-z,defs
 endif
 ifeq ($(uname_s),Darwin)
        # Darwin has its own idea on version numbers:
-       #
        realname := lib$(libname).$(x).dylib
        soname := $(realname)
        linkername := lib$(libname).so
        realname := lib$(libname).$(x).dylib
        soname := $(realname)
        linkername := lib$(libname).so
@@ -78,40 +69,103 @@ ifeq ($(uname_s),Darwin)
        LDFLAGS += -dynamiclib
 endif
 ifeq ($(uname_s),SunOS)
        LDFLAGS += -dynamiclib
 endif
 ifeq ($(uname_s),SunOS)
+       format := elf
        # Solaris needs another set of flags
        # Solaris needs another set of flags
-       LDFLAGS += --shared
        LDFLAGS += -z text
        LDFLAGS += -z defs
        LDFLAGS += -z text
        LDFLAGS += -z defs
-       realname := lib$(libname).so.$(major_version).$(minor_version).$(patchlevel_version)
        CPPFLAGS += -I/opt/csw/include
        CPPFLAGS += -I/opt/csw/include
+       LDFLAGS += -lc
 endif
 
 endif
 
-all: $(realname)
+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) $(executables) $(man_pages)
 Makefile.deps: $(wildcard *.c *.h)
        $(CC) -MM -MG *.c > $@
 Makefile.deps: $(wildcard *.c *.h)
        $(CC) -MM -MG *.c > $@
+osl.c fsck.c:
 
 -include Makefile.deps
 
 
 -include Makefile.deps
 
-%.o: %.c Makefile
-       $(CC) -c $(CPPFLAGS) $(CFLAGS) $<
+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 errtab.h
+       $(CC) -c -DVERSION='"$(VERSION)"' $(CPPFLAGS) $(CFLAGS) $< -o $@
+
+%.o: %.c Makefile errtab.h
+       $(CC) -c $(CPPFLAGS) $(CFLAGS) $(LIBCFLAGS) $<
+
+fsck.cmdline.h fsck.cmdline.c: fsck.ggo Makefile
+       gengetopt \
+               --conf-parser \
+               --unamed-opts=table \
+               --no-handle-version \
+               --file-name=fsck.cmdline \
+               --func-name=fsck_cmdline_parser \
+               --set-package="oslfsck" \
+               --arg-struct-name=fsck_args_info \
+               < $<
+
+oslfsck: $(fsck_objects)
+       $(CC) -o $@ $(fsck_objects) -lcrypto
+
+oslfsck.1: oslfsck
+       help2man -h --detailed-help -N ./$< > $@
 
 $(realname): $(objects)
 
 $(realname): $(objects)
-       $(CC) $(LDFLAGS) -o $@ $(objects) $(LDFLAGS) -lcrypto
+       $(CC) $(LDFLAGS) -o $@ $(objects) -lcrypto
 
 osl_errors.h: errlist
 
 osl_errors.h: errlist
+       echo '/** public error codes of the osl library. */' > $@
        sed -e 's/\([A-Z_]*\)   .*/     E_OSL_\1/' \
        sed -e 's/\([A-Z_]*\)   .*/     E_OSL_\1/' \
-               -e '1s/^/enum osl_errors {\n/1' \
+               -e '1s/^/enum osl_errors {/1' \
+               -e '1s/$$/=1/1' \
                -e '$$!s/$$/,/g' \
                -e '$$!s/$$/,/g' \
-               -e '$$s/$$/\n};/1' $< > $@
+               -e '$$s/$$/};/1' $< >> $@
 
 errtab.h: errlist
 
 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
-       cat $^ > $@
+osl.h: osl.h.in osl_errors.h Makefile
+       echo '#ifndef _OSL_H' > $@
+       echo '#define _OSL_H' >> $@
+       cat osl.h.in osl_errors.h >> $@
+       echo '#endif /* _OSL_H */' >> $@
 clean:
 clean:
-       rm -f *.o $(realname) osl.h osl_errors.h errtab.h
+       rm -f *.o $(realname) osl.h osl_errors.h errtab.h fsck.cmdline.h \
+               fsck.cmdline.c oslfsck
+
+distclean: clean
+       rm -f web/index.html web/oslfsck.1.html web/osl.png
+       rm -rf web/doxygen
 
 install: all
        $(MKDIR) $(libdir) $(includedir)
 
 install: all
        $(MKDIR) $(libdir) $(includedir)
@@ -119,5 +173,22 @@ install: all
        $(LN) -s $(libdir)/$(soname) $(libdir)/$(linkername)
        $(INSTALL) -s -m 755 $(realname) $(libdir)
        $(INSTALL) -m 644 $(headers) $(includedir)
        $(LN) -s $(libdir)/$(soname) $(libdir)/$(linkername)
        $(INSTALL) -s -m 755 $(realname) $(libdir)
        $(INSTALL) -m 644 $(headers) $(includedir)
+       $(INSTALL) -m 755 $(executables) $(bindir)
+       $(INSTALL) -m 644 $(man_pages) $(mandir)
 
 .PHONY: all clean install
 
 .PHONY: all clean install
+
+web/%.1.html: %.1
+       man2html $< > $@
+
+web/osl.png: web/osl.pdf Makefile
+       convert -scale 200x200 $< $@
+
+web/index.html: web/oslfsck.1.html web/index.html.in INSTALL README
+       sed -e '/@README@/,$$d' web/index.html.in > $@
+       grutatxt -nb < README >> $@
+       sed -e '1,/@README@/d' -e '/@INSTALL@/,$$d' web/index.html.in >> $@
+       grutatxt -nb < INSTALL >> $@
+       sed -e '1,/@INSTALL@/d' -e '/@MAN_PAGE@/,$$d' web/index.html.in >> $@
+       sed -e '1,/Return to Main Contents/d' -e '/Index/,$$d' web/oslfsck.1.html >> $@
+       sed -e '1,/@MAN_PAGE@/d' web/index.html.in >> $@