Arrange Makefile
Let the user specify his own C and LD FLAGS. Remove unuseful and non portable CFLAGS like pendantic and Wall.
This commit is contained in:
parent
db7922f173
commit
c870098b82
63
Makefile
63
Makefile
|
@ -1,61 +1,66 @@
|
||||||
# surf - simple browser
|
# surf - simple browser
|
||||||
# See LICENSE file for copyright and license details.
|
# See LICENSE file for copyright and license details.
|
||||||
|
.POSIX:
|
||||||
|
|
||||||
include config.mk
|
include config.mk
|
||||||
|
|
||||||
SRC = surf.c
|
SRC = surf.c
|
||||||
OBJ = ${SRC:.c=.o}
|
OBJ = $(SRC:.c=.o)
|
||||||
|
|
||||||
all: options surf
|
all: options surf
|
||||||
|
|
||||||
options:
|
options:
|
||||||
@echo surf build options:
|
@echo surf build options:
|
||||||
@echo "CFLAGS = ${CFLAGS}"
|
@echo "CFLAGS = $(SURF_CFLAGS)"
|
||||||
@echo "LDFLAGS = ${LDFLAGS}"
|
@echo "LDFLAGS = $(SURF_LDFLAGS)"
|
||||||
@echo "CC = ${CC}"
|
@echo "CC = $(CC)"
|
||||||
|
|
||||||
.c.o:
|
.c.o:
|
||||||
@echo CC $<
|
@echo CC -c $<
|
||||||
@${CC} -c ${CFLAGS} $<
|
@$(CC) $(SURF_CFLAGS) -c $<
|
||||||
|
|
||||||
${OBJ}: config.h config.mk
|
$(OBJ): config.h config.mk
|
||||||
|
|
||||||
config.h:
|
config.h:
|
||||||
@echo creating $@ from config.def.h
|
@echo creating $@ from config.def.h
|
||||||
@cp config.def.h $@
|
@cp config.def.h $@
|
||||||
|
|
||||||
surf: ${OBJ}
|
surf: $(OBJ)
|
||||||
@echo CC -o $@
|
@echo CC -o $@
|
||||||
@${CC} -o $@ surf.o ${LDFLAGS}
|
@$(CC) $(SURF_CFLAGS) -o $@ $(OBJ) $(SURF_LDFLAGS)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
@echo cleaning
|
@echo cleaning
|
||||||
@rm -f surf ${OBJ} surf-${VERSION}.tar.gz
|
@rm -f surf $(OBJ)
|
||||||
|
|
||||||
dist: clean
|
distclean: clean
|
||||||
|
@echo cleaning dist
|
||||||
|
@rm -f config.h surf-$(VERSION).tar.gz
|
||||||
|
|
||||||
|
dist: distclean
|
||||||
@echo creating dist tarball
|
@echo creating dist tarball
|
||||||
@mkdir -p surf-${VERSION}
|
@mkdir -p surf-$(VERSION)
|
||||||
@cp -R LICENSE Makefile config.mk config.def.h README \
|
@cp -R LICENSE Makefile config.mk config.def.h README \
|
||||||
surf-open.sh arg.h TODO.md surf.png \
|
surf-open.sh arg.h TODO.md surf.png \
|
||||||
surf.1 ${SRC} surf-${VERSION}
|
surf.1 $(SRC) surf-$(VERSION)
|
||||||
@tar -cf surf-${VERSION}.tar surf-${VERSION}
|
@tar -cf surf-$(VERSION).tar surf-$(VERSION)
|
||||||
@gzip surf-${VERSION}.tar
|
@gzip surf-$(VERSION).tar
|
||||||
@rm -rf surf-${VERSION}
|
@rm -rf surf-$(VERSION)
|
||||||
|
|
||||||
install: all
|
install: all
|
||||||
@echo installing executable file to ${DESTDIR}${PREFIX}/bin
|
@echo installing executable file to $(DESTDIR)$(PREFIX)/bin
|
||||||
@mkdir -p ${DESTDIR}${PREFIX}/bin
|
@mkdir -p $(DESTDIR)$(PREFIX)/bin
|
||||||
@cp -f surf ${DESTDIR}${PREFIX}/bin
|
@cp -f surf $(DESTDIR)$(PREFIX)/bin
|
||||||
@chmod 755 ${DESTDIR}${PREFIX}/bin/surf
|
@chmod 755 $(DESTDIR)$(PREFIX)/bin/surf
|
||||||
@echo installing manual page to ${DESTDIR}${MANPREFIX}/man1
|
@echo installing manual page to $(DESTDIR)$(MANPREFIX)/man1
|
||||||
@mkdir -p ${DESTDIR}${MANPREFIX}/man1
|
@mkdir -p $(DESTDIR)$(MANPREFIX)/man1
|
||||||
@sed "s/VERSION/${VERSION}/g" < surf.1 > ${DESTDIR}${MANPREFIX}/man1/surf.1
|
@sed "s/VERSION/$(VERSION)/g" < surf.1 > $(DESTDIR)$(MANPREFIX)/man1/surf.1
|
||||||
@chmod 644 ${DESTDIR}${MANPREFIX}/man1/surf.1
|
@chmod 644 $(DESTDIR)$(MANPREFIX)/man1/surf.1
|
||||||
|
|
||||||
uninstall:
|
uninstall:
|
||||||
@echo removing executable file from ${DESTDIR}${PREFIX}/bin
|
@echo removing executable file from $(DESTDIR)$(PREFIX)/bin
|
||||||
@rm -f ${DESTDIR}${PREFIX}/bin/surf
|
@rm -f $(DESTDIR)$(PREFIX)/bin/surf
|
||||||
@echo removing manual page from ${DESTDIR}${MANPREFIX}/man1
|
@echo removing manual page from $(DESTDIR)$(MANPREFIX)/man1
|
||||||
@rm -f ${DESTDIR}${MANPREFIX}/man1/surf.1
|
@rm -f $(DESTDIR)$(MANPREFIX)/man1/surf.1
|
||||||
|
|
||||||
.PHONY: all options clean dist install uninstall
|
.PHONY: all options clean dist install uninstall
|
||||||
|
|
18
config.mk
18
config.mk
|
@ -5,8 +5,8 @@ VERSION = 2.0
|
||||||
|
|
||||||
# paths
|
# paths
|
||||||
PREFIX = /usr/local
|
PREFIX = /usr/local
|
||||||
MANPREFIX = ${PREFIX}/share/man
|
MANPREFIX = $(PREFIX)/share/man
|
||||||
LIBPREFIX = ${PREFIX}/lib/surf
|
LIBPREFIX = $(PREFIX)/lib/surf
|
||||||
|
|
||||||
X11INC = /usr/X11R6/include
|
X11INC = /usr/X11R6/include
|
||||||
X11LIB = /usr/X11R6/lib
|
X11LIB = /usr/X11R6/lib
|
||||||
|
@ -15,17 +15,17 @@ GTKINC = `pkg-config --cflags gtk+-3.0 webkit2gtk-4.0`
|
||||||
GTKLIB = `pkg-config --libs gtk+-3.0 webkit2gtk-4.0`
|
GTKLIB = `pkg-config --libs gtk+-3.0 webkit2gtk-4.0`
|
||||||
|
|
||||||
# includes and libs
|
# includes and libs
|
||||||
INCS = -I. -I/usr/include -I${X11INC} ${GTKINC}
|
INCS = -I$(X11INC) $(GTKINC)
|
||||||
LIBS = -L/usr/lib -lc -L${X11LIB} -lX11 ${GTKLIB} -lgthread-2.0
|
LIBS = -L$(X11LIB) -lX11 $(GTKLIB) -lgthread-2.0
|
||||||
|
|
||||||
# flags
|
# flags
|
||||||
CPPFLAGS = -DVERSION=\"${VERSION}\" -DWEBEXTDIR=\"${LIBPREFIX}\" -D_DEFAULT_SOURCE
|
CPPFLAGS = -DVERSION=\"${VERSION}\" -DWEBEXTDIR=\"${LIBPREFIX}\" -D_DEFAULT_SOURCE
|
||||||
CFLAGS = -std=c99 -pedantic -Wall -Os ${INCS} ${CPPFLAGS}
|
SURF_CFLAGS = $(INCS) $(CPPFLAGS) $(CFLAGS)
|
||||||
LDFLAGS = -s ${LIBS}
|
SURF_LDFLAGS = $(LIBS) $(LDFLAGS)
|
||||||
|
|
||||||
# Solaris
|
# Solaris
|
||||||
#CFLAGS = -fast ${INCS} -DVERSION=\"${VERSION}\"
|
#CFLAGS = -fast $(INCS) -DVERSION=\"$(VERSION)\"
|
||||||
#LDFLAGS = ${LIBS}
|
#LDFLAGS = $(LIBS)
|
||||||
|
|
||||||
# compiler and linker
|
# compiler and linker
|
||||||
CC = cc
|
#CC = c99
|
||||||
|
|
Loading…
Reference in New Issue