]> Git Repo - binutils.git/blobdiff - binutils/Makefile.in
misc fixes
[binutils.git] / binutils / Makefile.in
index 450cd8e9ecc31a73a16e7c1d4fd1f92af1b8e100..7e6edd189b28382c32e36c096265e307de125657 100644 (file)
 # along with this program; if not, write to the Free Software
 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-#$Id$
-
 srcdir = .
 
 prefix = /usr/local
 
-program_prefix =
+program_transform_name =
 exec_prefix = $(prefix)
 bindir = $(exec_prefix)/bin
 libdir = $(exec_prefix)/lib
-tooldir = $(libdir)
+tooldir = $(exec_prefix)/$(target_alias)
 
 datadir = $(prefix)/lib
 mandir = $(prefix)/man
@@ -53,15 +51,23 @@ INSTALL_DATA = $(INSTALL)
 AR = ar
 AR_FLAGS = qv
 CFLAGS = -g
-BISON = bison -y
-FLEX = flex
 MAKEINFO = makeinfo
+TEXI2DVI = texi2dvi
 RANLIB = ranlib
-BISONFLAGS = -tvd
+BISONFLAGS = -d
 TEXI2ROFF=texi2roff
 
+NM_FOR_TARGET = nm
+NM = $(NM_FOR_TARGET)
+SYMLINK = ln -s
+
+BISON = `if [ -f ../byacc/byacc ] ; then echo ../byacc/byacc ; else echo byacc ; 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=1.96
+VERSION=2.2
 # Distribution name
 DIST_NAME=binutils-${VERSION}
 
@@ -70,15 +76,15 @@ version=`./../gcc/gcc -dumpversion`
 # Where to find texinfo.tex to format docn with TeX
 TEXIDIR = $(srcdir)/../texinfo/fsf
 
-MANPAGES= ar.1 nm.1 objdump.1 ranlib.1 size.1 strip.1
+MANPAGES= ar nm objdump ranlib size strip
 
 #CC=gcc -Wall
 # these two are almost the same program
 AR_PROG=ar
 RANLIB_PROG=ranlib
 
-# copy and strip should be the same program
-COPY_PROG=copy
+# objcopy and strip should be the same program
+OBJCOPY_PROG=objcopy
 STRIP_PROG=strip
 
 # These should all be the same program too.
@@ -86,23 +92,25 @@ SIZE_PROG=size
 NM_PROG=nm
 OBJDUMP_PROG=objdump
 
-PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRIP_PROG) $(RANLIB_PROG)
+# This is the demangler, as a standalone program.
+DEMANGLER_PROG=c++filt
+
+PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRIP_PROG) $(RANLIB_PROG) $(DEMANGLER_PROG) $(OBJCOPY_PROG)
 STAGESTUFF = $(PROGS) *.o
+# Files that can be generated, but should be in the distribution.
+DISTSTUFF=arparse.c arlex.c
 
 BASEDIR = $(srcdir)/..
 LIBDIR  = ./../bfd
+OPCODEDIR = ./../opcodes
 
 #### host and target dependant Makefile fragments come in here.
 ###
 
-INCDIR = $(BASEDIR)/include
+INCLUDES = -I. -I$(srcdir) -I$(BASEDIR)/include -I$(BASEDIR)/bfd
 
 .c.o:
-       $(CC) -c $(CFLAGS) -I. -I$(srcdir) -I$(INCDIR) $(HDEFINES) $(TDEFINES) $<
-
-# When adding .o files, to make VPATH work in Sun Make, you have to
-# also add a foo.o: foo.c line at the bottom of the file.
-DISASMS = m68k-pinsn.o i960-pinsn.o i386-pinsn.o sparc-pinsn.o  am29k-pinsn.o
+       $(CC) -c $(CFLAGS) $(INCLUDES) $(HDEFINES) $(TDEFINES) $<
 
 #\f
 ## Random definitions
@@ -120,7 +128,9 @@ DISASMS = m68k-pinsn.o i960-pinsn.o i386-pinsn.o sparc-pinsn.o  am29k-pinsn.o
 # Use the GNU getopt unless you have problems with it.
 # The IRIS version could probably benefit from being assembled with
 # libmalloc rather than the ordinary malloc.
-LIBIBERTY = ./../libiberty/libiberty.a
+LIBIBERTY_SRC_DIR = $(srcdir)/../libiberty
+LIBIBERTY_BIN_DIR = ./../libiberty
+LIBIBERTY = $(LIBIBERTY_BIN_DIR)/libiberty.a
 
 # Code shared by all the binutils.
 BULIBS = bucomm.o version.o filemode.o
@@ -128,42 +138,90 @@ BULIBS = bucomm.o version.o filemode.o
 ADDL_LIBS = $(MALLOC) $(BULIBS) $(BFD) $(LIBIBERTY)
 
 BFD = $(LIBDIR)/libbfd.a
+OPCODES = $(OPCODEDIR)/libopcodes.a
+
+RUNTEST = runtest
+RUNTESTFLAGS = 
+FLAGS_TO_PASS = \
+       "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` \
+       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`"
+
 #\f
 ## The rules
 
 all: $(ADDL_LIBS) $(PROGS)
 
-check:
-       /bin/sh $(srcdir)/sanity.sh .
+testsuite:
+       if [ -d testsuite ]; 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 .
+
+installcheck:
+       /bin/sh $(srcdir)/sanity.sh $(bindir)
 
 info: binutils.info
 
+dvi: binutils.dvi
+
 #$(BFD):$(LIBDIR)/../common/*.c
 #      (cd $(LIBDIR); make)
 
 $(SIZE_PROG): $(ADDL_LIBS) size.o $(BFD)
        $(CC) $(LDFLAGS) $(CFLAGS) -o $(SIZE_PROG) size.o $(ADDL_LIBS) $(LOADLIBES)
 
-$(COPY_PROG): $(ADDL_LIBS) copy.o not-strip.o $(BFD)
-       $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o not-strip.o $(ADDL_LIBS) $(LOADLIBES)
+$(OBJCOPY_PROG): $(ADDL_LIBS) objcopy.o not-strip.o $(BFD)
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJCOPY_PROG) objcopy.o not-strip.o $(ADDL_LIBS) $(LOADLIBES)
 
-$(STRIP_PROG): $(ADDL_LIBS) copy.o is-strip.o $(BFD)
-       $(CC) $(LDFLAGS) $(CFLAGS) -o $(STRIP_PROG) copy.o is-strip.o $(ADDL_LIBS) $(LOADLIBES)
+$(STRIP_PROG): $(ADDL_LIBS) objcopy.o is-strip.o $(BFD)
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(STRIP_PROG) objcopy.o is-strip.o $(ADDL_LIBS) $(LOADLIBES)
 
 $(NM_PROG): $(ADDL_LIBS) nm.o $(BFD)
        $(CC) $(LDFLAGS) $(CFLAGS) -o $(NM_PROG) nm.o $(ADDL_LIBS) $(LOADLIBES)
 
-$(OBJDUMP_PROG): $(ADDL_LIBS) size.o objdump.o $(DISASMS) $(BFD)
-       $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJDUMP_PROG) objdump.o $(DISASMS) $(ADDL_LIBS) $(LOADLIBES)
+$(OBJDUMP_PROG): $(ADDL_LIBS) size.o objdump.o $(BFD) $(OPCODES)
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJDUMP_PROG) objdump.o $(OPCODES) $(ADDL_LIBS) $(LOADLIBES)
+
+underscore.c:
+       echo "int xxy_us_dummy;" >dummy.c
+       $(CC) -c dummy.c
+       echo '/*WARNING: This file is automatically generated!*/' >underscore.c
+       if [ "`$(NM) dummy.o | grep _xxy_us_dummy`" != "" ]; then \
+         echo "int prepends_underscore = 1;" >>underscore.c; \
+       else \
+         echo "int prepends_underscore = 0;" >>underscore.c; \
+       fi
+       -rm -f dummy.c dummy.o
+
+cplus-dem.o: $(LIBIBERTY_SRC_DIR)/cplus-dem.c
+       $(CC) -c -DMAIN $(CFLAGS) $(INCLUDES) $(HDEFINES) $(TDEFINES) $(LIBIBERTY_SRC_DIR)/cplus-dem.c
+
+$(DEMANGLER_PROG): cplus-dem.o $(LIBIBERTY) underscore.o
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(DEMANGLER_PROG) cplus-dem.o $(LIBIBERTY) $(LOADLIBES) underscore.o
 
 arparse.c:arparse.y
-       $(BISON) $(BISONFLAGS)  $(VPATH)/arparse.y
-       mv y.tab.c arparse.c
-       mv y.tab.h arparse.h
+       $(BISON) $(BISONFLAGS)  $(srcdir)/arparse.y
+       -mv y.tab.c arparse.c
+       -mv y.tab.h arparse.h
 
 
-arlex.c:arlex.l
-       $(FLEX) -I -Cem -t $(VPATH)/arlex.l >arlex.c
+arlex.c: arlex.l
+       $(LEX) $(LEX_OPTIONS) $(srcdir)/arlex.l
+       mv lex.yy.c arlex.c
 
 $(AR_PROG): $(ADDL_LIBS) ar.o arparse.o arlex.o not-ranlib.o $(BFD) arsup.o
        $(CC) $(LDFLAGS) $(CFLAGS) -o $(AR_PROG) ar.o arparse.o arlex.o arsup.o not-ranlib.o $(ADDL_LIBS) $(LOADLIBES)
@@ -183,12 +241,12 @@ ar_with_ranlib: $(ADDL_LIBS) ar.o maybe-ranlib.o $(BFD)
        -rm -f $(RANLIB_PROG)
        -ln $(AR_PROG) $(RANLIB_PROG)
 
-# copy and strip in one binary that uses argv[0] to decide its action.
+# objcopy and strip in one binary that uses argv[0] to decide its action.
 
-copy_with_strip: $(ADDL_LIBS) copy.o maybe-strip.o $(BFD)
-       $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o maybe-strip.o $(ADDL_LIBS) $(LOADLIBES)
+objcopy_with_strip: $(ADDL_LIBS) objcopy.o maybe-strip.o $(BFD)
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJCOPY_PROG) objcopy.o maybe-strip.o $(ADDL_LIBS) $(LOADLIBES)
        -rm -f $(STRIP_PROG)
-       -ln $(COPY_PROG) $(STRIP_PROG)
+       -ln $(OBJCOPY_PROG) $(STRIP_PROG)
 
 stage1: force
        - mkdir stage1
@@ -223,9 +281,7 @@ de-stage3: force
 # DOCUMENTATION TARGETS
 # TeX output
 binutils.dvi: $(srcdir)/binutils.texi
-       TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi
-       texindex binutils.??
-       TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi
+       $(TEXI2DVI) $(srcdir)/binutils.texi
 
 # info file for online browsing
 binutils.info: $(srcdir)/binutils.texi
@@ -293,26 +349,46 @@ binutils.me: $(srcdir)/binutils.texi
 
 ######################################################################
 
-clean:
-       -rm -f *.o *~ \#* core $(STAGESTUFF) TAGS binutils.?? binutils.???
+mostlyclean:
+       -rm -f *.o *~ \#* core binutils.?? binutils.???
+clean: mostlyclean
+       -rm -f $(PROGS) underscore.c
+distclean: clean
+       -rm -f Makefile config.status sysdep.h
+realclean: distclean
+       -rm -f $(DISTSTUFF) TAGS
 
 etags tags: TAGS
 
 TAGS: force
        etags $(INCDIR)/*.h $(BFDSRC)/*.[hc] *.[hc]
 
-realclean: clean
-       -rm -f $(STAGESTUFF) TAGS
-
 install: all
-       for i in $(PROGS) ; do \
-               $(INSTALL_PROGRAM) $$i $(bindir)/$(program_prefix)$$i ; \
+       -parent=`echo $(bindir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(bindir) ] ; then true ; else mkdir $(bindir) ; fi
+       -for i in $(PROGS) ; do \
+               $(INSTALL_PROGRAM) $$i $(bindir)/`t='$(program_transform_name)'; echo $$i | sed -e "" $$t` ; \
        done
-       for i in $(MANPAGES) ; do \
-               $(INSTALL_DATA) $(srcdir)/$$i $(man1dir)/$(program_prefix)$$i ; \
+       -parent=`echo $(man1dir)|sed -e 's@/[^/]*$$@@'`; \
+       if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi
+       -if [ -d $(man1dir) ] ; then true ; else mkdir $(man1dir) ; fi
+       -for i in $(MANPAGES) ; do \
+               $(INSTALL_DATA) $(srcdir)/$$i.1 $(man1dir)/`t='$(program_transform_name)'; echo $$i | sed -e "" $$t`.1 ; \
        done
+       -if [ -d $(tooldir) ]; then \
+          if [ -d $(tooldir)/bin ] ; then true ; else mkdir $(tooldir)/bin ; fi; \
+          for i in nm strip ; 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          
 
 install-info: 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
        for i in *.info* ; do \
                $(INSTALL_DATA) $$i $(infodir)/$$i ; \
        done
@@ -320,30 +396,41 @@ install-info: info
 clean-info:
        -rm -rf *.info*
 
-dist: $(DIST_NAME).tar.Z
+# Making a dist:
+# cvs rtag binutils-x-yy ld+utils
+# cvs co -r binutils-x-yy ld+utils
+# Sanitize
+# cd {HERE}; make dist [-f Makefile.in]
+
+dist: $(DIST_NAME).tar.z
+
+diststuff: $(DISTSTUFF)
 
-$(DIST_NAME).tar.Z:
+$(DIST_NAME).tar.z:
        cd ../..; rm -f $(DIST_NAME); ln -s devo $(DIST_NAME)
-       make binutils.mm -f Makefile.in
-       cd ../ld; make ld.mm -f Makefile.in
-       cd ../..; tar chf - $(DIST_NAME) | compress >$(DIST_NAME).tar.Z
+       make diststuff -f Makefile.in
+       cd ../ld; make diststuff -f Makefile.in
+       cd ../gprof; make diststuff -f Makefile.in
+       cd ../texinfo; mv texinfo.tex ..; rm -rf *; mv ../texinfo.tex .
+       # Take out texinfo from configurable dirs
+       mv ../configure.in tmp; \
+         sed -e '/^host_tools=/s/texinfo //' <tmp >../configure.in; rm tmp
+       cd ..; chmod og=u `find . -print`
+       cd ../..; tar chf - $(DIST_NAME) | gzip >$(DIST_NAME).tar.z
        rm -rf ../../$(DIST_NAME)
 
 # These get around a bug in Sun Make in SunOS 4.1.1
 alloca.o:alloca.c
-am29k-pinsn.o: am29k-pinsn.c
 ar.o: ar.c
+arsup.o: arsup.c
 bucomm.o: bucomm.c
-copy.o: copy.c
-cplus-dem.o:cplus-dem.c
+objcopy.o: objcopy.c
 filemode.o:filemode.c
 getopt.o:getopt.c
 getopt1.o:getopt1.c
 gmalloc.o:gmalloc.c
-i960-pinsn.o: i960-pinsn.c
 is-ranlib.o:is-ranlib.c
 is-strip.o:is-strip.c
-m68k-pinsn.o: m68k-pinsn.c
 maybe-ranlib.o:maybe-ranlib.c
 maybe-strip.o:maybe-strip.c
 nm.o: nm.c
@@ -351,11 +438,9 @@ not-ranlib.o:not-ranlib.c
 not-strip.o:not-strip.c
 objdump.o: objdump.c
 size.o: size.c
-sparc-pinsn.o: sparc-pinsn.c
-i386-pinsn.o: i386-pinsn.c
 strip.o:strip.c
 version.o: $(srcdir)/version.c
-       $(CC) $(CFLAGS) -I. -I$(srcdir) -I$(INCDIR) $(HDEFINES) $(TDEFINES) -DVERSION='"$(VERSION)"' -c $(srcdir)/version.c
+       $(CC) $(CFLAGS) $(INCLUDES) $(HDEFINES) $(TDEFINES) -DVERSION='"$(VERSION)"' -c $(srcdir)/version.c
 
 #-----------------------------------------------------------------------------
 #              'STANDARD' GNU/960 TARGETS BELOW THIS POINT
This page took 0.034615 seconds and 4 git commands to generate.