Added support for building with OBJDIR
This commit is contained in:
parent
2193ed5704
commit
d48c55558c
18
Makefile
18
Makefile
|
@ -3,7 +3,8 @@ VERSION = 0.0.0
|
|||
SUBDIRS = include src tools
|
||||
RM = rm -f
|
||||
LN = ln -f
|
||||
TAR = tar -czvf
|
||||
TAR = tar
|
||||
MKDIR = mkdir -m 0755 -p
|
||||
|
||||
|
||||
all: subdirs
|
||||
|
@ -20,7 +21,7 @@ distclean:
|
|||
dist:
|
||||
$(RM) -r -- $(PACKAGE)-$(VERSION)
|
||||
$(LN) -s -- . $(PACKAGE)-$(VERSION)
|
||||
@$(TAR) $(PACKAGE)-$(VERSION).tar.gz -- \
|
||||
@$(TAR) -czvf $(PACKAGE)-$(VERSION).tar.gz -- \
|
||||
$(PACKAGE)-$(VERSION)/include/GToolkit.h \
|
||||
$(PACKAGE)-$(VERSION)/include/Makefile \
|
||||
$(PACKAGE)-$(VERSION)/include/project.conf \
|
||||
|
@ -42,10 +43,21 @@ dist:
|
|||
$(PACKAGE)-$(VERSION)/project.conf
|
||||
$(RM) -- $(PACKAGE)-$(VERSION)
|
||||
|
||||
distcheck: dist
|
||||
$(TAR) -xzvf $(PACKAGE)-$(VERSION).tar.gz
|
||||
$(MKDIR) -- $(PACKAGE)-$(VERSION)/objdir
|
||||
$(MKDIR) -- $(PACKAGE)-$(VERSION)/destdir
|
||||
(cd "$(PACKAGE)-$(VERSION)" && $(MAKE) OBJDIR="$$PWD/objdir/")
|
||||
(cd "$(PACKAGE)-$(VERSION)" && $(MAKE) OBJDIR="$$PWD/objdir/" DESTDIR="$$PWD/destdir" install)
|
||||
(cd "$(PACKAGE)-$(VERSION)" && $(MAKE) OBJDIR="$$PWD/objdir/" DESTDIR="$$PWD/destdir" uninstall)
|
||||
(cd "$(PACKAGE)-$(VERSION)" && $(MAKE) OBJDIR="$$PWD/objdir/" distclean)
|
||||
(cd "$(PACKAGE)-$(VERSION)" && $(MAKE) dist)
|
||||
$(RM) -r -- $(PACKAGE)-$(VERSION)
|
||||
|
||||
install:
|
||||
@for i in $(SUBDIRS); do (cd "$$i" && $(MAKE) install) || exit; done
|
||||
|
||||
uninstall:
|
||||
@for i in $(SUBDIRS); do (cd "$$i" && $(MAKE) uninstall) || exit; done
|
||||
|
||||
.PHONY: all subdirs clean distclean dist install uninstall
|
||||
.PHONY: all subdirs clean distclean dist distcheck install uninstall
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
OBJDIR =
|
||||
PREFIX = /usr/local
|
||||
DESTDIR =
|
||||
RM = rm -f
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
SUBDIRS = GToolkit
|
||||
OBJDIR =
|
||||
PREFIX = /usr/local
|
||||
DESTDIR =
|
||||
RM = rm -f
|
||||
|
|
35
src/Makefile
35
src/Makefile
|
@ -1,4 +1,5 @@
|
|||
TARGETS = libGToolkit.a libGToolkit.so.0.0 libGToolkit.so.0 libGToolkit.so
|
||||
TARGETS = $(OBJDIR)libGToolkit.a $(OBJDIR)libGToolkit.so.0.0 $(OBJDIR)libGToolkit.so.0 $(OBJDIR)libGToolkit.so
|
||||
OBJDIR =
|
||||
PREFIX = /usr/local
|
||||
DESTDIR =
|
||||
LIBDIR = $(PREFIX)/lib
|
||||
|
@ -18,27 +19,27 @@ INSTALL = install
|
|||
|
||||
all: $(TARGETS)
|
||||
|
||||
libGToolkit_OBJS = common.o gwindow.o gtoolkit.o
|
||||
libGToolkit_OBJS = $(OBJDIR)common.o $(OBJDIR)gwindow.o $(OBJDIR)gtoolkit.o
|
||||
libGToolkit_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) $(CFLAGSF) $(CFLAGS)
|
||||
libGToolkit_LDFLAGS = $(LDFLAGSF) $(LDFLAGS) `pkg-config --libs gl`
|
||||
|
||||
libGToolkit.a: $(libGToolkit_OBJS)
|
||||
$(AR) -rc libGToolkit.a $(libGToolkit_OBJS)
|
||||
$(RANLIB) libGToolkit.a
|
||||
$(OBJDIR)libGToolkit.a: $(libGToolkit_OBJS)
|
||||
$(AR) -rc $(OBJDIR)libGToolkit.a $(libGToolkit_OBJS)
|
||||
$(RANLIB) $(OBJDIR)libGToolkit.a
|
||||
|
||||
libGToolkit.so.0.0 libGToolkit.so.0 libGToolkit.so: $(libGToolkit_OBJS)
|
||||
$(CCSHARED) -o libGToolkit.so.0.0 -Wl,-soname,libGToolkit.so.0 $(libGToolkit_OBJS) $(libGToolkit_LDFLAGS)
|
||||
$(LN) -s -- libGToolkit.so.0.0 libGToolkit.so.0
|
||||
$(LN) -s -- libGToolkit.so.0.0 libGToolkit.so
|
||||
$(OBJDIR)libGToolkit.so.0.0 $(OBJDIR)libGToolkit.so.0 $(OBJDIR)libGToolkit.so: $(libGToolkit_OBJS)
|
||||
$(CCSHARED) -o $(OBJDIR)libGToolkit.so.0.0 -Wl,-soname,libGToolkit.so.0 $(libGToolkit_OBJS) $(libGToolkit_LDFLAGS)
|
||||
$(LN) -s -- libGToolkit.so.0.0 $(OBJDIR)libGToolkit.so.0
|
||||
$(LN) -s -- libGToolkit.so.0.0 $(OBJDIR)libGToolkit.so
|
||||
|
||||
common.o: common.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -c common.c
|
||||
$(OBJDIR)common.o: common.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -o $(OBJDIR)common.o -c common.c
|
||||
|
||||
gwindow.o: gwindow.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -c gwindow.c
|
||||
$(OBJDIR)gwindow.o: gwindow.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -o $(OBJDIR)gwindow.o -c gwindow.c
|
||||
|
||||
gtoolkit.o: gtoolkit.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -c gtoolkit.c
|
||||
$(OBJDIR)gtoolkit.o: gtoolkit.c
|
||||
$(CC) $(libGToolkit_CFLAGS) -o $(OBJDIR)gtoolkit.o -c gtoolkit.c
|
||||
|
||||
clean:
|
||||
$(RM) -- $(libGToolkit_OBJS)
|
||||
|
@ -48,8 +49,8 @@ distclean: clean
|
|||
|
||||
install: $(TARGETS)
|
||||
$(MKDIR) $(DESTDIR)$(PREFIX)/lib
|
||||
$(INSTALL) -m 0644 libGToolkit.a $(DESTDIR)$(PREFIX)/lib/libGToolkit.a
|
||||
$(INSTALL) -m 0755 libGToolkit.so.0.0 $(DESTDIR)$(PREFIX)/lib/libGToolkit.so.0.0
|
||||
$(INSTALL) -m 0644 $(OBJDIR)libGToolkit.a $(DESTDIR)$(PREFIX)/lib/libGToolkit.a
|
||||
$(INSTALL) -m 0755 $(OBJDIR)libGToolkit.so.0.0 $(DESTDIR)$(PREFIX)/lib/libGToolkit.so.0.0
|
||||
$(LN) -s -- libGToolkit.so.0.0 $(DESTDIR)$(PREFIX)/lib/libGToolkit.so.0
|
||||
$(LN) -s -- libGToolkit.so.0.0 $(DESTDIR)$(PREFIX)/lib/libGToolkit.so
|
||||
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
TARGETS = test
|
||||
TARGETS = $(OBJDIR)test
|
||||
OBJDIR =
|
||||
PREFIX = /usr/local
|
||||
DESTDIR =
|
||||
BINDIR = $(PREFIX)/bin
|
||||
|
@ -16,15 +17,15 @@ INSTALL = install
|
|||
|
||||
all: $(TARGETS)
|
||||
|
||||
test_OBJS = test.o
|
||||
test_OBJS = $(OBJDIR)test.o
|
||||
test_CFLAGS = $(CPPFLAGSF) $(CPPFLAGS) $(CFLAGSF) $(CFLAGS)
|
||||
test_LDFLAGS = $(LDFLAGSF) $(LDFLAGS) -L../src -L $(PREFIX)/lib -Wl,-rpath,$(PREFIX)/lib -lGToolkit
|
||||
test_LDFLAGS = $(LDFLAGSF) $(LDFLAGS) -L$(OBJDIR). -L../src -L $(PREFIX)/lib -Wl,-rpath,$(PREFIX)/lib -lGToolkit
|
||||
|
||||
test: $(test_OBJS)
|
||||
$(CC) -o test $(test_OBJS) $(test_LDFLAGS)
|
||||
$(OBJDIR)test: $(test_OBJS)
|
||||
$(CC) -o $(OBJDIR)test $(test_OBJS) $(test_LDFLAGS)
|
||||
|
||||
test.o: test.c ../include/GToolkit.h
|
||||
$(CC) $(test_CFLAGS) -c test.c
|
||||
$(OBJDIR)test.o: test.c ../include/GToolkit.h
|
||||
$(CC) $(test_CFLAGS) -o $(OBJDIR)test.o -c test.c
|
||||
|
||||
clean:
|
||||
$(RM) -- $(test_OBJS)
|
||||
|
|
|
@ -7,7 +7,7 @@ dist=Makefile
|
|||
[test]
|
||||
type=binary
|
||||
sources=test.c
|
||||
ldflags=-L../src -L $(PREFIX)/lib -Wl,-rpath,$(PREFIX)/lib -lGToolkit
|
||||
ldflags=-L$(OBJDIR). -L../src -L $(PREFIX)/lib -Wl,-rpath,$(PREFIX)/lib -lGToolkit
|
||||
|
||||
[test.c]
|
||||
depends=../include/GToolkit.h
|
||||
|
|
Loading…
Reference in New Issue
Block a user