]> Git Repo - binutils.git/blobdiff - binutils/Makefile.in
merge binutils and gdb sparc disassemblers
[binutils.git] / binutils / Makefile.in
index f42616421046cfc77a7a6b31499c4f247a99153e..595d64068f98ab54d0d57de6b35c44ae1988d264 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 = $(libdir)/$(target_alias)
 
 datadir = $(prefix)/lib
 mandir = $(prefix)/man
@@ -53,15 +51,21 @@ 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
 
+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.1
 # Distribution name
 DIST_NAME=binutils-${VERSION}
 
@@ -70,7 +74,7 @@ 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
@@ -86,23 +90,29 @@ 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=demangle
+
+PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRIP_PROG) $(RANLIB_PROG) $(DEMANGLER_PROG)
 STAGESTUFF = $(PROGS) *.o
+# Files that can be generated, but should be in the distribution.
+DISTSTUFF=arparse.c arlex.c binutils.mm
 
 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) $<
+       $(CC) -c $(CFLAGS) $(INCLUDES) $(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
+DISASMS = i960-pinsn.o am29k-pinsn.o
 
 #\f
 ## Random definitions
@@ -120,7 +130,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,15 +140,29 @@ BULIBS = bucomm.o version.o filemode.o
 ADDL_LIBS = $(MALLOC) $(BULIBS) $(BFD) $(LIBIBERTY)
 
 BFD = $(LIBDIR)/libbfd.a
+OPCODES = $(OPCODEDIR)/libopcodes.a
 #\f
 ## The rules
 
-all: $(ADDL_LIBS) $(PROGS)
+all: $(ADDL_LIBS) $(PROGS) testsuite
+
+testsuite:
+       if [ -d testsuite ]; then \
+                       (rootme=`pwd`/ ; export rootme ; \
+                        rootsrc=`cd $(srcdir); pwd`/ ; export rootsrc ; \
+                        cd testsuite; $(MAKE) $(FLAGS_TO_PASS)); \
+       else true ; fi
+
+check: all
+       /bin/sh $(srcdir)/sanity.sh .
 
-check:
+installcheck:
+       /bin/sh $(srcdir)/sanity.sh $(bindir)
 
 info: binutils.info
 
+dvi: binutils.dvi
+
 #$(BFD):$(LIBDIR)/../common/*.c
 #      (cd $(LIBDIR); make)
 
@@ -152,17 +178,21 @@ $(STRIP_PROG): $(ADDL_LIBS) copy.o is-strip.o $(BFD)
 $(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 $(DISASMS) $(BFD) $(OPCODES)
+       $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJDUMP_PROG) objdump.o $(DISASMS) $(OPCODES) $(ADDL_LIBS) $(LOADLIBES)
+
+$(DEMANGLER_PROG): $(LIBIBERTY_SRC_DIR)/cplus-dem.c
+       $(CC) $(LDFLAGS) $(CFLAGS) $(INCLUDES) $(HDEFINES) $(TDEFINES) -DMAIN -o $(DEMANGLER_PROG) $(LIBIBERTY_SRC_DIR)/cplus-dem.c $(LIBIBERTY) $(LOADLIBES)
 
 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)
@@ -222,9 +252,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
@@ -292,26 +320,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)
+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
@@ -319,12 +367,26 @@ install-info: info
 clean-info:
        -rm -rf *.info*
 
+# 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:
        cd ../..; rm -f $(DIST_NAME); ln -s devo $(DIST_NAME)
-       make binutils.mm -f Makefile.in
-       cd ../ld; make ld.mm -f Makefile.in
+       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) | compress >$(DIST_NAME).tar.Z
        rm -rf ../../$(DIST_NAME)
 
@@ -332,9 +394,9 @@ $(DIST_NAME).tar.Z:
 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
 filemode.o:filemode.c
 getopt.o:getopt.c
 getopt1.o:getopt1.c
@@ -342,7 +404,6 @@ 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
@@ -350,11 +411,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.030349 seconds and 4 git commands to generate.