--- gforth/Makefile.in 1995/07/25 15:28:02 1.29 +++ gforth/Makefile.in 1995/10/07 17:38:10 1.33 @@ -7,7 +7,7 @@ #To do: #use $(srcdir) to make compilation in a non-srcdir possible -VERSION =0.1alpha#gforth version +VERSION =0.1#gforth version SHELL = /bin/sh RM = rm CP = cp @@ -19,7 +19,7 @@ GCC = gcc CC = $(GCC) FORTH = ./gforth STRIP = strip -TEXI2DVI = tex +TEXI2DVI = texi2dvi DVI2PS = dvips #you can get texi2html from http://asis01.cern.ch/infohtml/texi2html.html TEXI2HTML = texi2html @@ -28,10 +28,13 @@ XCFLAGS = @CFLAGS@ XDEFINES = @DEFS@ SWITCHES = $(XCFLAGS) $(XDEFINES) #-DNDEBUG #turn off assertions ENGINE_FLAGS = -fno-defer-pop -fcaller-saves -CFLAGS = @DEBUGFLAG@ -pipe -O4 -Wall $(SWITCHES) -DDEFAULTPATH=\"$(datadir)/gforth/$(VERSION):$(libdir)/gforth/$(VERSION):.\" +DEBUGFLAG = @DEBUGFLAG@ +CFLAGS = -pipe -O4 -Wall $(SWITCHES) -DDEFAULTPATH=\"$(datadir)/gforth/$(VERSION):$(libdir)/gforth/$(VERSION):.\" #John Wavrik should use -Xlinker -N to get a writable text (executable) -LDFLAGS = @DEBUGFLAG@ @LDFLAGS@ @GCCLDFLAGS@ +XLDFLAGS = @LDFLAGS@ +GCCLDFLAGS = @GCCLDFLAGS@ +LDFLAGS = $(DEBUGFLAG) $(XLDFLAGS) $(GCCLDFLAGS) LDLIBS = @LIBS@ prefix = @prefix@ @@ -48,8 +51,11 @@ mandir = $(prefix)/man/man1 INCLUDES = forth.h io.h +KERN_SRC = main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ + errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs + FORTH_SRC = anslocal.fs add.fs assert.fs ansi.fs blocks.fs bufio.fs checkans.fs \ - colorize.fs cross.fs debug.fs debugging.fs doskey.fs ds2texi.fs \ + code.fs colorize.fs cross.fs debug.fs debugging.fs doskey.fs ds2texi.fs \ dumpimage.fs environ.fs errore.fs etags.fs extend.fs filedump.fs \ float.fs glocals.fs glosgen.fs gray.fs hash.fs history.fs \ kernal.fs locals-test.fs look.fs main.fs makedoc.fs \ @@ -67,7 +73,7 @@ SOURCES = Makefile.in configure.in confi getopt.c getopt1.c getopt.h select.c \ ecvt.c memcmp.c strtol.c strtoul.c ansidecl.h memmove.c pow10.c \ strerror.c \ - makefile.dos configure.bat startup.dos \ + makefile.dos mkdosmf.sed configure.bat startup.dos \ glosgen.glo glossaries.doc \ $(INCLUDES) $(FORTH_SRC) @@ -84,7 +90,11 @@ FORTH_GEN = $(FORTH_GEN0) @KERNAL@ FORTH_GEN1 = $(FORTH_GEN0) @gforth_fi@ -GEN_PRECIOUS = $(FORTH_GEN) gforth.texi gforth.dvi gforth.ps Makefile configure +KERNLS = kernl16b.fi+ kernl16l.fi+ \ + kernl32b.fi+ kernl32l.fi+ \ + kernl64b.fi+ kernl64l.fi+ + +GEN_PRECIOUS = $(FORTH_GEN) $(KERNLS) gforth.texi gforth.dvi gforth.ps Makefile configure #standards.info recommends this: .SUFFIXES: @@ -123,6 +133,7 @@ dist: $(SOURCES) $(FORTH_GEN) mkdir gforth-$(VERSION) cp -p $(SOURCES) $(FORTH_GEN) gforth-$(VERSION) tar cvf - gforth-$(VERSION)|gzip -9 >gforth-$(VERSION).tar.gz + -rm -rf gforth-$(VERSION) #a binary distribution contains the complete source distribution, # the objects, the executable and the links. the objects are there for making @@ -164,12 +175,13 @@ install: gforth $(FORTH_SRC) gforth.fi g done check: test - + touch test + test: gforth @echo 'Expect to see INCORRECT RESULT: { GS1 -> }' @echo 'This is a bug of the testing program' $(FORTH) tester.fs coretest.fs -e bye - $(FORTH) startup.fs blocks.fs checkans.fs -e bye + $(FORTH) startup.fs blocks.fs code.fs checkans.fs -e bye @echo 'Expect no differences' $(FORTH) prims2x.fs -e "s\" primitives.b\" ' output-c process-file bye"| diff -c - primitives.i @@ -180,48 +192,54 @@ gforth: $(OBJECTS) $(GCC) $(LDFLAGS) $(OBJECTS) $(LDLIBS) -o $@ @MAKE_EXE@ -kernl16l.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach16l.fs $(FORTH_GEN1) - -$(CP) kernl16l.fi kernl16l.fi~ +kernl16l.fi+: $(KERN_SRC) mach16l.fs $(FORTH_GEN0) $(FORTH) -e 's" mach16l.fs"' main.fs - @LINK_KERNL16L@ -kernl16b.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach16b.fs $(FORTH_GEN1) - -$(CP) kernl16b.fi kernl16b.fi~ +kernl16b.fi+: $(KERN_SRC) mach16b.fs $(FORTH_GEN0) $(FORTH) -e 's" mach16b.fs"' main.fs - @LINK_KERNL16B@ -kernl32l.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach32l.fs $(FORTH_GEN1) - -$(CP) kernl32l.fi kernl32l.fi~ +kernl32l.fi+: $(KERN_SRC) mach32l.fs $(FORTH_GEN0) $(FORTH) -e 's" mach32l.fs"' main.fs - @LINK_KERNL32L@ -kernl32b.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach32b.fs $(FORTH_GEN1) - -$(CP) kernl32b.fi kernl32b.fi~ +kernl32b.fi+: $(KERN_SRC) mach32b.fs $(FORTH_GEN0) $(FORTH) -e 's" mach32b.fs"' main.fs - @LINK_KERNL32B@ -kernl64l.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach64l.fs $(FORTH_GEN1) - -$(CP) kernl64l.fi kernl64l.fi~ +kernl64l.fi+: $(KERN_SRC) mach64l.fs $(FORTH_GEN0) $(FORTH) -e 's" mach64l.fs"' main.fs - @LINK_KERNL64L@ -kernl64b.fi: main.fs search-order.fs cross.fs aliases.fs vars.fs add.fs \ - errore.fs kernal.fs version.fs extend.fs tools.fs toolsext.fs \ - mach64b.fs $(FORTH_GEN1) - -$(CP) kernl64b.fi kernl64b.fi~ +kernl64b.fi+: $(KERN_SRC) mach64b.fs $(FORTH_GEN0) $(FORTH) -e 's" mach64b.fs"' main.fs + +kernl16b.fi: $(KERNLS) + -$(CP) kernl16b.fi kernl16b.fi~ + -$(CP) kernl16b.fi+ kernl16b.fi + @LINK_KERNL16B@ + +kernl16l.fi: $(KERNLS) + -$(CP) kernl16l.fi kernl16l.fi~ + -$(CP) kernl16l.fi+ kernl16l.fi + @LINK_KERNL16L@ + +kernl32b.fi: $(KERNLS) + -$(CP) kernl32b.fi kernl32b.fi~ + -$(CP) kernl32b.fi+ kernl32b.fi + @LINK_KERNL32B@ + +kernl32l.fi: $(KERNLS) + -$(CP) kernl32l.fi kernl32l.fi~ + -$(CP) kernl32l.fi+ kernl32l.fi + @LINK_KERNL32L@ + +kernl64b.fi: $(KERNLS) + -$(CP) kernl64b.fi kernl64b.fi~ + -$(CP) kernl64b.fi+ kernl64b.fi @LINK_KERNL64B@ +kernl64l.fi: $(KERNLS) + -$(CP) kernl64l.fi kernl64l.fi~ + -$(CP) kernl64l.fi+ kernl64l.fi + @LINK_KERNL64L@ + engine.s: engine.c primitives.i prim_labels.i machine.h $(INCLUDES) $(GCC) $(CFLAGS) $(ENGINE_FLAGS) -S engine.c @@ -255,8 +273,8 @@ version.c: Makefile.in doc.fd: makedoc.fs float.fs search-order.fs glocals.fs environ.fs \ toolsext.fs wordinfo.fs \ vt100.fs colorize.fs see.fs bufio.fs debug.fs history.fs \ - doskey.fs vt100key.fs startup.fs assert.fs debugging.fs - $(FORTH) -e "s\" doc.fd\"" makedoc.fs startup.fs -e bye + doskey.fs vt100key.fs startup.fs assert.fs debugging.fs code.fs + $(FORTH) -e "s\" doc.fd\"" makedoc.fs startup.fs code.fs -e bye gforth.texi: gforth.ds primitives.b ds2texi.fs prims2x.fs doc.fd crossdoc.fd $(FORTH) ds2texi.fs >$@ @@ -283,3 +301,10 @@ config.status: configure ./config.status --recheck configure: configure.in cd $(srcdir) && autoconf + +makefile.dos: mkdosmf.sed Makefile.in + sed -f mkdosmf.sed makefile.dos + +startup.dos: startup.fs Makefile.in + sed -e "s/\\\\ include doskey/include doskey/g" \ + -e "s/include vt100key/\\\\ include vt100key/g" <$< >$@ \ No newline at end of file