aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog22
-rw-r--r--Makefile.in243
2 files changed, 130 insertions, 135 deletions
diff --git a/ChangeLog b/ChangeLog
index ea52f50..5a9c9c3 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,27 @@
Tue Feb 9 12:42:27 1993 Ian Lance Taylor (ian@cygnus.com)
+ * Makefile.in: Various changes to eliminate a level of make
+ recursion and reduce the required command line length.
+ (BASE_FLAGS_TO_PASS): New variable holding flags passed to all
+ sub-makes.
+ (EXTRA_HOST_FLAGS, EXTRA_TARGET_FLAGS, EXTRA_GCC_FLAGS): New
+ variables holding settings for specific sub-makes.
+ (FLAGS_TO_PASS, TARGET_FLAGS_TO_PASS, GCC_FLAGS_TO_PASS): Rewrote
+ in terms of BASE_FLAGS_TO_PASS.
+ (TARGET_LIBS): New variable listing directories which use
+ TARGET_FLAGS_TO_PASS.
+ (subdir_do): Eliminated.
+ (do-*): New set of targets to replace subdir_do.
+ (various): All targets which used subdir_do now depend on do-*.
+ (local-clean): Renamed from do_clean.
+ (local-distclean): New target, dependency of distclean and
+ realclean.
+ (install-info): Don't create directories. Depend on dir.info
+ rather than calling make recursively.
+ (install-dir.info): Eliminated.
+ (install-info-dirs): Create all info directories here.
+ (dir.info): Depend upon do-install-info.
+
* test-build.mk (HOLES): Added false.
Sat Feb 6 14:05:09 1993 Per Bothner (bothner@rtl.cygnus.com)
diff --git a/Makefile.in b/Makefile.in
index 6fd4396..d8c903a 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -184,6 +184,7 @@ NM_FOR_TARGET = ` \
fi \
fi`
+# FIXME: This is badly named.
XTRAFLAGS = ` \
if [ -f $${rootme}/gcc/Makefile ] ; then \
if [ -f $${rootme}/newlib/Makefile ] ; then \
@@ -199,22 +200,24 @@ XTRAFLAGS = ` \
#### host and target specific makefile fragments come in here.
###
-# Flags to pass down to sub-makes -- please keep these in alphabetical order
-FLAGS_TO_PASS = \
- "AR=$(AR)" \
+# Flags to pass down to all sub-makes.
+# Please keep these in alphabetical order.
+BASE_FLAGS_TO_PASS = \
"AR_FLAGS=$(AR_FLAGS)" \
"AR_FOR_TARGET=$(AR_FOR_TARGET)" \
+ "AS_FOR_TARGET=$(AS_FOR_TARGET)" \
"BISON=$(BISON)" \
- "CXXFLAGS=$(CXXFLAGS)" \
- "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
- "CC=$(CC)" \
"CC_FOR_BUILD=$(CC_FOR_BUILD)" \
+ "CC_FOR_TARGET=$(CC_FOR_TARGET)" \
"CFLAGS=$(CFLAGS)" \
$(start-sanitize-chill)\
"CHILLFLAGS=$(CHILLFLAGS)" \
"CHILL_FOR_TARGET=$(CHILL_FOR_TARGET)" \
"CHILL_LIB=$(CHILL_LIB)" \
$(end-sanitize-chill)\
+ "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
+ "CXXFLAGS=$(CXXFLAGS)" \
+ "CXX_FOR_TARGET=$(CXX_FOR_TARGET)" \
"GCC_FOR_TARGET=$(GCC_FOR_TARGET)" \
"INSTALL=$(INSTALL)" \
"INSTALL_DATA=$(INSTALL_DATA)" \
@@ -223,104 +226,121 @@ $(end-sanitize-chill)\
"LEX=$(LEX)" \
"LOADLIBES=$(LOADLIBES)" \
"MAKEINFO=$(MAKEINFO)" \
- "RANLIB=$(RANLIB)" \
+ "NM_FOR_TARGET=$(NM_FOR_TARGET)" \
"RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \
+ "XTRAFLAGS_FOR_TARGET=$(XTRAFLAGS)" \
"exec_prefix=$(exec_prefix)" \
"prefix=$(prefix)" \
"tooldir=$(tooldir)"
+# Flags to pass down to most sub-makes, in which we're building with
+# the host environment.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_HOST_FLAGS = \
+ "AR=$(AR)" \
+ "AS=$(AS)" \
+ "CC=$(CC)" \
+ "CXX=$(CXX)" \
+ "NM=$(NM)" \
+ "RANLIB=$(RANLIB)" \
+ "XTRAFLAGS="
+
+FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_HOST_FLAGS)
+
# Flags that are concerned with the location of the X11 include files
# and library files
-
X11_FLAGS_TO_PASS = \
"X11_INCLUDE_FLAGS=$(X11_INCLUDE_FLAGS)" \
"X11_LIB_FLAGS=$(X11_LIB_FLAGS)" \
"X11_LIB=$(X11_LIB)"
-# Flags to pass down to makes which are built with the target
-# environment (e.g. libg++, xiberty, newlib). -- keep these in alpha order please
-TARGET_FLAGS_TO_PASS = \
- "AR=$(AR_FOR_TARGET)" \
- "AR_FLAGS=$(AR_FLAGS)" \
- "AS=$(AS_FOR_TARGET)" \
- "BISON=$(BISON)" \
- "CXX=$(CXX_FOR_TARGET)" \
- "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
- "CXXFLAGS=$(CXXFLAGS)" \
- "CC=$(CC_FOR_TARGET)" \
- "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
- "CFLAGS=$(CFLAGS)" \
- "INSTALL=$(INSTALL)" \
- "INSTALL_DATA=$(INSTALL_DATA)" \
- "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
- "LDFLAGS=$(LDFLAGS)" \
- "LEX=$(LEX)" \
- "LOADLIBES=$(LOADLIBES)" \
- "MAKEINFO=$(MAKEINFO)" \
- "NM=$(NM_FOR_TARGET)" \
- "RANLIB=$(RANLIB_FOR_TARGET)" \
- "XTRAFLAGS=$(XTRAFLAGS)" \
- "exec_prefix=$(exec_prefix)" \
- "prefix=$(prefix)" \
- "tooldir=$(tooldir)"
+# Shell case of subdirectories which are built with the target environment.
+TARGET_LIBS=libg++ | xiberty | newlib
+$(start-sanitize-chill)
+TARGET_LIBS=libg++ | xiberty | newlib | chillrt
+$(end-sanitize-chill)
+
+# Flags to pass down to makes which are built with the target environment.
+# The double $ decreases the length of the command line; the variables
+# are set in BASE_FLAGS_TO_PASS, and the sub-make will expand them.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_TARGET_FLAGS = \
+ 'AR=$$(AR_FOR_TARGET)' \
+ 'AS=$$(AS_FOR_TARGET)' \
+ 'CC=$$(CC_FOR_TARGET)' \
+ 'CXX=$$(CXX_FOR_TARGET)' \
+ 'NM=$$(NM_FOR_TARGET)' \
+ 'RANLIB=$$(RANLIB_FOR_TARGET)' \
+ 'XTRAFLAGS=$$(XTRAFLAGS_FOR_TARGET)'
+
+TARGET_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_TARGET_FLAGS)
# Flags to pass down to gcc. gcc builds a library, libgcc.a, so it
# unfortunately needs the native compiler and the target ar and
-# ranlib. Keep these in alphabetical order, please.
-GCC_FLAGS_TO_PASS = \
- "AR=$(AR_FOR_TARGET)" \
- "AR_FLAGS=$(AR_FLAGS)" \
- "AR_FOR_TARGET=$(AR_FOR_TARGET)" \
+# ranlib.
+# Because of the way do-info, et. al., use this, this must not contain
+# any backquotes.
+EXTRA_GCC_FLAGS = \
+ 'AR=$$(AR_FOR_TARGET)' \
"AS=$(AS)" \
- "BISON=$(BISON)" \
- "CXX=$(CXX)" \
- "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \
- "CXXFLAGS=$(CXXFLAGS)" \
"CC=$(CC)" \
- "CC_FOR_BUILD=$(CC_FOR_BUILD)" \
- "CFLAGS=$(CFLAGS)" \
- "INSTALL=$(INSTALL)" \
- "INSTALL_DATA=$(INSTALL_DATA)" \
- "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \
- "LDFLAGS=$(LDFLAGS)" \
- "LEX=$(LEX)" \
- "LOADLIBES=$(LOADLIBES)" \
- "MAKEINFO=$(MAKEINFO)" \
+ "CXX=$(CXX)" \
"NM=$(NM)" \
- "RANLIB=$(RANLIB_FOR_TARGET)" \
- "RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \
- "XTRAFLAGS=$(XTRAFLAGS)" \
- "exec_prefix=$(exec_prefix)" \
- "prefix=$(prefix)" \
- "tooldir=$(tooldir)"
+ 'RANLIB=$$(RANLIB_FOR_TARGET)' \
+ "XTRAFLAGS="
+
+GCC_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_GCC_FLAGS)
# The first rule in the file had better be this one. Don't put any above it.
all: $(ALL)
-.PHONY: all check dvi info install-info
+.PHONY: all check dvi info install-info install-info-dirs
+.PHONY: do-info do-check do-dvi do-install-info
+.PHONY: do-clean do-mostlyclean do-distclean do-realclean
.NOEXPORT:
-info: all-texinfo
- @rootme=`pwd` ; export rootme ; \
- $(MAKE) $(FLAGS_TO_PASS) DO=info "DODIRS=$(SUBDIRS)" subdir_do
-
-check dvi:
- @rootme=`pwd` ; export rootme ; \
- $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
+# Do a target for all the subdirectories. A ``make do-X'' will do a
+# ``make X'' in all subdirectories (because, in general, X depends on
+# fdo-X, a ``make X'' will also do this, but it may do additional work
+# as well).
+# This target ensures that $(BASE_FLAGS_TO_PASS) appears only once,
+# because it is so large that it can easily overflow the command line
+# length limit on some systems.
+do-info do-check do-dvi do-install-info do-clean do-mostlyclean do-distclean do-realclean:
+ @target=`echo $@ | sed -e 's/^do-//'`; \
+ rootme=`pwd`; export rootme; \
+ srcroot=`cd $(srcdir); pwd`; export srcroot; \
+ for i in $(SUBDIRS); do \
+ if [ -f ./$$i/localenv ] || [ -f ./$$i/Makefile ]; then \
+ case $$i in \
+ $(TARGET_LIBS) ) \
+ extra_flags=`echo $(EXTRA_TARGET_FLAGS)`; \
+ ;; \
+ gcc) \
+ extra_flags=`echo $(EXTRA_GCC_FLAGS)`; \
+ ;; \
+ *) \
+ extra_flags=`echo $(EXTRA_HOST_FLAGS)`; \
+ ;; \
+ esac ; \
+ export extra_flags; \
+ if (cd ./$$i; \
+ $(MAKE) $(BASE_FLAGS_TO_PASS) $${extra_flags} $${target}); \
+ then true; else exit 1; fi; \
+ else true; fi; \
+ done
-install-info: install-info-dirs force
- -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
- if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
- -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
- @rootme='pwd' ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) DO=install-info "DODIRS=$(SUBDIRS)" subdir_do
- @rootme='pwd' ; export rootme ; $(MAKE) $(FLAGS_TO_PASS) dir.info install-dir.info
+info: do-info
+check: do-check
+dvi: do-dvi
-install-dir.info:
- -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
- if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
- -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
+install-info: install-info-dirs do-install-info dir.info
$(INSTALL_DATA) dir.info $(infodir)/dir.info
+do-install-info: install-info-dirs
+
all.normal: all-m4 all-autoconf all-libiberty all-mmalloc all-texinfo \
all-byacc all-flex all-opcodes all-bfd all-ld all-gas all-tgas \
all-gcc all-binutils all-libg++ all-readline all-sim all-gdb \
@@ -344,20 +364,19 @@ all.cross: all-libiberty all-mmalloc all-gas all-byacc all-flex all-ld \
$(end-sanitize-chill) \
all-deja-gnu
-.PHONY: clean distclean mostlyclean realclean do_clean
+.PHONY: clean distclean mostlyclean realclean local-clean local-distclean
-do_clean:
+local-clean:
-rm -f *.a TEMP errs core *.o *~ \#* TAGS *.E
-clean mostlyclean: do_clean
- @rootme=`pwd` ; export rootme ; \
- $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
-
-distclean realclean: do_clean
- @rootme=`pwd` ; export rootme ; \
- $(MAKE) $(FLAGS_TO_PASS) DO=$@ "DODIRS=$(SUBDIRS)" subdir_do
+local-distclean:
-rm -f Makefile config.status
+clean: do-clean local-clean
+mostlyclean: do-mostlyclean local-clean
+distclean: do-distclean local-clean local-distclean
+realclean: do-realclean local-clean local-distclean
+
uninstall:
@echo "the uninstall target is not supported in this tree"
@@ -1329,55 +1348,6 @@ install-textutils: force
### other supporting targets
-subdir_do:
-### start-sanitize-chill
-###
-### WARNING: THIS IS VERY UGLY AND I DID NOT DO THIS WILLINGLY
-###
-### if you change the code for libg++ et al, also change the
-### code for chillrt
-###
-### end-sanitize-chill
- @for i in $(DODIRS); do \
- if [ -f ./$$i/localenv ] || [ -f ./$$i/Makefile ] ; then \
- case $$i in \
- libg++ | xiberty | newlib) \
- if (rootme=`pwd` ; export rootme ; \
- srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
- cd ./$$i ; \
- $(MAKE) $(TARGET_FLAGS_TO_PASS) $(DO)) ; then true ; \
- else exit 1 ; fi \
- ;; \
- $(start-sanitize-chill) \
- chillrt) \
- if (rootme=`pwd` ; export rootme ; \
- srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
- cd ./$$i ; \
- $(MAKE) $(TARGET_FLAGS_TO_PASS) $(DO)) ; then true ; \
- else exit 1 ; fi \
- ;; \
- $(end-sanitize-chill) \
- gcc) \
- if (rootme=`pwd` ; export rootme ; \
- srcroot=`cd $(srcdir); pwd` ; export srcroot ; \
- cd ./$$i ; \
- $(MAKE) $(GCC_FLAGS_TO_PASS) $(DO)) ; then true ; \
- else exit 1 ; fi \
- ;; \
- *) \
- if (rootme=`pwd` ; export rootme ; \
- cd ./$$i ; \
- $(MAKE) $(FLAGS_TO_PASS) $(DO)) ; then true ; \
- else exit 1 ; fi \
- ;; \
- esac ; \
- else true ; fi ; \
- done
-
-# The "else true" stuff is for Ultrix; the shell returns the exit code
-# of the "if" command, if no commands are run in the "then" or "else" part,
-# causing Make to quit.
-
MAKEDIRS= \
$(prefix) \
$(exec_prefix) \
@@ -1417,8 +1387,11 @@ install-dirs:
install-info-dirs:
if [ -d $(prefix) ] ; then true ; else mkdir $(prefix) ; fi
+ -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \
+ if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+ -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi
-dir.info:
+dir.info: do-install-info
$(srcdir)/texinfo/gen-info-dir $(infodir) $(srcdir)/texinfo/dir.info-template > dir.info.new
mv -f dir.info.new dir.info