OSDN Git Service

* config/cris/predicates.md: New file.
[pf3gnuchains/gcc-fork.git] / gcc / treelang / Make-lang.in
index 79da1a6..239d3f9 100644 (file)
@@ -1,7 +1,7 @@
 # Top level makefile fragment for TREELANG For GCC. -*- makefile -*-
 
-#   Copyright (C) 1994, 1995, 1997, 1998, 1999 2000, 2001, 2002 Free
-#   Software Foundation, Inc.
+#   Copyright (C) 1994, 1995, 1997, 1998, 1999, 2000, 2001, 2002, 2003
+#   Free Software Foundation, Inc.
 
 #This file is part of GCC.
 
 # Each language makefile fragment must provide the following targets:
 #
 # foo.all.build, foo.all.cross, foo.start.encap, foo.rest.encap,
-# foo.info, foo.dvi,
-# foo.install-normal, foo.install-common, foo.install-info, foo.install-man,
+# foo.install-normal, foo.install-common, foo.install-man,
 # foo.uninstall, foo.distdir,
-# foo.mostlyclean, foo.clean, foo.distclean, foo.extraclean,
+# foo.mostlyclean, foo.clean, foo.distclean,
 # foo.maintainer-clean, foo.stage1, foo.stage2, foo.stage3, foo.stage4
 #
 # where `foo' is the name of the language.
 #
 # It should also provide rules for:
 #
-# - making any compiler driver (eg: GCC)
-# - the compiler proper (eg: treelang)
+# - making any compiler driver (eg: gcc)
+# - the compiler proper (eg: tree1)
 # - define the names for selecting the language in LANGUAGES.
 #\f
 
@@ -46,8 +45,6 @@
 TREELANGSED = sed
 TREELANGSEDFLAGS = -n
 
-# back end compiler libraries etc
-TREE_BE_LIBS = $(BACKEND) $(LIBIBERTY) $(INTLLIBS) $(LIBS) $(LIBDEPS) 
 GCC_EXTRAS = -B./ -B$(build_tooldir)/bin/ -isystem $(build_tooldir)/include
 
 # ./xgcc is the just built compiler. See GCC_FOR_TARGET in the GCC Makefile.in.
@@ -56,15 +53,17 @@ GCC_EXTRAS = -B./ -B$(build_tooldir)/bin/ -isystem $(build_tooldir)/include
 
 # GCC_FOR_TREELANG = ./xgcc $(GCC_EXTRAS)
 
-TREE_GENERATED = $(srcdir)/treelang/lex.c $(srcdir)/treelang/parse.c\
-       $(srcdir)/treelang/parse.h $(srcdir)/treelang/parse.output $(srcdir)/treelang/TAGS
+TREE_GENERATED = lex.c parse.c parse.h parse.output
+# We need to use something other than treelang here because the directory
+# is called treelang
+TREE_EXES = gtreelang
 
-TREE_SOURCE = ${srcdir}/treelang/parse.y ${srcdir}/treelang/lex.l ${srcdir}/treelang/tree1.c ${srcdir}/treelang/treelang.h ${srcdir}/treelang/treetree.c $(srcdir)/treelang/treetree.h
-
-TREE_EXES = tree1$(exeext)
-
-#no -Wtraditional warnings, allow long long
-treelang-warn = $(LOOSE_WARN) -pedantic -Wno-long-long -Wmissing-prototypes -Wmissing-declarations
+#strict warnings for treelang
+treelang-warn = $(STRICT_WARN)
+# bison emits some unused static arrays (yytoknum)
+treelang/parse.o-warn = -Wno-error
+# flex produces 'no previous prototype' warnings
+treelang/lex.o-warn = -Wno-error
 
 #\f
 # Define the names for selecting treelang in LANGUAGES.
@@ -73,17 +72,27 @@ treelang-warn = $(LOOSE_WARN) -pedantic -Wno-long-long -Wmissing-prototypes -Wmi
 
 treelang TREELANG:treelang.done
 
-treelang.done: tree1$(exeext)
+treelang.done: gtreelang$(exeext) tree1$(exeext)
        $(STAMP) treelang.done
 
 # no preprocessor
 
-# core compiler 
-tree1$(exeext): treelang/tree1.o treelang/treetree.o treelang/lex.o treelang/parse.o\
-       $(TREE_BE_LIBS) c-convert.o c-typeck.o c-common.o c-decl.o attribs.o
+# core compiler
+tree1$(exeext): treelang/tree1.o treelang/treetree.o treelang/tree-convert.o \
+       treelang/lex.o treelang/parse.o \
+       $(BACKEND) $(LIBSDEPS) attribs.o
        $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ \
-       treelang/tree1.o treelang/treetree.o treelang/lex.o treelang/parse.o c-convert.o\
-       c-typeck.o c-common.o c-decl.o attribs.o $(TREE_BE_LIBS)
+       treelang/tree1.o treelang/treetree.o treelang/tree-convert.o \
+       treelang/lex.o treelang/parse.o \
+       $(BACKEND) $(LIBS) attribs.o
+
+# Create the compiler driver treelang.
+gtreelang$(exeext): gcc.o version.o prefix.o intl.o $(EXTRA_GCC_OBJS) \
+  $(LIBDEPS) treelang/spec.o
+       $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ treelang/spec.o \
+         gcc.o version.o prefix.o intl.o $(EXTRA_GCC_OBJS) $(LIBS)
+
+
 
 #\f
 # Compiling object files from source files.
@@ -92,29 +101,40 @@ tree1$(exeext): treelang/tree1.o treelang/treetree.o treelang/lex.o treelang/par
 
 treelang/tree1.o: treelang/tree1.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
   flags.h toplev.h $(GGC_H) $(TREE_H) diagnostic.h treelang/treelang.h \
+  input.h treelang/treetree.h options.h opts.h \
   treelang/treetree.h gt-treelang-tree1.h gtype-treelang.h
 
 treelang/treetree.o: treelang/treetree.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
-  $(TM_H) $(TREE_H) flags.h output.h $(C_TREE_H) $(RTL_H) $(GGC_H) toplev.h \
-  varray.h $(LANGHOOKS_DEF_H) langhooks.h treelang/treelang.h \
-  treelang/treetree.h
+  $(TM_H) $(TREE_H) flags.h output.h $(RTL_H) $(GGC_H) toplev.h \
+  varray.h $(LANGHOOKS_DEF_H) langhooks.h treelang/treelang.h input.h \
+  treelang/treetree.h treelang/parse.h
+
+treelang/tree-convert.o: treelang/tree-convert.c $(CONFIG_H) $(SYSTEM_H) \
+  coretypes.h diagnostic.h $(TREE_H) flags.h toplev.h langhooks.h $(TM_H)
+
+treelang/spec.o: treelang/spec.c $(CONFIG_H) $(SYSTEM_H) \
+  coretypes.h diagnostic.h $(TREE_H) flags.h toplev.h langhooks.h $(TM_H)
 
 treelang/parse.o: treelang/parse.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
-  $(TM_H) diagnostic.h treelang/treelang.h treelang/treetree.h
+  $(TM_H) diagnostic.h treelang/treelang.h input.h treelang/treetree.h
 
 treelang/lex.o: treelang/lex.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
-  $(TM_H) diagnostic.h $(TREE_H) treelang/treelang.h treelang/parse.h
+  $(TM_H) diagnostic.h $(TREE_H) treelang/treelang.h input.h \
+  treelang/parse.h
 
 # generated files the files from lex and yacc are put into the source
 # directory in case someone wants to build but does not have
 # lex/yacc
 
-$(srcdir)/treelang/lex.c: $(srcdir)/treelang/lex.l
-       $(LEX) $(LEXFLAGS) -o$(srcdir)/treelang/lex.c $(srcdir)/treelang/lex.l
+treelang.srcextra: treelang/parse.c treelang/parse.h treelang/lex.c
+       -cp -p $^ $(srcdir)/treelang
+
+treelang/lex.c: treelang/lex.l
+       -$(FLEX) $(FLEXFLAGS) -o$@ $<
+
+treelang/parse.c treelang/parse.h treelang/parse.output: treelang/parse.y
+       -$(BISON) $(BISONFLAGS) -v --defines --output=treelang/parse.c $<
 
-$(srcdir)/treelang/parse.c $(srcdir)/treelang/parse.h: $(srcdir)/treelang/parse.y
-       $(BISON) $(BISONFLAGS) -v $(srcdir)/treelang/parse.y\
-       --output=$(srcdir)/treelang/parse.c --defines
 # -v
 
 gt-treelang-tree1.h gtype-treelang.h : s-gtype; @true
@@ -123,26 +143,44 @@ gt-treelang-tree1.h gtype-treelang.h : s-gtype; @true
 # Build hooks:
 
 treelang.all.build: treelang
-treelang.all.cross: 
+treelang.all.cross:
        _error_not_here_yet - havent even thought about it - it may even work
 
 treelang.start.encap:
-treelang.rest.encap: 
+treelang.rest.encap:
+treelang.man:
+treelang.srcman:
+
+treelang.tags: force
+       cd $(srcdir)/treelang; etags -o TAGS.sub *.y *.l *.c *.h; \
+       etags --include TAGS.sub --include ../TAGS.sub
+
+treelang.info: doc/treelang.info
+
+treelang.srcinfo: doc/treelang.info
+       -cp -p $^ $(srcdir)/doc
+
+dvi:: doc/treelang.dvi
 
-.phony:treelang.info
-treelang.info: $(srcdir)/treelang/treelang.info
+TEXI_TREELANG_FILES = treelang/treelang.texi \
+        $(docdir)/include/gcc-common.texi \
+        $(docdir)/include/gpl.texi \
+        $(docdir)/include/fdl.texi \
+        $(docdir)/include/funding.texi \
+        gcc-vers.texi
 
-$(srcdir)/treelang/treelang.info: $(srcdir)/treelang/treelang.texi
-       cd $(srcdir) && $(MAKEINFO) $(MAKEINFOFLAGS) -Idoc/include \
-       -o treelang/treelang.info treelang/treelang.texi
+doc/treelang.info: $(TEXI_TREELANG_FILES)
+       $(MAKEINFO) $(MAKEINFOFLAGS) -I $(docdir)/include -o $@ $<
 
-treelang.dvi: $(srcdir)/treelang/treelang.texi
-       TEXINPUTS=$(srcdir)/treelang:$(srcdir):$$TEXINPUTS $(TEXI2DVI) $(srcdir)/treelang/treelang.texi; \
-         texindex treelang.??; \
-         TEXINPUTS=$(srcdir)/treelang:$(srcdir):$$TEXINPUTS $(TEXI2DVI) $(srcdir)/treelang/treelang.texi; \
-         mv treelang.dvi treelang;
+doc/treelang.dvi: $(TEXI_TREELANG_FILES)
+       $(TEXI2DVI) -I $(abs_docdir)/include -o $@ $<
 
-treelang.generated-manpages:
+html:: $(htmldir)/treelang/index.html
+
+$(htmldir)/treelang/index.html: $(TEXI_TREELANG_FILES)
+       $(mkinstalldirs) $(@D)
+       rm -f $(@D)/*
+       $(TEXI2HTML) -I $(docdir)/include -I $(srcdir)/treelang -o $(@D) $<
 
 #\f
 # Install hooks:
@@ -150,37 +188,29 @@ treelang.generated-manpages:
 # Nothing to do here.
 treelang.install-normal: treelang.install.common
 
-# Install 
+# Install
 .phony:treelang.install.common
 .phony:treelang.install
 
 treelang.install treelang.install.common treelang.install-common: treelang.install.common.done
 
-treelang.install.common.done:  installdirs treelang.done 
+treelang.install.common.done:  installdirs treelang.done
        for name in $(TREE_EXES); \
        do \
           if [ -f $$name ] ; then \
            name2="`echo \`basename $$name\` | sed -e '$(program_transform_name)' `"; \
-           rm -f $(bindir)/$$name2$(exeext); \
-           echo $(INSTALL_PROGRAM) $$name$(exeext) $(bindir)/$$name2$(exeext); \
-           $(INSTALL_PROGRAM) $$name$(exeext) $(bindir)/$$name2$(exeext); \
-           chmod a+x $(bindir)/$$name2$(exeext); \
+           rm -f $(DESTDIR)$(bindir)/$$name2$(exeext); \
+           echo $(INSTALL_PROGRAM) $$name$(exeext) $(DESTDIR)$(bindir)/$$name2$(exeext); \
+           $(INSTALL_PROGRAM) $$name$(exeext) $(DESTDIR)$(bindir)/$$name2$(exeext); \
+           chmod a+x $(DESTDIR)$(bindir)/$$name2$(exeext); \
          fi ; \
        done
        $(STAMP) treelang.install.common.done
 
-treelang.install-info: $(srcdir)/treelang/treelang.info
-       for name in $(srcdir)/treelang/treelang.info; \
-       do \
-          if [ -f $$name ] ; then \
-           name2="`echo \`basename $$name\` | sed -e '$(program_transform_name)' `"; \
-           rm -f $(libsubdir)/$$name2$(exeext); \
-           $(INSTALL_PROGRAM) $$name$(exeext) $(libsubdir)/$$name2$(exeext); \
-           chmod a+x $(libsubdir)/$$name2$(exeext); \
-         fi ; \
-       done
+# We might not be able to build the info files
+install-info:: $(DESTDIR)$(infodir)/treelang.info
 
-treelang.install-man: 
+treelang.install-man:
 
 treelang.uninstall:
        for name in $(TREE_EXES); \
@@ -188,8 +218,8 @@ treelang.uninstall:
          echo $$name; \
          name2="`echo $$name | sed -e '$(program_transform_name)' `"; \
          echo becomes $$name2; \
-         echo -rm -rf $(bindir)/$$name2$(exeext); \
-         rm -rf $(bindir)/$$name2$(exeext); \
+         echo -rm -rf $(DESTDIR)$(bindir)/$$name2$(exeext); \
+         rm -rf $(DESTDIR)$(bindir)/$$name2$(exeext); \
        done
        -rm treelang.install.common.done
 
@@ -198,7 +228,7 @@ treelang.uninstall:
 # A lot of the ancillary files are deleted by the main makefile.
 # We just have to delete files specific to us.
 
-treelang.mostlyclean: 
+treelang.mostlyclean:
        for name in $(TREE_EXES); \
        do \
          echo deleting $$name; \
@@ -214,12 +244,10 @@ treelang.mostlyclean:
 treelang.clean: treelang.mostlyclean
 
 treelang.distclean: treelang.clean
-       -rm -f treelang/config.status 
+       -rm -f treelang/config.status
        -rm -f treelang/*.output
 
-treelang.extraclean: treelang.distclean
-
-treelang.maintainer-clean: treelang.extraclean
+treelang.maintainer-clean: treelang.distclean
        for name in $(TREE_GENERATED); \
        do \
          if [ -f $(srcdir)/treelang/$$name ] ; then \
@@ -242,6 +270,10 @@ treelang.stage3: stage3-start
        -mv treelang/*$(objext) stage3/treelang
 treelang.stage4: stage4-start
        -mv treelang/*$(objext) stage4/treelang
+treelang.stageprofile: stageprofile-start
+       -mv treelang/*$(objext) stageprofile/treelang
+treelang.stagefeedback: stagefeedback-start
+       -mv treelang/*$(objext) stagefeedback/treelang
 #\f
 # Maintenance hooks:
 
@@ -251,56 +283,38 @@ treelang.distdir:
 #      not here yet sorry not sure if this is needed or not???
 
 # test hook
-# the other languages are hard coded in the main makefile.in - that seems to be wrong 
 
 check-treelang: treelang.check
 
 TESTSUITEDIR = testsuite
 
 treelang.check: $(TESTSUITEDIR)/site.exp
-       -mkdir testsuite/treelang 
+       -mkdir testsuite/treelang
 
 # these three files are empty and it seems diff has trouble generating
 # patch files for new empty files as required for cvs.
 # STAMP does not cut it here as I need an empty file.
        touch $(srcdir)/testsuite/treelang/{a01gcco01runpgmerr,a01gcc.out01,a01gcc.out01err}
-       -rootme=`${PWD}`; export rootme; \
-       srcdir=`cd ${srcdir}; ${PWD}` ; export srcdir ; \
+       -rootme=`${PWD_COMMAND}`; export rootme; \
+       srcdir=`cd ${srcdir}; ${PWD_COMMAND}` ; export srcdir ; \
        cd testsuite; \
        EXPECT=${EXPECT} ; export EXPECT ; \
        TRANSFORM=$(program_transform_name); export TRANSFORM; \
        if [ -f $${rootme}/../expect/expect ] ; then  \
-          TCL_LIBRARY=`cd .. ; cd ${srcdir}/../tcl/library ; ${PWD}` ; \
+          TCL_LIBRARY=`cd .. ; cd ${srcdir}/../tcl/library ; ${PWD_COMMAND}` ; \
           export TCL_LIBRARY ; fi ; \
-       PATH=`cd ..;${PWD}`:$$PATH; export PATH; \
-       gcc_extras="-B`cd ..;${PWD}` -B`cd ..;${PWD}`/treelang"; export gcc_extras; \
+       PATH=`cd ..;${PWD_COMMAND}`:$$PATH; export PATH; \
+       gcc_extras="-B`cd ..;${PWD_COMMAND}` -B`cd ..;${PWD_COMMAND}`/treelang"; export gcc_extras; \
        $(RUNTEST) --tool treelang $(RUNTESTFLAGS)
        rm $(srcdir)/testsuite/treelang/{a01gcco01runpgmerr,a01gcc.out01,a01gcc.out01err}
-#      GCC_EXTRAS="$(GCC_EXTRAS)"; export GCC_EXTRAS; \
 
 # copy the output files from the current test to source ie say the new results are OK
 treelang.check.fix: force
-       srcdir=`cd ${srcdir}; ${PWD}` ; export srcdir ; 
+       srcdir=`cd ${srcdir}; ${PWD_COMMAND}` ; export srcdir ;
        -cp testsuite/treelang/*.out* t
        -cp testsuite/treelang/*runpgm* t
        -rm -f t/*nofilename
 
-treelang.wc: force
-       wc  ${TREE_SOURCE}
-
 #\f
 
-# Update the tags table for emacs find label (alt-.) function
-TAGS: treelang.tags
-
-.PHONY: treelang.tags
-
-treelang.tags:
-       cd $(srcdir)/treelang;                                          \
-       etags -l c ${TREE_SOURCE}
-
-.PHONY: treelang.html
-
-treelang.html:
-       cd $(srcdir)/treelang && texi2html -I ../doc/include -verbose -menu -split_chapter -number treelang.texi
-#      mv treelang*.html $(srcdir)/treelang
+config.status: treelang/config-lang.in