(gas-dg-test): Detect invalid values of `do_what'.
[deliverable/binutils-gdb.git] / binutils / Makefile.in
index 297044a95bb20ff2d010523b3b0b1d432b7030e6..d3ec002866b759ff9fac58ed783cbafca8dc121b 100644 (file)
@@ -46,7 +46,7 @@ SHELL = /bin/sh
 
 INSTALL = `cd $(srcdir)/..;pwd`/install.sh -c
 INSTALL_PROGRAM = $(INSTALL)
-INSTALL_DATA = $(INSTALL)
+INSTALL_DATA = $(INSTALL) 
 INSTALL_XFORM = $(INSTALL) -t='$(program_transform_name)'
 INSTALL_XFORM1 = $(INSTALL_XFORM) -b=.1
 
@@ -59,18 +59,18 @@ RANLIB = ranlib
 BISONFLAGS = -d
 TEXI2ROFF=texi2roff
 MAKEOVERRIDES=
-
+CC_FOR_BUILD = $(CC)
 NM_FOR_TARGET = nm
 NM = $(NM_FOR_TARGET)
 SYMLINK = ln -s
 
-BISON = `if [ -f ../byacc/byacc ] ; then echo ../byacc/byacc ; else echo byacc ; fi`
+BISON = `if [ -f ../bison/bison ] ; then echo ../bison/bison -y -L../bison/bison ; else echo bison -y ; fi`
 # Comment these out if using lex.
 LEX_OPTIONS = -I -Cem 
 LEX = `if [ -f ../flex/flex ] ; then echo ../flex/flex ; else echo flex ; fi`
 
 # Distribution version
-VERSION=cygnus-2.3.1
+VERSION=cygnus-2.5
 # Distribution name
 DIST_NAME=binutils-${VERSION}
 
@@ -79,33 +79,40 @@ version=`./../gcc/gcc -dumpversion`
 # Where to find texinfo.tex to format docn with TeX
 TEXIDIR = $(srcdir)/../texinfo
 
-MANPAGES= ar nm objdump ranlib size strings strip c++filt objcopy nlmconv
-
 #CC=gcc -Wall
+CC=cc
 # these two are almost the same program
 AR_PROG=ar
 RANLIB_PROG=ranlib
 
 # objcopy and strip should be the same program
 OBJCOPY_PROG=objcopy
-STRIP_PROG=strip
+STRIP_PROG=strip.new
 
 STRINGS_PROG=strings
 
 # These should all be the same program too.
 SIZE_PROG=size
-NM_PROG=nm
+NM_PROG=nm.new
 OBJDUMP_PROG=objdump
 
 # This is the demangler, as a standalone program.
+# Note: This one is used as the installed name too, unlike the above.
 DEMANGLER_PROG=c++filt
 
 NLMCONV_PROG=nlmconv
 
-PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRINGS_PROG) $(STRIP_PROG) $(RANLIB_PROG) $(DEMANGLER_PROG) $(OBJCOPY_PROG) $(BUILD_NLMCONV)
+SRCONV_PROG=srconv sysdump coffdump 
+
+MANPAGES= ar nm objdump ranlib size strings strip objcopy nlmconv
+
+PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRINGS_PROG) $(STRIP_PROG) $(RANLIB_PROG) $(DEMANGLER_PROG) $(OBJCOPY_PROG) $(BUILD_NLMCONV) $(BUILD_SRCONV) $(SYSINFO_PROG) 
 STAGESTUFF = $(PROGS) *.o
 # Files that can be generated, but should be in the distribution.
-DISTSTUFF=arparse.c arlex.c nlmheader.c info
+DISTSTUFF=arparse.c arlex.c nlmheader.c sysinfo.c syslex.c info
+
+# Stuff that goes in tooldir/ if appropriate
+TOOL_PROGS = nm.new strip.new ar ranlib
 
 BASEDIR = $(srcdir)/..
 BFDDIR = $(BASEDIR)/bfd
@@ -154,33 +161,53 @@ FLAGS_TO_PASS = \
        "CC=$(CC)" \
        "CFLAGS=$(CFLAGS)" \
        "RUNTEST=$(RUNTEST)" \
-       "RUNTESTFLAGS=$(RUNTESTFLAGS) \
-       SIZE=`if [ -f $$rootme/$(SIZE_PROG) ] ; then echo $$rootme/$(SIZE_PROG) ; else echo $(SIZE_PROG); fi` \
-       OBJCOPY=`if [ -f $$rootme/$(OBJCOPY_PROG) ] ; then echo $$rootme/$(OBJCOPY_PROG) ; else echo $(OBJCOPY_PROG); fi` \
-       NM=`if [ -f $$rootme/$(NM_PROG) ] ; then echo $$rootme/$(NM_PROG) ; else echo $(NM_PROG); fi` \
-       AR=`if [ -f $$rootme/$(AR_PROG) ] ; then echo $$rootme/$(AR_PROG) ; else echo $(AR_PROG); fi` \
-       OBJDUMP=`if [ -f $$rootme/$(OBJDUMP_PROG) ] ; then echo $$rootme/$(OBJDUMP_PROG) ; else echo $(OBJDUMP_PROG); fi` \
-       STRINGS=`if [ -f $$rootme/$(STRINGS_PROG) ] ; then echo $$rootme/$(STRINGS_PROG) ; else echo $(STRINGS_PROG); fi` \
-       STRIP=`if [ -f $$rootme/$(STRIP_PROG) ] ; then echo $$rootme/$(STRIP_PROG) ; else echo $(STRIP_PROG); fi` \
-       RANLIB=`if [ -f $$rootme/$(RANLIB_PROG) ] ; then echo $$rootme/$(RANLIB_PROG) ; else echo $(RANLIB_PROG); fi` \
-       DEMANGLE=`if [ -f $$rootme/$(DEMANGLER_PROG) ] ; then echo $$rootme/$(DEMANGLER_PROG) ; else echo $(DEMANGLER_PROG); fi`"
+       "RUNTESTFLAGS=$(RUNTESTFLAGS)"
 
 #\f
 ## The rules
 
 all: $(ADDL_LIBS) $(PROGS)
 
-testsuite:
-       if [ -f testsuite/Makefile.in ]; then \
-               (rootme=`pwd`/ ; export rootme ; \
-                rootsrc=`cd $(srcdir); pwd`/ ; export rootsrc ; \
-                cd testsuite; $(MAKE) FLAGS_TO_PASS=$(FLAGS_TO_PASS)); \
-       else true ; fi
-
-check: force
-       rootme=`pwd`; export rootme; cd testsuite ; \
-       $(MAKE) check $(FLAGS_TO_PASS)
-#      /bin/sh $(srcdir)/sanity.sh .
+# These targets are for the dejagnu testsuites. The file site.exp 
+# contains global variables that all the testsuites will use.
+
+site.exp: ./config.status Makefile
+       @echo "Making a new config file..."
+       @rm -f ./tmp?
+       @touch site.exp
+       @mv site.exp site.bak
+       @echo "## variables are automatically generated by make ##" > ./tmp0
+       @echo "# Do not edit here. If you wish to override these" >> ./tmp0
+       @echo "# values, add them to the last section" >> ./tmp0
+       @echo "# HOST AND TARGET INFO" >> ./tmp0
+       @echo "set host_os $(host_os)" >> ./tmp0
+       @echo "set host_alias $(host_alias)" >> ./tmp0
+       @echo "set host_cpu $(host_cpu)" >> ./tmp0
+       @echo "set host_vendor $(host_vendor)" >> ./tmp0
+       @echo "set target_os $(target_os)" >> ./tmp0
+       @echo "set target_alias $(target_alias)" >> ./tmp0
+       @echo "set target_cpu $(target_cpu)" >> ./tmp0
+       @echo "set target_vendor $(target_vendor)" >> ./tmp0
+       @echo "set host_triplet $(host_canonical)" >> ./tmp0
+       @echo "set target_triplet $(target_canonical)" >> ./tmp0
+       @echo "# DIRECTORY INFO" >> ./tmp0
+       @echo "set objdir `pwd`" >> ./tmp0
+       @echo "" >> ./tmp0      
+       @echo "## Variables generated by configure. Do Not Edit ##" >> ./tmp0
+       @cat ./tmp0 > site.exp
+       @cat site.bak | sed \
+                       -e '1,/^## Variables generated by.*##/ d' >> site.exp
+       -@rm -f ./tmp?
+
+check: site.exp
+       r=`pwd`; export r; \
+       srcroot=`cd ${srcdir}; pwd` ; export srcroot ; \
+       EXPECT=${EXPECT} ; export EXPECT ; \
+       if [ -f $$r/../expect/expect ] ; then  \
+          TCL_LIBRARY=$${srcroot}/../tcl/library ; \
+          export TCL_LIBRARY ; else true; fi ; \
+       $(RUNTEST) --tool binutils --srcdir $(srcdir)/testsuite \
+         $(RUNTESTFLAGS)
 
 installcheck:
        /bin/sh $(srcdir)/sanity.sh $(bindir)
@@ -201,45 +228,35 @@ $(STRINGS_PROG): $(ADDL_LIBS) strings.o $(BFD)
 $(STRIP_PROG): $(ADDL_LIBS) objcopy.o is-strip.o $(BFD)
        $(CC) $(CFLAGS) $(LDFLAGS) -o $(STRIP_PROG) objcopy.o is-strip.o $(ADDL_LIBS) $(EXTRALIBS)
 
-$(NM_PROG): $(ADDL_LIBS) nm.o demangle.o $(BFD)
-       $(CC) $(CFLAGS) $(LDFLAGS) -o $(NM_PROG) nm.o demangle.o $(ADDL_LIBS) $(EXTRALIBS)
+$(NM_PROG): $(ADDL_LIBS) nm.o $(BFD)
+       $(CC) $(CFLAGS) $(LDFLAGS) -o $(NM_PROG) nm.o $(ADDL_LIBS) $(EXTRALIBS)
 
 $(OBJDUMP_PROG): $(ADDL_LIBS) objdump.o $(BFD) $(OPCODES)
        $(CC) $(CFLAGS) $(LDFLAGS) -o $(OBJDUMP_PROG) objdump.o $(OPCODES) $(ADDL_LIBS) $(EXTRALIBS)
 
-objdump.o: objdump.c config.status
-       $(CC) -c $(INCLUDES) $(HDEFINES) $(TDEFINES) $(ARCHDEFS) $(CFLAGS) $(srcdir)/objdump.c
-
-underscore.c:
-       echo "int xxy_us_dummy;" >dummy.c
-       $(CC) -c dummy.c
+underscore.c: Makefile
        rm -f underscore.c
-       echo '/*WARNING: This file is automatically generated!*/' >underscore.c
-       if [ "`$(NM) dummy.o | grep _xxy_us_dummy ; true`" != "" ]; then \
-         echo "int prepends_underscore = 1;" >>underscore.c; \
-       else \
-         echo "int prepends_underscore = 0;" >>underscore.c; \
-       fi
-       -rm -f dummy.c dummy.o
+       echo '/*WARNING: This file is automatically generated!*/' >underscore.t
+       echo "int prepends_underscore = $(UNDERSCORE);" >>underscore.t
+       mv -f underscore.t underscore.c
 
-version.o: version.c
+version.o: version.c Makefile
        $(CC) $(INCLUDES) $(HDEFINES) $(TDEFINES) -DVERSION='"$(VERSION)"' $(CFLAGS) -c $(srcdir)/version.c
 
-demangle.o: $(BASEDIR)/libiberty/cplus-dem.c
-       $(CC) -c $(INCLUDES) $(HDEFINES) $(TDEFINES) $(CFLAGS) $(BASEDIR)/libiberty/cplus-dem.c
-       mv cplus-dem.o demangle.o
-
-# For parallel compiling, depend on demangle.o so that one gets done first.
-cplus-dem.o: $(BASEDIR)/libiberty/cplus-dem.c $(INCDIR)/getopt.h demangle.o
+cplus-dem.o: $(BASEDIR)/libiberty/cplus-dem.c $(INCDIR)/getopt.h
        $(CC) -c -DMAIN $(INCLUDES) $(HDEFINES) $(TDEFINES) $(CFLAGS) $(BASEDIR)/libiberty/cplus-dem.c
 
 $(DEMANGLER_PROG): cplus-dem.o $(LIBIBERTY) underscore.o version.o
        $(CC) $(CFLAGS) $(LDFLAGS)  -o $(DEMANGLER_PROG) cplus-dem.o $(LIBIBERTY) $(EXTRALIBS) underscore.o version.o
 
-arparse.h arparse.c: arparse.y
+arparse.c: arparse.y
        $(BISON) $(BISONFLAGS)  $(srcdir)/arparse.y
-       -mv y.tab.c arparse.c
-       -mv y.tab.h arparse.h
+       mv -f y.tab.c arparse.c
+       mv -f y.tab.h arparse.h
+
+# Separate from arparse.c so that a parallel make doesn't try to build
+# both arparse.c and arparse.h simultaneously.
+arparse.h: arparse.c
 
 arlex.c: arlex.l
        $(LEX) $(LEX_OPTIONS) $(srcdir)/arlex.l
@@ -270,14 +287,71 @@ objcopy_with_strip: $(ADDL_LIBS) objcopy.o maybe-strip.o $(BFD)
        -rm -f $(STRIP_PROG)
        -ln $(OBJCOPY_PROG) $(STRIP_PROG)
 
-nlmheader.c: nlmheader.y
+sysroff.c: sysinfo sysroff.info 
+       ./sysinfo -c <$(srcdir)/sysroff.info >sysroff.c
+       ./sysinfo -i <$(srcdir)/sysroff.info >>sysroff.c
+       ./sysinfo -g <$(srcdir)/sysroff.info >>sysroff.c
+
+sysroff.h: sysinfo sysroff.info
+       ./sysinfo -d <$(srcdir)/sysroff.info >sysroff.h 
+
+# Depend upon arparse.c to avoid building both arparse.c and sysinfo.c
+# simultaneously.
+sysinfo.c: sysinfo.y arparse.c
+       $(BISON) -tvd $(srcdir)/sysinfo.y
+       rm -f sysinfo.c
+       mv -f y.tab.c sysinfo.c
+       mv -f y.tab.h sysinfo.h
+
+# Separate from sysinfo.c so that a parallel make doesn't try to build
+# both sysinfo.c and sysinfo.h simultaneously.
+sysinfo.h: sysinfo.c
+
+syslex.c : syslex.l
+       $(LEX) $(LEX_OPTIONS) $(srcdir)/syslex.l
+       mv lex.yy.c syslex.c
+       
+sysinfo: sysinfo.o syslex.o
+       $(CC_FOR_BUILD) $(CFLAGS) $(LDFLAGS) -o $@ sysinfo.o syslex.o 
+
+syslex.o: syslex.c sysinfo.h
+       if [ -r syslex.c ]; then \
+         $(CC_FOR_BUILD) -c -I. $(CFLAGS)  syslex.c  ; \
+       else \
+         $(CC_FOR_BUILD) -c -I. $(CFLAGS) $(srcdir)/syslex.c ;\
+       fi
+
+sysinfo.o: sysinfo.c
+       if [ -r sysinfo.c ]; then \
+         $(CC_FOR_BUILD) -c -I. $(CFLAGS)  sysinfo.c  ; \
+       else \
+         $(CC_FOR_BUILD) -c -I. $(CFLAGS) $(srcdir)/sysinfo.c ; \
+       fi
+
+srconv.o: srconv.c sysroff.h sysroff.c coffgrok.h $(INCDIR)/coff/internal.h \
+  ../bfd/libcoff.h
+
+srconv: srconv.o coffgrok.o $(ADDL_LIBS)
+       $(CC) $(CFLAGS) $(LDFLAGS) -o $@ srconv.o coffgrok.o $(ADDL_LIBS) $(EXTRALIBS)
+
+coffdump: coffdump.o coffgrok.o $(ADDL_LIBS)
+       $(CC) $(CFLAGS) $(LDFLAGS) -o $@  coffdump.o coffgrok.o $(ADDL_LIBS) $(EXTRALIBS)
+
+sysdump.o: sysdump.c sysroff.h sysroff.c
+
+sysdump: sysdump.o $(ADDL_LIBS)
+       $(CC) $(CFLAGS) $(LDFLAGS) -o $@ sysdump.o $(ADDL_LIBS) $(EXTRALIBS)
+
+# Depend upon sysinfo.c to avoid building both nlmheader.c and sysinfo.c
+# simultaneously.
+nlmheader.c: nlmheader.y sysinfo.c
        $(BISON) $(srcdir)/nlmheader.y
        rm -f nlmheader.c
-       -mv y.tab.c nlmheader.c
+       mv -f y.tab.c nlmheader.c
 
 nlmconv.o: nlmconv.c
-       ldname=`t='$(program_transform_name)'; echo ld | sed -e "" $$t`; \
-       $(CC) -c -DLD_NAME="\"$${ldname}\"" $(INCLUDES) $(HDEFINES) $(TDEFINES) $(CFLAGS) $(srcdir)/nlmconv.c
+       ldname=`t='$(program_transform_name)'; echo ld | sed -e "s/brokensed/brokensed/" $$t`; \
+       $(CC) -c -DLD_NAME="\"$${ldname}\"" $(INCLUDES) $(HDEFINES) $(TDEFINES) $(NLMCONV_DEFS) $(CFLAGS) $(srcdir)/nlmconv.c
 
 $(NLMCONV_PROG): nlmconv.o nlmheader.o $(ADDL_LIBS) $(BFD)
        $(CC) $(CFLAGS) $(LDFLAGS) -o $@ nlmconv.o nlmheader.o $(ADDL_LIBS) $(EXTRALIBS)
@@ -325,10 +399,14 @@ objcopy.o: objcopy.c ../bfd/bfd.h $(INCDIR)/ansidecl.h \
 is-strip.o: is-strip.c 
 is-ranlib.o: is-ranlib.c 
 not-strip.o: not-strip.c 
-nlmheader.o: nlmheader.c nlmconv.h $(INCDIR)/nlm/common.h \
-  $(INCDIR)/nlm/internal.h
-nlmconv.o: $(INCDIR)/nlm/common.h $(INCDIR)/nlm/internal.h \
-  $(BFDDIR)/libnlm.h bucomm.h
+nlmheader.o: nlmheader.c ../bfd/bfd.h ../bfd/sysdep.h \
+  $(BFDDIR)/hosts/std-host.h $(INCDIR)/fopen-same.h bucomm.h \
+  $(INCDIR)/nlm/common.h $(INCDIR)/nlm/internal.h nlmconv.h
+nlmconv.o: nlmconv.c ../bfd/bfd.h $(INCDIR)/libiberty.h ../bfd/sysdep.h \
+  $(BFDDIR)/hosts/std-host.h $(INCDIR)/fopen-same.h bucomm.h \
+  $(BFDDIR)/libnlm.h $(INCDIR)/nlm/common.h \
+  $(INCDIR)/nlm/internal.h $(INCDIR)/nlm/external.h nlmconv.h \
+  $(INCDIR)/coff/sym.h $(INCDIR)/coff/ecoff.h
 
 stage1: force
        - mkdir stage1
@@ -369,6 +447,10 @@ binutils.dvi: $(srcdir)/binutils.texi
 binutils.info: $(srcdir)/binutils.texi
        $(MAKEINFO) -o binutils.info $(srcdir)/binutils.texi
 
+$(DEMANGLER_PROG).1: cxxfilt.man Makefile
+       sed -e 's/@PROGRAM@/$(DEMANGLER_PROG)/' < $(srcdir)/cxxfilt.man \
+               > $(DEMANGLER_PROG).1
+
 #   different targets for -ms, -mm, -me
 # Try to use a recent texi2roff.  v2 was put on prep in jan91.
 # If you want an index, see texi2roff doc for postprocessing 
@@ -433,17 +515,13 @@ binutils.me: $(srcdir)/binutils.texi
 
 mostlyclean:
        -rm -f *.o *~ \#* core binutils.?? binutils.???
+       -rm -rf tmpdir
 clean: mostlyclean
-       @if [ -d testsuite ] ; then \
-         cd testsuite ; $(MAKE) $(FLAGS_TO_PASS) clean ; \
-       else true; fi
        -rm -f $(PROGS) underscore.c
 distclean:
-       @if [ -d testsuite ] ; then \
-         cd testsuite ; $(MAKE) $(FLAGS_TO_PASS) distclean ; \
-       else true; fi
-       -rm -f Makefile config.status sysdep.h *.o *~ \#* core \
+       -rm -f Makefile config.status sysdep.h *.o *~ \#* core y.* \
                binutils.?? binutils.??s binutils.aux binutils.log binutils.toc
+       -rm -f $(PROGS) underscore.c
 realclean: clean distclean
        -rm -f $(DISTSTUFF) TAGS
 
@@ -452,27 +530,36 @@ etags tags: TAGS
 TAGS: force
        etags $(INCDIR)/*.h $(srcdir)/*.[hc] 
 
-install: all
+install: all $(DEMANGLER_PROG).1
        for i in $(PROGS) ; do \
-         $(INSTALL_XFORM) $$i $(bindir)/$$i ; \
+         $(INSTALL_XFORM) $$i $(bindir)/`echo $$i | sed -e 's/.new//'` ; \
        done
        for i in $(MANPAGES) ; do \
          $(INSTALL_XFORM1) $(srcdir)/$$i.1 $(man1dir)/$$i.1 ; \
        done
+       $(INSTALL_XFORM1) $(DEMANGLER_PROG).1 $(man1dir)/$(DEMANGLER_PROG).1
        -if [ -d $(tooldir) ]; then \
-          if [ -d $(tooldir)/bin ] ; then true ; else mkdir $(tooldir)/bin ; fi; \
-          for i in nm strip ar ranlib; do \
-            rm -f $(tooldir)/bin/$$i; \
-            ln $(bindir)/`t='$(program_transform_name)'; echo $$i | sed -e "" $$t` $(tooldir)/bin/$$i \
-             || $(INSTALL_PROGRAM) $$i $(tooldir)/bin/$$i; \
-          done; \
-        else true; fi          
-
-# Use binutils.info as the target so that VPATH will DTRT.
-# (Use "$<*" in case the output is multiple files, though.)
+         if [ -d $(tooldir)/bin ]; then true; else mkdir $(tooldir)/bin; fi; \
+         for i in $(TOOL_PROGS) ; do \
+           j=`echo $$i | sed -e 's/.new//'`; \
+           rm -f $(tooldir)/bin/$$j; \
+           k=`t='$(program_transform_name)'; echo $$j | sed -e s/x/x/ $$t`; \
+           ln $(bindir)/$$k $(tooldir)/bin/$$j >/dev/null 2>/dev/null \
+            || $(INSTALL_PROGRAM) $$i $(tooldir)/bin/$$j; \
+         done; \
+        else true; fi
+
+# This little path search is required because in the FSF net releases,
+# the info files are included in the source tree, and that may not be
+# the same as the build directory.
 install-info: binutils.info
-       for i in $<* ; do \
-               $(INSTALL_DATA) $$i $(infodir)/$$i ; \
+       if [ -r binutils.info ]; then \
+         dir=. ; \
+       else \
+         dir=$(srcdir) ; \
+       fi ; \
+       for i in `cd $$dir; echo binutils.info*` ; do \
+               $(INSTALL_DATA) $$dir/$$i $(infodir)/$$i ; \
        done
 
 clean-info:
This page took 0.026753 seconds and 4 git commands to generate.