X-Git-Url: http://git.tuebingen.mpg.de/?p=osl.git;a=blobdiff_plain;f=Makefile;h=1f125c6886fb3757b193b7ca1fb0be6026f83b91;hp=c741cb97ea457e10076e2b0c84d77b4f2c745d50;hb=3448f4caccded0a60aa5f81976cd8c285908e7bb;hpb=c36dc2cd252559a03b44d7f8d6ed6565ded2edc5 diff --git a/Makefile b/Makefile index c741cb9..1f125c6 100644 --- a/Makefile +++ b/Makefile @@ -1,9 +1,9 @@ # where to install -prefix := /usr/local -libdir := $(prefix)/lib -includedir := $(prefix)/include -bindir := $(prefix)/bin -mandir := $(prefix)/man/man1 +PREFIX ?= /usr/local +libdir := $(PREFIX)/lib +includedir := $(PREFIX)/include +bindir := $(PREFIX)/bin +mandir := $(PREFIX)/man/man1 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 @@ -12,7 +12,9 @@ executables := oslfsck man_pages := oslfsck.1 INSTALL := install -CC := gcc +ifeq "$(origin CC)" "default" + CC := gcc +endif MKDIR := mkdir -p RM := rm -f LN := ln @@ -56,7 +58,7 @@ ifeq ($(uname_s),Darwin) # Darwin has its own idea on version numbers: realname := lib$(libname).$(x).dylib soname := $(realname) - linkername := lib$(libname).so + linkername := lib$(libname).dylib # The minor version number is an incremental number using the format # X[.Y[.Z]]. To set the minor version number of a dynamic library, use # the gcc -current_version option. @@ -107,7 +109,6 @@ ifeq ($(format),elf) LDFLAGS += --shared endif - all: $(realname) $(executables) $(man_pages) Makefile.deps: $(wildcard *.c *.h) $(CC) -MM -MG *.c > $@ @@ -125,7 +126,7 @@ fsck.cmdline.o: fsck.cmdline.c fsck.cmdline.h $(CC) -c $(CPPFLAGS) $(CFLAGS) $(LIBCFLAGS) $< fsck.cmdline.h fsck.cmdline.c: fsck.ggo Makefile - gengetopt $$O \ + gengetopt \ --conf-parser \ --unamed-opts=table \ --no-handle-version \ @@ -141,7 +142,6 @@ oslfsck: $(fsck_objects) oslfsck.1: oslfsck help2man -h --detailed-help -N ./$< > $@ - $(realname): $(objects) $(CC) $(LDFLAGS) -o $@ $(objects) -lcrypto @@ -165,13 +165,32 @@ clean: 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) + $(MKDIR) $(libdir) $(includedir) $(mandir) $(bindir) $(RM) $(libdir)/$(linkername) $(LN) -s $(libdir)/$(soname) $(libdir)/$(linkername) - $(INSTALL) -s -m 755 $(realname) $(libdir) + $(INSTALL) -m 755 $(realname) $(libdir) $(INSTALL) -m 644 $(headers) $(includedir) - $(INSTALL) -m 644 $(executables) $(bindir) + $(INSTALL) -m 755 $(executables) $(bindir) $(INSTALL) -m 644 $(man_pages) $(mandir) .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 >> $@