--- gforth/engine/Makefile.in 2007/04/15 20:33:46 1.63 +++ gforth/engine/Makefile.in 2012/12/31 15:25:19 1.90 @@ -1,12 +1,12 @@ #Makefile for the C part of Gforth -#Copyright (C) 1995,1996,1997,1998,2000,2003,2006 Free Software Foundation, Inc. +#Copyright (C) 1995,1996,1997,1998,2000,2003,2006,2007,2008,2009,2011,2012 Free Software Foundation, Inc. #This file is part of Gforth. #Gforth is free software; you can redistribute it and/or #modify it under the terms of the GNU General Public License -#as published by the Free Software Foundation; either version 2 +#as published by the Free Software Foundation, either version 3 #of the License, or (at your option) any later version. #This program is distributed in the hope that it will be useful, @@ -15,12 +15,12 @@ #GNU General Public License for more details. #You should have received a copy of the GNU General Public License -#along with this program; if not, write to the Free Software -#Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA. +#along with this program. If not, see http://www.gnu.org/licenses/. # ------------- gforth version VERSION =@PACKAGE_VERSION@ +LIBVERSION=@LIB_VERSION@ DOSVERSION=`echo $VERSION|sed 's/\.//g'` EXE=@EXEEXT@ @@ -36,9 +36,8 @@ include_fi = @include_fi@ PATHSEP = @PATHSEP@ -osclass = @OSCLASS@ - EC = @EC@ +ARCH= @ARCH@ # ------------- Utility programs @@ -48,152 +47,228 @@ RMTREE = rm -rf CP = cp -p TAR = tar cf - GCC = @CC@ +BOOTFORTH = ../preforth CC = $(GCC) LD = $(GCC:gcc=ld) +AS = $(GCC:gcc=as) STRIP = strip GCCLD = @GCC_LD@ +LIBTOOL = @GNU_LIBTOOL@ +LTLD = $(LIBTOOL) --mode=link $(GCCLD) -rpath $(libdir) -version-info $(LIBVERSION) -module + +FORTHPATH = .$(PATHSEP)$(libdir)/gforth/site-forth$(PATHSEP)$(datadir)/gforth/site-forth$(PATHSEP)$(libdir)/gforth$(ARCH)/$(VERSION)$(PATHSEP)$(datadir)/gforth/$(VERSION) -FORTHPATH = .$(PATHSEP)$(libdir)/gforth/site-forth$(PATHSEP)$(datadir)/gforth/site-forth$(PATHSEP)$(libdir)/gforth/$(VERSION)$(PATHSEP)$(datadir)/gforth/$(VERSION) +# ------------ Source and Build directories -# ------------ Install Directorys +top_srcdir = @top_srcdir@ +top_builddir = @top_builddir@ + +# ------------ Install directories VPATH = @srcdir@ prefix = @prefix@ exec_prefix = @exec_prefix@ srcdir = @srcdir@ -bindir = $(exec_prefix)/bin +bindir = @bindir@ #read-only architecture-independent files -datadir = $(prefix)/share +datadir = @datadir@ #read-only architecture-dependent non-ascii files -libdir = $(prefix)/lib -infodir = $(prefix)/info -mandir = $(prefix)/man +libdir = @libdir@ +infodir = @infodir@ +mandir = @mandir@ man1dir= $(mandir)/man1 man1ext= .1 +# ------------- ltdl variables + +LTDLDEPS = @LTDLDEPS@ +LTDLINCL = @LTDLINCL@ +LIBLTDL = @LIBLTDL@ + # ------------- Compiler Flags XCFLAGS = @CFLAGS@ XDEFINES = @DEFS@ -SWITCHES = $(XCFLAGS) $(XDEFINES) +SWITCHES = $(XCFLAGS) $(XDEFINES) $(OPTDEFINES) #use -fno-inline to avoid register problems with asinh, atanh on gcc-3.3 on 386 ENGINE_FLAGS = @ENGINE_FLAGS@ -fno-defer-pop -fcaller-saves -fno-inline DEBUGFLAG = @DEBUGFLAG@ -CFLAGS = $(DEBUGFLAG) -I$(srcdir)/../arch/$(machine) -I. -Wall $(SWITCHES) -DDEFAULTPATH='"$(FORTHPATH)"' -CFLAGS2 = $(DEBUGFLAG) -I$(srcdir)/../arch/$(machine) -I. -Wall $(SWITCHES) -DDEFAULTPATH='"$(FORTHPATH)"' +CFLAGS = $(DEBUGFLAG) -I$(srcdir)/../arch/$(machine) -I. -Wall $(SWITCHES) -DDEFAULTPATH='"$(FORTHPATH)"' $(LTDLINCL) +CPPFLAGS=@CPPFLAGS@ FORTHKFLAGS= --die-on-signal -p "..$(PATHSEP)$(srcdir)" -i ../$(kernel_fi) FORTHK = ../gforth $(FORTHKFLAGS) -FORTH = ../gforth --die-on-signal -p "..$(PATHSEP)$(srcdir)" -i ../gforth.fi +FORTH = $(BOOTFORTH) --die-on-signal #John Wavrik should use -Xlinker -N to get a writable text (executable) XLDFLAGS = @LDFLAGS@ LDFLAGS = $(DEBUGFLAG) $(XLDFLAGS) -LDLIBS = @LIBS@ +LDLIBS = @LIBS@ @LTDL_LDLIBS@ + +AOBJECTS = @signals_o@ support$(OPT).o @LIBOBJS@ $(OPTOBJECTS) -AOBJECTS = @signals_o@ support.o @LIBOBJS@ +@MAKEINC@ -OBJECTS = engine.o @engine2@ main.o -OBJECTS_NATIVE = engine-native.o engine-native2.o engine-native3.o main-native.o -OBJECTS_FAST = engine-fast.o @engine_fast2@ main-fast.o -OBJECTS_ITC = engine-itc.o main-itc.o -OBJECTS_DITC = engine-ditc.o main-ditc.o -OBJECTS_PROF = engine-prof.o main-prof.o -OBJECTS_FI = engine.o main-fi.o +OBJECTS = engine$(OPT).o @engine2@ main$(OPT).o +OBJECTS_NATIVE = engine-native$(OPT).o engine-native2$(OPT).o engine-native3$(OPT).o main-native$(OPT).o +OBJECTS_FAST = engine-fast$(OPT).o @engine_fast2@ main-fast$(OPT).o +OBJECTS_ITC = engine-itc$(OPT).o main-itc$(OPT).o +OBJECTS_DITC = engine-ditc$(OPT).o main-ditc$(OPT).o +OBJECTS_PROF = engine-prof$(OPT).o main-prof$(OPT).o +OBJECTS_FI = engine$(OPT).o main-fi$(OPT).o # In engine subdirectory there are (or should be) only files that belong to # our engine, so we can make life easy -DEPS = config.h *.h $(srcdir)/../arch/$(machine)/*.[h] -ENGINE_DEPS = engine.c $(DEPS) prim_lab.i prim.i @image_i@ +DEPS = config.h forth.h io.h $(srcdir)/../arch/$(machine)/*.[h] +ENGINE_DEPS = engine.c $(DEPS) prim_lab.i prim.i @image_i@ fnmatch.h threaded.h MAIN_DEPS = main.c $(DEPS) prim_superend.i prim_num.i prim_grp.i costs.i super2.i -ENGINE_FAST_DEPS = engine.c $(DEPS) prim_lab-fast.i prim-fast.i +ENGINE_FAST_DEPS = engine.c $(DEPS) prim_lab-fast.i prim-fast.i fnmatch.h threaded.h MAIN_FAST_DEPS = main.c $(DEPS) prim_superend-fast.i prim_num-fast.i prim_grp-fast.i costs-fast.i super2-fast.i +COMPILE.c = $(GCC) $(CFLAGS) $(CPPFLAGS) -c # simulate BSD sys.mk +LIBTOOL.c = $(LIBTOOL) --mode=compile $(COMPILE.c) +COMPILER = $(COMPILE.c) + +%.lo: COMPILER = $(LIBTOOL.c) + #some makes don't do the -o $@ correctly, so we help them .c.o: - $(GCC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $< + $(COMPILER) -o $@ $< + +%.lo: %.c + $(COMPILER) -o $@ $< + +.s.o: + $(COMPILER) -o $@ $< + +support$(OPT).o support$(OPT).lo: support.c config.h forth.h longlong.h + $(COMPILER) -o $@ $(srcdir)/support.c + +strtol.o strtol.lo: strtol.c ansidecl.h + +fnmatch.o fnmatch.lo: fnmatch.c fnmatch.h + +getopt1.o getopt1.lo: getopt1.c getopt.h + +getopt.o getopt.lo: getopt.c getopt.h -support.o: support.c config.h forth.h longlong.h +GFORTHDEPS = $(AOBJECTS) $(LTDLDEPS) libmain.o +GFORTHOBJS = $(AOBJECTS) $(LDLIBS) libmain.o -gforth$(EC)$(EXE): $(OBJECTS) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS) $(AOBJECTS) $(LDLIBS) -o $@ +LINKER=$(GCCLD) $(LDFLAGS) +%.la: LINKER=$(LTLD) $(LDFLAGS) -gforth-native$(EC)$(EXE): $(OBJECTS_NATIVE) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS_NATIVE) $(AOBJECTS) $(LDLIBS) -o $@ +gforth$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS) $(GFORTHDEPS) + $(LINKER) $(OBJECTS) $(GFORTHOBJS) -o $@ -gforth-fast$(EC)$(EXE): $(OBJECTS_FAST) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS_FAST) $(AOBJECTS) $(LDLIBS) -o $@ +gforth-native$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_NATIVE) $(GFORTHDEPS) + $(LINKER) $(OBJECTS_NATIVE) $(GFORTHOBJS) -o $@ -gforth-itc$(EC)$(EXE): $(OBJECTS_ITC) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS_ITC) $(AOBJECTS) $(LDLIBS) -o $@ +gforth-fast$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_FAST) $(GFORTHDEPS) + $(LINKER) $(OBJECTS_FAST) $(GFORTHOBJS) -o $@ -gforth-ditc$(EC)$(EXE): $(OBJECTS_DITC) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS_DITC) $(AOBJECTS) $(LDLIBS) -o $@ +gforth-itc$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_ITC) $(GFORTHDEPS) + $(LINKER) $(OBJECTS_ITC) $(GFORTHOBJS) -o $@ -gforth-prof$(EC)$(EXE): $(OBJECTS_PROF) $(AOBJECTS) profile.o - $(GCCLD) $(LDFLAGS) $(OBJECTS_PROF) $(AOBJECTS) profile.o $(LDLIBS) -o $@ +gforth-ditc$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_DITC) $(GFORTHDEPS) + $(LINKER) $(OBJECTS_DITC) $(GFORTHOBJS) -o $@ -gforth-fi$(EC)$(EXE): $(OBJECTS_FI) $(AOBJECTS) - $(GCCLD) $(LDFLAGS) $(OBJECTS_FI) $(AOBJECTS) $(LDLIBS) -o $@ +gforth-prof$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_PROF) profile$(OPT).o $(GFORTHDEPS) + $(LINKER) $(OBJECTS_PROF) $(AOBJECTS) profile$(OPT).o $(LDLIBS) -o $@ + +gforth-fi$(OPT)$(EC)$(ARCH)$(EXE): $(OBJECTS_FI) $(GFORTHDEPS) + $(LINKER) $(OBJECTS_FI) $(GFORTHOBJS) -o $@ + +LIBGFORTHDEPS = $(AOBJECTS:%.o=%.lo) $(LTDLDEPS) +LIBGFORTHOBJS = $(AOBJECTS:%.o=%.lo) $(LDLIBS) + +libgforth$(EC)$(ARCH).la libgforth$(OPT)$(EC)$(ARCH).la: $(OBJECTS:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +libgforth-native$(EC)$(ARCH).la libgforth-native$(OPT)$(EC)$(ARCH).la: $(OBJECTS_NATIVE:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_NATIVE:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +libgforth-fast$(EC)$(ARCH).la libgforth-fast$(OPT)$(EC)$(ARCH).la: $(OBJECTS_FAST:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_FAST:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +libgforth-itc$(EC)$(ARCH).la libgforth-itc$(OPT)$(EC)$(ARCH).la: $(OBJECTS_ITC:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_ITC:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +libgforth-ditc$(EC)$(ARCH).la libgforth-ditc$(OPT)$(EC)$(ARCH).la: $(OBJECTS_DITC:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_DITC:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +libgforth-prof$(EC)$(ARCH).la libgforth-prof$(OPT)$(EC)$(ARCH).la: $(OBJECTS_PROF:%.o=%.lo) profile$(OPT).o $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_PROF:%.o=%.lo) $(AOBJECTS) profile$(OPT).o $(LDLIBS) -o $@ + +libgforth-fi$(EC)$(ARCH).la libgforth-fi$(OPT)$(EC)$(ARCH).la: $(OBJECTS_FI:%.o=%.lo) $(LIBGFORTHDEPS) + $(LINKER) $(OBJECTS_FI:%.o=%.lo) $(LIBGFORTHOBJS) -o $@ + +# executables generated by linking to library + +libgforth%$(EXE): libgforth%.la libmain.lo + $(LTLD) $(LDFLAGS) $(patsubst lib%,-l%,$@) libmain.lo -o $@ + +libgforth$(EXE): libgforth.la libmain.lo + $(LTLD) $(LDFLAGS) $(patsubst lib%,-l%,$@) libmain.lo -o $@ engine.s: $(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -S $(srcdir)/engine.c + $(GCC) $(CFLAGS) $(CPPFLAGS) $(ENGINE_FLAGS) -S $(srcdir)/engine.c -engine.o: $(ENGINE_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DGFORTH_DEBUGGING -o $@ -c $(srcdir)/engine.c +engine$(OPT).o engine$(OPT).lo: $(ENGINE_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DGFORTH_DEBUGGING -o $@ $(srcdir)/engine.c -engine2.o: $(ENGINE_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DGFORTH_DEBUGGING -DENGINE=2 -o $@ -c $(srcdir)/engine.c +engine2$(OPT).o engine2$(OPT).lo: $(ENGINE_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DGFORTH_DEBUGGING -DENGINE=2 -o $@ $(srcdir)/engine.c -engine-native.o:$(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DNO_IP -o $@ -c $(srcdir)/engine.c +engine-native$(OPT).o engine-native$(OPT).lo:$(ENGINE_FAST_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DNO_IP -o $@ $(srcdir)/engine.c -engine-native2.o:$(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DNO_IP -DENGINE=2 -o $@ -c $(srcdir)/engine.c +engine-native2$(OPT).o engine-native2$(OPT).lo:$(ENGINE_FAST_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DNO_IP -DENGINE=2 -o $@ $(srcdir)/engine.c -engine-native3.o:$(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DNO_IP -DENGINE=3 -o $@ -c $(srcdir)/engine.c +engine-native3$(OPT).o engine-native3$(OPT).lo:$(ENGINE_FAST_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DNO_IP -DENGINE=3 -o $@ $(srcdir)/engine.c -engine-fast.o: $(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -o $@ -c $(srcdir)/engine.c +engine-fast$(OPT).o engine-fast$(OPT).lo: $(ENGINE_FAST_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -o $@ $(srcdir)/engine.c -engine-fast2.o: $(ENGINE_FAST_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DENGINE=2 -o $@ -c $(srcdir)/engine.c +engine-fast2$(OPT).o engine-fast2$(OPT).lo: $(ENGINE_FAST_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DENGINE=2 -o $@ $(srcdir)/engine.c -engine-itc.o: $(ENGINE_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DINDIRECT_THREADED -DGFORTH_DEBUGGING -o $@ -c $(srcdir)/engine.c +engine-itc$(OPT).o engine-itc$(OPT).lo: $(ENGINE_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DINDIRECT_THREADED -DGFORTH_DEBUGGING -o $@ $(srcdir)/engine.c -engine-ditc.o: $(ENGINE_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DDOUBLY_INDIRECT -o $@ -c $(srcdir)/engine.c +engine-ditc$(OPT).o engine-ditc$(OPT).lo: $(ENGINE_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DDOUBLY_INDIRECT -o $@ $(srcdir)/engine.c -engine-prof.o: $(ENGINE_DEPS) - $(GCC) $(CFLAGS2) $(ENGINE_FLAGS) -DVM_PROFILING -o $@ -c $(srcdir)/engine.c +engine-prof$(OPT).o engine-prof$(OPT).lo: $(ENGINE_DEPS) + $(COMPILER) $(ENGINE_FLAGS) -DVM_PROFILING -o $@ $(srcdir)/engine.c -main.o: $(MAIN_DEPS) - $(GCC) $(CFLAGS) -DGFORTH_DEBUGGING @no_dynamic@ -o $@ -c $(srcdir)/main.c +main$(OPT).o main$(OPT).lo: $(MAIN_DEPS) + $(COMPILER) -DGFORTH_DEBUGGING @no_dynamic@ -o $@ $(srcdir)/main.c -main-native.o: $(MAIN_FAST_DEPS) - $(GCC) $(CFLAGS) -DNO_IP -o $@ -c $(srcdir)/main.c +main-native$(OPT).o main-native$(OPT).lo: $(MAIN_FAST_DEPS) + $(COMPILER) -DNO_IP -o $@ $(srcdir)/main.c -main-fast.o: $(MAIN_FAST_DEPS) - $(GCC) $(CFLAGS) -o $@ -c $(srcdir)/main.c +main-fast$(OPT).o main-fast$(OPT).lo: $(MAIN_FAST_DEPS) + $(COMPILER) -o $@ $(srcdir)/main.c -main-itc.o: $(MAIN_DEPS) - $(GCC) $(CFLAGS) -DINDIRECT_THREADED -DGFORTH_DEBUGGING -o $@ -c $(srcdir)/main.c +main-itc$(OPT).o main-itc$(OPT).lo: $(MAIN_DEPS) + $(COMPILER) -DINDIRECT_THREADED -DGFORTH_DEBUGGING -o $@ $(srcdir)/main.c -main-ditc.o: $(MAIN_DEPS) - $(GCC) $(CFLAGS) -DDOUBLY_INDIRECT -o $@ -c $(srcdir)/main.c +main-ditc$(OPT).o main-ditc$(OPT).lo: $(MAIN_DEPS) + $(COMPILER) -DDOUBLY_INDIRECT -o $@ $(srcdir)/main.c -main-prof.o: $(MAIN_DEPS) - $(GCC) $(CFLAGS) -DVM_PROFILING -o $@ -c $(srcdir)/main.c +main-prof$(OPT).o main-prof$(OPT).lo: $(MAIN_DEPS) + $(COMPILER) -DVM_PROFILING -o $@ $(srcdir)/main.c -main-fi.o: $(MAIN_DEPS) - $(GCC) $(CFLAGS) -DINCLUDE_IMAGE -o $@ -c $(srcdir)/main.c +main-fi$(OPT).o main-fi$(OPT).lo: $(MAIN_DEPS) + $(COMPILER) -DINCLUDE_IMAGE -o $@ $(srcdir)/main.c -peephole.o: peephole.c peephole.i $(DEPS) - $(GCC) $(CFLAGS) -o $@ -c $(srcdir)/peephole.c +peephole$(OPT).o peephole$(OPT).lo: peephole.c peephole.i $(DEPS) + $(COMPILER) -o $@ $(srcdir)/peephole.c -profile.o: profile.c profile.i $(DEPS) - $(GCC) $(CFLAGS) -o $@ -c $(srcdir)/profile.c +profile$(OPT).o profile$(OPT).lo: profile.c profile.i $(DEPS) + $(COMPILER) -o $@ $(srcdir)/profile.c #The next two rules seem to be superfluous: @@ -206,29 +281,16 @@ profile.o: profile.c profile.i $(DEPS) termios.o: /usr/lib/libposix.a ar x /usr/lib/libposix.a termios.o -#duplicated rules to avoid too many recursive make invocations -# !! No any forth stuff should be done in ../Makefile. -# !! I added the dependencies on prim.i and prim_lab.i in the main Makefile, jens - -#I commented out the following rules because they are no longer up-to-date. - anton - -#prim.i: ../prim.b ../prims2x.fs -# $(FORTHK) prims2x.fs -e "s\" ../prim.b\" ' output-c process-file bye" >$@- -# $(CP) $@- $@ -# $(RM) $@- -# -#prim_lab.i: ../prim.b ../prims2x.fs -# $(FORTHK) prims2x.fs -e "s\" ../prim.b\" ' output-label process-file bye" >$@- -# $(CP) $@- $@ -# $(RM) $@- - config.h: stamp-h stamp-h: config.h.in ../config.status ../stamp-h.in cd .. && CONFIG_FILES=$@ CONFIG_HEADERS=engine/config.h ./config.status echo timestamp > stamp-h +Makefile: Makefile.in ../config.status ../configure.in + cd .. && $(MAKE) engine/Makefile.in + image.i: ../fi2c.fs ../$(include_fi) - $(FORTH) fi2c.fs -e "s\" ../$(include_fi)\" fi2c bye" >$@ + $(BOOTFORTH) ../fi2c.fs -e "s\" ../$(include_fi)\" fi2c bye" >$@ ../$(include_fi): FORCE cd .. && $(MAKE) $(include_fi)