summaryrefslogtreecommitdiff
path: root/source4/main.mk
diff options
context:
space:
mode:
authorJames Peach <jpeach@samba.org>2007-01-11 04:32:43 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 14:40:20 -0500
commitfa5560bdcb281c7c21391cccb2f53a4dbf84dd97 (patch)
treea4d14af6ad9a2a657feb0f07b924037755a54155 /source4/main.mk
parente8d2437cd570d8cbfaca7c07305831c29e260450 (diff)
downloadsamba-fa5560bdcb281c7c21391cccb2f53a4dbf84dd97.tar.gz
samba-fa5560bdcb281c7c21391cccb2f53a4dbf84dd97.tar.bz2
samba-fa5560bdcb281c7c21391cccb2f53a4dbf84dd97.zip
r20677: Condense compilations rules.
(This used to be commit 586b5113a09ec5ff751bcdaf4094d5672d58f220)
Diffstat (limited to 'source4/main.mk')
-rw-r--r--source4/main.mk90
1 files changed, 63 insertions, 27 deletions
diff --git a/source4/main.mk b/source4/main.mk
index d685a0a0fc..d7b15bf2c3 100644
--- a/source4/main.mk
+++ b/source4/main.mk
@@ -81,6 +81,9 @@ showflags:
@echo ' SHLD = $(SHLD)'
@echo ' SHLD_FLAGS = $(SHLD_FLAGS)'
@echo ' SHLIBEXT = $(SHLIBEXT)'
+ @echo ' srcdir = $(srcdir)'
+ @echo ' builddir = $(builddir)'
+ @echo ' pwd = '`/bin/pwd`
# The permissions to give the executables
INSTALLPERMS = 0755
@@ -141,7 +144,7 @@ installlib: $(INSTALLABLE_SHARED_LIBS) $(STATIC_LIBS) installdirs
@$(SHELL) $(srcdir)/script/installlib.sh $(DESTDIR)$(LIBDIR) "$(STLIBEXT)" $(STATIC_LIBS)
installheader: headers installdirs
- @$(PERL) $(srcdir)/script/installheader.pl $(DESTDIR)$(INCLUDEDIR) $(PUBLIC_HEADERS) $(DEFAULT_HEADERS)
+ @srcdir=$(srcdir) builddir=$(builddir) $(PERL) $(srcdir)/script/installheader.pl $(DESTDIR)$(INCLUDEDIR) $(PUBLIC_HEADERS) $(DEFAULT_HEADERS)
installdat: installdirs
@$(SHELL) $(srcdir)/script/installdat.sh $(DESTDIR)$(DATADIR) $(srcdir)
@@ -283,47 +286,50 @@ realdistclean: distclean removebackup
test: $(DEFAULT_TEST_TARGET)
+SELFTEST = builddir=$(builddir) srcdir=$(srcdir) \
+ $(srcdir)/script/tests/selftest.sh ${selftest_prefix}
+
test-swrap: all libraries
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} all SOCKET_WRAPPER
+ $(SELFTEST) all SOCKET_WRAPPER
test-noswrap: all libraries
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} all
+ $(SELFTEST) all
quicktest: all
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} quick SOCKET_WRAPPER
+ $(SELFTEST) quick SOCKET_WRAPPER
testenv: all libraries
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} xterm SOCKET_WRAPPER
+ $(SELFTEST) xterm SOCKET_WRAPPER
valgrindtest: valgrindtest-quick
valgrindtest-quick: all
SMBD_VALGRIND="xterm -n smbd -e valgrind -q --db-attach=yes --num-callers=30" \
VALGRIND="valgrind -q --num-callers=30 --log-file=${selftest_prefix}/valgrind.log" \
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} quick SOCKET_WRAPPER
+ $(SELFTEST) quick SOCKET_WRAPPER
valgrindtest-all: all libraries
SMBD_VALGRIND="xterm -n smbd -e valgrind -q --db-attach=yes --num-callers=30" \
VALGRIND="valgrind -q --num-callers=30 --log-file=${selftest_prefix}/valgrind.log" \
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} all SOCKET_WRAPPER
+ $(SELFTEST) all SOCKET_WRAPPER
valgrindtest-env: all libraries
SMBD_VALGRIND="xterm -n smbd -e valgrind -q --db-attach=yes --num-callers=30" \
VALGRIND="valgrind -q --num-callers=30 --log-file=${selftest_prefix}/valgrind.log" \
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} xterm SOCKET_WRAPPER
+ $(SELFTEST) xterm SOCKET_WRAPPER
gdbtest: gdbtest-quick
gdbtest-quick: all
SMBD_VALGRIND="xterm -n smbd -e gdb --args " \
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} quick SOCKET_WRAPPER
+ $(SELFTEST) quick SOCKET_WRAPPER
gdbtest-all: all libraries
SMBD_VALGRIND="xterm -n smbd -e gdb --args " \
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} all SOCKET_WRAPPER
+ $(SELFTEST) all SOCKET_WRAPPER
wintest: all
- $(srcdir)/script/tests/selftest.sh ${selftest_prefix} win
+ $(SELFTEST) win
unused_macros:
$(srcdir)/script/find_unused_macros.pl `find . -name "*.[ch]"` | sort
@@ -334,17 +340,27 @@ unused_macros:
.SUFFIXES: .x .c .et .y .l .d .o .h .h.gch .a .$(SHLIBEXT) .1 .1.xml .3 .3.xml .5 .5.xml .7 .7.xml .8 .8.xml .ho .idl .hd
+# Dependencies command
+DEPENDS = $(CC) -M -MG -MP -MT $(<:.c=.o) -MT $@ \
+ `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $< -o $@
+# Dependencies for host objects
+HDEPENDS = $(CC) -M -MG -MP -MT $(<:.c=.ho) -MT $@ \
+ `$(PERL) $(srcdir)/script/cflags.pl $@` $(HOSTCC_CFLAGS) $< -o $@
+# Dependencies for precompiled headers
+PCHDEPENDS = $(CC) -M -MG -MT include/includes.h.gch -MT $@ \
+ $(CFLAGS) $< -o $@
+
.c.d:
@echo "Generating dependencies for $<"
- @$(CC) -M -MG -MP -MT $(<:.c=.o) -MT $@ `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $< -o $@
+ @$(DEPENDS)
.c.hd:
@echo "Generating host-compiler dependencies for $<"
- @$(CC) -M -MG -MP -MT $(<:.c=.ho) -MT $@ `$(PERL) $(srcdir)/script/cflags.pl $@` $(HOSTCC_CFLAGS) $< -o $@
+ @$(HDEPENDS)
include/includes.d: include/includes.h
@echo "Generating dependencies for $<"
- @$(CC) -M -MG -MT include/includes.h.gch -MT $@ $(CFLAGS) $< -o $@
+ @$(PCHDEPENDS)
#
# $< is broken in older BSD versions:
@@ -352,27 +368,47 @@ include/includes.d: include/includes.h
# if it also exists. So better use $* which is foo/bar
# and append .c manually to get foo/bar.c
#
+
+# Run a static analysis checker
+CHECK = $(CC_CHECKER) `$(PERL) $(srcdir)/script/cflags.pl $@` \
+ $(CFLAGS) $(PICFLAG) -c $*.c -o $@
+
+# Run the configured compiler
+COMPILE = $(CC) `$(PERL) $(srcdir)/script/cflags.pl $@` \
+ $(CFLAGS) $(PICFLAG) -c $*.c -o $@
+
+# Run the compiler for the build host
+HCOMPILE = $(HOSTCC) `$(PERL) $(srcdir)/script/cflags.pl $@` \
+ $(HOSTCC_CFLAGS) -c $*.c -o $@
+
+# Precompile headers
+PCHCOMPILE = @$(CC) -Ilib/replace \
+ `$(PERL) $(srcdir)/script/cflags.pl $@` \
+ $(CFLAGS) $(PICFLAG) -c $*.c -o $@
+
.c.o:
@if test -n "$(CC_CHECKER)"; then \
- echo "Checking $*.c with '$(CC_CHECKER)'"; \
- $(CC_CHECKER) `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $(PICFLAG) -c $*.c -o $@; \
+ echo "Checking $< with '$(CC_CHECKER)'"; \
+ $(CHECK) ; \
fi
- @echo "Compiling $*.c"
- @$(CC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $(PICFLAG) -c $*.c -o $@ && exit 0;\
- echo "The following command failed:" 1>&2;\
- echo "$(CC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $(PICFLAG) -c $*.c -o $@" 1>&2;\
- $(CC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $(PICFLAG) -c $*.c -o $@ >/dev/null 2>&1
+ @echo "Compiling $<"
+ @-mkdir -p `dirname $@`
+ @$(COMPILE) && exit 0 ; \
+ @echo "The following command failed:" 1>&2;\
+ @echo "$(COMPILE)" 1>&2;\
+ @$(COMPILE) >/dev/null 2>&1
.c.ho:
- @echo "Compiling $*.c with host compiler"
- @$(HOSTCC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(HOSTCC_CFLAGS) -c $*.c -o $@ && exit 0;\
- echo "The following command failed:" 1>&2;\
- echo "$(HOSTCC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(HOSTCC_CFLAGS) -c $*.c -o $@" 1>&2;\
- $(HOSTCC) `$(PERL) $(srcdir)/script/cflags.pl $@` $(HOSTCC_CFLAGS) -c $*.c -o $@ >/dev/null 2>&1
+ @echo "Compiling $< with host compiler"
+ @-mkdir -p `dirname $@`
+ @$(HCOMPILE) && exit 0;\
+ @echo "The following command failed:" 1>&2;\
+ @echo "$(HCOMPILE)" 1>&2;\
+ @$(HCOMPILE) >/dev/null 2>&1
.h.h.gch:
@echo "Precompiling $<"
- @$(CC) -Ilib/replace `$(PERL) $(srcdir)/script/cflags.pl $@` $(CFLAGS) $(PICFLAG) -c $< -o $@
+ @$(PCHCOMPILE)
.y.c:
@echo "Building $< with $(YACC)"