mirror of
https://github.com/vishapoberon/compiler.git
synced 2026-04-05 23:22:25 +00:00
separated Kernel, Files. Texts modules for bootstrapping and general use
Former-commit-id: e1f76da278
This commit is contained in:
parent
5d683e6727
commit
66c583b70e
41 changed files with 3229 additions and 327 deletions
38
makefile
38
makefile
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -8,10 +8,8 @@ RELEASE = 1.0
|
|||
|
||||
|
||||
INCLUDEPATH = -Isrc/lib/system/$(TOS)/$(CCOMP)/$(TARCH)
|
||||
#ADDITIONALFLAGS = "-Wno-implicit-function-declaration -Wno-pointer-sign -Wno-implicit-int -Wno-logical-op-parentheses"
|
||||
ADDITIONALFLAGS = ""
|
||||
|
||||
SETPATH = CFLAGS="$(ADDITIONALFLAGS) $(INCLUDEPATH)" PATH=.:/bin:/usr/bin MODULES=.:src/lib:src/lib/v4:src/lib/v4/$(TARCH):src/lib/system/$(TOS)/$(CCOMP):src/lib/system/$(TOS)/$(CCOMP)/$(TARCH):src/lib/ulm:src/lib/ulm/$(TARCH):src/lib/ooc2:src/lib/ooc2/$(TOS)/$(CCOMP):src/lib/ooc:src/lib/ooc/$(TOS)/$(CCOMP)/$(TARCH):src/lib/pow:src/lib/misc:src/lib/s3:src/voc:src/voc/$(TOS)/$(CCOMP):src/voc/$(TOS)/$(CCOMP)/$(TARCH):src/tools/ocat:src/tools/browser:src/tools/vocparam:src/tools/vmake:src/tools/coco:src/test
|
||||
SETPATH = CFLAGS=$(INCLUDEPATH) PATH=.:/bin:/usr/bin MODULES=.:src/lib:src/lib/v4:src/lib/v4/$(TARCH):src/lib/system/$(TOS)/$(CCOMP):src/lib/system/$(TOS)/$(CCOMP)/$(TARCH):src/lib/ulm:src/lib/ulm/$(TARCH):src/lib/ooc2:src/lib/ooc2/$(TOS)/$(CCOMP):src/lib/ooc:src/lib/ooc/$(TOS)/$(CCOMP)/$(TARCH):src/lib/pow:src/lib/misc:src/lib/s3:src/voc:src/voc/$(TOS)/$(CCOMP):src/voc/$(TOS)/$(CCOMP)/$(TARCH):src/tools/ocat:src/tools/browser:src/tools/vocparam:src/tools/vmake:src/tools/coco:src/test
|
||||
|
||||
VOC = voc
|
||||
VERSION = $(TOS).$(CCOMP).$(TARCH)
|
||||
|
|
@ -22,18 +20,15 @@ LIBNAME = VishapOberon
|
|||
LIBRARY = lib$(LIBNAME)
|
||||
|
||||
ifndef PRF
|
||||
#PRF = "/opt"
|
||||
PRF = "/Users/noch/local/voc"
|
||||
PRF = "/opt"
|
||||
endif
|
||||
PREFIX = $(PRF)/voc-$(RELEASE)
|
||||
PREFIXLN = $(PRF)/voc
|
||||
|
||||
|
||||
CCOPT = -fPIC $(ADDITIONALFLAGS) $(INCLUDEPATH) -g
|
||||
CCOPT = -fPIC $(INCLUDEPATH) -g
|
||||
|
||||
CC = cc $(CCOPT) -c
|
||||
CL = cc $(CCOPT)
|
||||
#LD = cc -shared -o $(LIBRARY).so
|
||||
LD = cc -dynamiclib -o $(LIBRARY).dylib
|
||||
# s is necessary to create index inside a archive
|
||||
ARCHIVE = ar rcs $(LIBRARY).a
|
||||
|
|
@ -83,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -102,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) voc.c -o voc \
|
||||
$(CL) voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -159,7 +161,7 @@ stage6:
|
|||
$(VOCSTATIC) -sP oocFilenames.Mod
|
||||
$(VOCSTATIC) -sP oocwrapperlibc.Mod
|
||||
$(VOCSTATIC) -sP oocC.Mod
|
||||
#no X11 under macosx
|
||||
#no X11 on macosx
|
||||
#$(VOCSTATIC) -sP oocX11.Mod
|
||||
#$(VOCSTATIC) -sP oocXutil.Mod
|
||||
#$(VOCSTATIC) -sP oocXYplane.Mod
|
||||
|
|
@ -220,13 +222,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -256,27 +251,27 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
#$(ARCHIVE) objects
|
||||
$(LD) *.o
|
||||
### echo "$(PREFIX)/lib" > 05vishap.conf
|
||||
echo "$(PREFIX)/lib" > 05vishap.conf
|
||||
|
||||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.dylib
|
||||
|
||||
|
|
@ -293,13 +288,13 @@ install:
|
|||
test -d $(PREFIX)/lib/voc/obj | mkdir -p $(PREFIX)/lib/voc/obj
|
||||
test -d $(PREFIX)/lib/voc/sym | mkdir -p $(PREFIX)/lib/voc/sym
|
||||
|
||||
cp $(LIBRARY).so $(PREFIX)/lib
|
||||
cp $(LIBRARY).dylib $(PREFIX)/lib
|
||||
cp $(LIBRARY).a $(PREFIX)/lib
|
||||
cp *.c $(PREFIX)/lib/voc/obj/
|
||||
cp *.h $(PREFIX)/lib/voc/obj/
|
||||
cp *.sym $(PREFIX)/lib/voc/sym/
|
||||
|
||||
cp 05vishap.conf /etc/ld.so.conf.d/
|
||||
#cp 05vishap.conf /etc/ld.so.conf.d/
|
||||
ldconfig
|
||||
ln -s $(PREFIX) $(PREFIXLN)
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
|
|
@ -78,10 +78,9 @@ stage3:
|
|||
$(VOCSTATIC0) -sPS Args.Mod Console.Mod Unix.Mod
|
||||
sed -i.tmp "s#/opt#$(PRF)#g" src/voc/prf.Mod
|
||||
$(VOCSTATIC0) -sPS prf.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files.Mod
|
||||
$(VOCSTATIC0) -sxPS OakFiles.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod CmdlnTexts.Mod errors.Mod
|
||||
$(VOCSTATIC0) -sPS oocOakStrings.Mod architecture.Mod version.Mod Kernel0.Mod Modules.Mod
|
||||
$(VOCSTATIC0) -sxPS Files0.Mod
|
||||
$(VOCSTATIC0) -sPS Reals.Mod Texts0.Mod errors.Mod
|
||||
|
||||
# build the compiler
|
||||
stage4:
|
||||
|
|
@ -97,24 +96,32 @@ stage4:
|
|||
#this is a way to create a bootstrap binary.
|
||||
stage5:
|
||||
$(CC) SYSTEM.c Args.c Console.c Modules.c Unix.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel.c Files.c OakFiles.c Reals.c CmdlnTexts.c \
|
||||
oocOakStrings.c architecture.c prf.c version.c Kernel0.c Files0.c Reals.c Texts0.c \
|
||||
extTools.c \
|
||||
OPM.c OPS.c OPT.c OPC.c OPV.c OPB.c OPP.c errors.c
|
||||
|
||||
$(CL) -static voc.c -o voc \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
extTools.o \
|
||||
OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
$(CL) BrowserCmd.c -o showdef \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o \
|
||||
OPM.o OPS.o OPT.o OPV.o OPC.o errors.o
|
||||
|
||||
$(CL) OCatCmd.c -o ocat \
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel.o Files.o Reals.o CmdlnTexts.o
|
||||
SYSTEM.o Args.o Console.o Modules.o Unix.o oocOakStrings.o architecture.o prf.o version.o Kernel0.o Files0.o Reals.o Texts0.o
|
||||
|
||||
# build all library files
|
||||
stage6:
|
||||
#v4 libs
|
||||
$(VOCSTATIC) -sP Kernel.Mod
|
||||
$(VOCSTATIC) -sP Files.Mod
|
||||
$(VOCSTATIC) -sP Texts.Mod
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
|
||||
#ooc libs
|
||||
$(VOCSTATIC) -sP oocAscii.Mod
|
||||
|
|
@ -214,13 +221,6 @@ stage6:
|
|||
$(VOCSTATIC) -sP ulmRandomGenerators.Mod
|
||||
$(VOCSTATIC) -sP ulmTCrypt.Mod
|
||||
|
||||
#more v4 libs
|
||||
$(VOCSTATIC) -sP Printer.Mod
|
||||
$(VOCSTATIC) -sP Strings.Mod
|
||||
$(VOCSTATIC) -sP Sets.Mod
|
||||
$(VOCSTATIC) -sP Sets0.Mod
|
||||
$(VOCSTATIC) -sP compatIn.Mod
|
||||
|
||||
#pow32 libs
|
||||
$(VOCSTATIC) -sP powStrings.Mod
|
||||
|
||||
|
|
@ -250,13 +250,13 @@ stage6:
|
|||
# $(VOCSTATIC0) -sPS compatIn.Mod
|
||||
# $(VOCSTATIC0) -smPS vmake.Mod
|
||||
# $(CC) compatIn.c
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o CmdlnTexts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o prf.o version.o architecture.o
|
||||
# $(CL) vmake.c -o vmake SYSTEM.o Args.o compatIn.o Texts.o Console.o Files.o Reals.o Modules.o Kernel.o Unix.o oocOakStrings.o oocIntStr.o oocConvTypes.o oocIntConv.o
|
||||
|
||||
|
||||
|
||||
stage7:
|
||||
#remove non library objects
|
||||
rm -f architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
rm -f Kernel0.o Files0.o Texts0.o architecture.o prf.o version.o extTools.o OPM.o OPS.o OPT.o OPC.o OPV.o OPB.o OPP.o errors.o
|
||||
#objects := $(wildcard *.o)
|
||||
#$(LD) objects
|
||||
$(ARCHIVE) *.o
|
||||
|
|
@ -267,10 +267,10 @@ stage7:
|
|||
clean:
|
||||
# rm_objects := rm $(wildcard *.o)
|
||||
# objects
|
||||
rm *.o
|
||||
rm *.sym
|
||||
rm *.h
|
||||
rm *.c
|
||||
rm *.sym
|
||||
rm *.o
|
||||
rm *.a
|
||||
rm *.so
|
||||
|
||||
|
|
|
|||
BIN
ocat
BIN
ocat
Binary file not shown.
|
|
@ -1 +1 @@
|
|||
a8fbd8d35e5afe88b33765d1df1c959f37ef7541
|
||||
03332b4fdd5e4e54908279b12a66a2e0bbd7f202
|
||||
|
|
@ -1,5 +1,5 @@
|
|||
MODULE oocRts; (* module is written from scratch by noch to wrap around Unix.Mod and Args.Mod and provide compatibility for some ooc libraries *)
|
||||
IMPORT Args, Unix, Files := OakFiles, Strings := oocStrings(*, Console*);
|
||||
IMPORT Args, Unix, Files, Strings := oocStrings(*, Console*);
|
||||
CONST
|
||||
pathSeperator* = "/";
|
||||
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
Refer to the "General ETH Oberon System Source License" contract available at: http://www.oberon.ethz.ch/ *)
|
||||
|
||||
MODULE ethBTrees; (** portable *) (* ejz, *)
|
||||
IMPORT Files := OakFiles;
|
||||
IMPORT Files;
|
||||
|
||||
(** BTrees is a utility module that manages b-trees with string (64 characters) or longint keys. Each key is linked to
|
||||
a longint value (org) which normaly is an offset to where the data for that key is stored. *)
|
||||
|
|
|
|||
|
|
@ -8,7 +8,7 @@ MODULE ethGZReaders; (** Stefan Walthert **)
|
|||
**)
|
||||
|
||||
IMPORT
|
||||
Files := OakFiles, ZlibReaders := ethZlibReaders;
|
||||
Files, ZlibReaders := ethZlibReaders;
|
||||
|
||||
|
||||
CONST
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ Refer to the "General ETH Oberon System Source License" contract available at: h
|
|||
MODULE ethGZWriters; (** Stefan Walthert **)
|
||||
|
||||
IMPORT
|
||||
Files := OakFiles, ZlibWriters := ethZlibWriters;
|
||||
Files, ZlibWriters := ethZlibWriters;
|
||||
|
||||
CONST
|
||||
(** result codes **)
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@ Refer to the "General ETH Oberon System Source License" contract available at: h
|
|||
|
||||
MODULE ethSets; (** portable *)
|
||||
|
||||
IMPORT Texts := CmdlnTexts;
|
||||
IMPORT Texts;
|
||||
|
||||
CONST size* = SIZE(LONGINT)* 8(*32*);
|
||||
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ Refer to the "General ETH Oberon System Source License" contract available at: h
|
|||
MODULE ethZip; (** Stefan Walthert **)
|
||||
|
||||
IMPORT
|
||||
Files := OakFiles, Zlib := ethZlib, ZlibReaders := ethZlibReaders, ZlibWriters := ethZlibWriters;
|
||||
Files, Zlib := ethZlib, ZlibReaders := ethZlibReaders, ZlibWriters := ethZlibWriters;
|
||||
|
||||
CONST
|
||||
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ Refer to the "General ETH Oberon System Source License" contract available at: h
|
|||
MODULE ethZlibReaders; (** Stefan Walthert **)
|
||||
|
||||
IMPORT
|
||||
Files := OakFiles, Zlib := ethZlib, ZlibBuffers := ethZlibBuffers, ZlibInflate := ethZlibInflate;
|
||||
Files, Zlib := ethZlib, ZlibBuffers := ethZlibBuffers, ZlibInflate := ethZlibInflate;
|
||||
|
||||
CONST
|
||||
(** result codes **)
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ Refer to the "General ETH Oberon System Source License" contract available at: h
|
|||
MODULE ethZlibWriters; (** Stefan Walthert **)
|
||||
|
||||
IMPORT
|
||||
Files := OakFiles, Zlib := ethZlib, ZlibBuffers := ethZlibBuffers, ZlibDeflate := ethZlibDeflate;
|
||||
Files, Zlib := ethZlib, ZlibBuffers := ethZlibBuffers, ZlibDeflate := ethZlibDeflate;
|
||||
|
||||
CONST
|
||||
(** result codes **)
|
||||
|
|
|
|||
|
|
@ -1,5 +1,5 @@
|
|||
MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
|
||||
(* modified version of Files, which opens only the file provided and does not scan any path in any environment variable, also ReadLine procedure added; -- noch *)
|
||||
IMPORT SYSTEM, Unix, Kernel, Args, Console;
|
||||
|
||||
(* standard data type I/O
|
||||
|
|
@ -66,10 +66,6 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
PROCEDURE -includetime()
|
||||
'#include "time.h"';
|
||||
|
||||
(* for getcwd() *)
|
||||
PROCEDURE -includeUnistd()
|
||||
'#include <unistd.h>';
|
||||
|
||||
PROCEDURE -localtime(VAR clock: LONGINT): Time
|
||||
"(Files_Time) localtime(clock)";
|
||||
|
||||
|
|
@ -189,7 +185,7 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
f.fd := noDesc; f.state := create; f.len := 0; f.pos := 0; f.swapper := -1; (*all f.buf[i] = NIL*)
|
||||
RETURN f
|
||||
END New;
|
||||
|
||||
(*
|
||||
PROCEDURE ScanPath(VAR pos: INTEGER; VAR dir: ARRAY OF CHAR); (* supports ~, ~user and blanks inside path *)
|
||||
VAR i: INTEGER; ch: CHAR; home: ARRAY 256 OF CHAR;
|
||||
BEGIN
|
||||
|
|
@ -207,7 +203,7 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
WHILE (i > 0) & (dir[i-1] = " ") DO DEC(i) END ;
|
||||
dir[i] := 0X
|
||||
END ScanPath;
|
||||
|
||||
*)
|
||||
PROCEDURE HasDir(VAR name: ARRAY OF CHAR): BOOLEAN;
|
||||
VAR i: INTEGER; ch: CHAR;
|
||||
BEGIN i := 0; ch := name[0];
|
||||
|
|
@ -243,7 +239,10 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
BEGIN
|
||||
IF name # "" THEN
|
||||
IF HasDir(name) THEN dir := ""; COPY(name, path)
|
||||
ELSE pos := 0; ScanPath(pos, dir); MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
ELSE
|
||||
pos := 0;
|
||||
COPY(name, path); (* -- noch *)
|
||||
(*ScanPath(pos, dir);*) (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
END ;
|
||||
LOOP
|
||||
fd := Unix.Open(path, Unix.rdwr, {}); done := fd >= 0; errno := Unix.errno();
|
||||
|
|
@ -274,7 +273,8 @@ END ;
|
|||
RETURN f
|
||||
END
|
||||
ELSIF dir = "" THEN RETURN NIL
|
||||
ELSE MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
ELSE (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
RETURN NIL
|
||||
END
|
||||
END
|
||||
ELSE RETURN NIL
|
||||
|
|
@ -392,6 +392,11 @@ END ;
|
|||
r.offset := offset + 1; r.res := 0
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteByte* (VAR r : Rider; x : SYSTEM.BYTE); (* added for compatibility with PO 2013, -- noch *)
|
||||
BEGIN
|
||||
Write(r, x);
|
||||
END WriteByte;
|
||||
|
||||
PROCEDURE WriteBytes* (VAR r: Rider; VAR x: ARRAY OF SYSTEM.BYTE; n: LONGINT);
|
||||
VAR xpos, min, restInBuf, offset: LONGINT; buf: Buffer;
|
||||
BEGIN
|
||||
|
|
@ -427,6 +432,7 @@ BEGIN
|
|||
buf.data[offset] := x; r.offset := offset + 1; buf.chg := TRUE
|
||||
END Write;
|
||||
|
||||
|
||||
PROCEDURE WriteBytes ...
|
||||
|
||||
PROCEDURE Read* (VAR r: Rider; VAR x: SYSTEM.BYTE);
|
||||
|
|
@ -554,7 +560,23 @@ Especially Length would become fairly complex.
|
|||
BEGIN i := 0;
|
||||
REPEAT Read(R, ch); x[i] := ch; INC(i) UNTIL ch = 0X
|
||||
END ReadString;
|
||||
|
||||
|
||||
(* need to read line; -- noch *)
|
||||
PROCEDURE ReadLine* (VAR R: Rider; VAR x: ARRAY OF CHAR);
|
||||
VAR i: INTEGER; ch: CHAR; b : BOOLEAN;
|
||||
BEGIN i := 0;
|
||||
b := FALSE;
|
||||
REPEAT
|
||||
Read(R, ch);
|
||||
IF ((ch = 0X) OR (ch = 0AX) OR (ch = 0DX)) THEN
|
||||
b := TRUE
|
||||
ELSE
|
||||
x[i] := ch;
|
||||
INC(i);
|
||||
END;
|
||||
UNTIL b
|
||||
END ReadLine;
|
||||
|
||||
PROCEDURE ReadNum* (VAR R: Rider; VAR x: LONGINT);
|
||||
VAR s: SHORTINT; ch: CHAR; n: LONGINT;
|
||||
BEGIN s := 0; n := 0; Read(R, ch);
|
||||
|
|
@ -610,6 +632,11 @@ Especially Length would become fairly complex.
|
|||
Write(R, CHR(x MOD 128))
|
||||
END WriteNum;
|
||||
|
||||
PROCEDURE GetName*(f: File; VAR name: ARRAY OF CHAR);
|
||||
BEGIN
|
||||
COPY (f.workName, name);
|
||||
END GetName;
|
||||
|
||||
PROCEDURE Finalize(o: SYSTEM.PTR);
|
||||
VAR f: File; res: LONGINT;
|
||||
BEGIN
|
||||
|
|
|
|||
|
|
@ -1,6 +1,9 @@
|
|||
MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
(* modified version of Files, which opens only the file provided and does not scan any path in any environment variable, also ReadLine procedure added; -- noch *)
|
||||
IMPORT SYSTEM, Unix, Kernel, Args, Console;
|
||||
MODULE Files0; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
|
||||
(* this module is not for use by developers and inteded to bootstrap voc *)
|
||||
(* for general use import Files module *)
|
||||
|
||||
IMPORT SYSTEM, Unix, Kernel := Kernel0, Args, Console;
|
||||
|
||||
(* standard data type I/O
|
||||
|
||||
|
|
@ -67,7 +70,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
'#include "time.h"';
|
||||
|
||||
PROCEDURE -localtime(VAR clock: LONGINT): Time
|
||||
"(OakFiles_Time) localtime(clock)";
|
||||
"(Files0_Time) localtime(clock)";
|
||||
|
||||
PROCEDURE -getcwd(VAR cwd: Unix.Name)
|
||||
"getcwd(cwd, cwd__len)";
|
||||
|
|
@ -185,7 +188,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
f.fd := noDesc; f.state := create; f.len := 0; f.pos := 0; f.swapper := -1; (*all f.buf[i] = NIL*)
|
||||
RETURN f
|
||||
END New;
|
||||
(*
|
||||
|
||||
PROCEDURE ScanPath(VAR pos: INTEGER; VAR dir: ARRAY OF CHAR); (* supports ~, ~user and blanks inside path *)
|
||||
VAR i: INTEGER; ch: CHAR; home: ARRAY 256 OF CHAR;
|
||||
BEGIN
|
||||
|
|
@ -203,7 +206,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
WHILE (i > 0) & (dir[i-1] = " ") DO DEC(i) END ;
|
||||
dir[i] := 0X
|
||||
END ScanPath;
|
||||
*)
|
||||
|
||||
PROCEDURE HasDir(VAR name: ARRAY OF CHAR): BOOLEAN;
|
||||
VAR i: INTEGER; ch: CHAR;
|
||||
BEGIN i := 0; ch := name[0];
|
||||
|
|
@ -239,10 +242,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
BEGIN
|
||||
IF name # "" THEN
|
||||
IF HasDir(name) THEN dir := ""; COPY(name, path)
|
||||
ELSE
|
||||
pos := 0;
|
||||
COPY(name, path); (* -- noch *)
|
||||
(*ScanPath(pos, dir);*) (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
ELSE pos := 0; ScanPath(pos, dir); MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
END ;
|
||||
LOOP
|
||||
fd := Unix.Open(path, Unix.rdwr, {}); done := fd >= 0; errno := Unix.errno();
|
||||
|
|
@ -258,7 +258,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
fd := Unix.Open(path, Unix.rdonly, {}); done := fd >= 0; errno := Unix.errno()
|
||||
END ;
|
||||
IF (~done) & (errno # Unix.ENOENT) THEN
|
||||
Console.String("warning Files.Old "); Console.String(name);
|
||||
Console.String("warning Files0.Old "); Console.String(name);
|
||||
Console.String(" errno = "); Console.Int(errno, 0); Console.Ln;
|
||||
END ;
|
||||
IF done THEN
|
||||
|
|
@ -273,8 +273,7 @@ END ;
|
|||
RETURN f
|
||||
END
|
||||
ELSIF dir = "" THEN RETURN NIL
|
||||
ELSE (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
RETURN NIL
|
||||
ELSE MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
END
|
||||
END
|
||||
ELSE RETURN NIL
|
||||
|
|
@ -392,11 +391,6 @@ END ;
|
|||
r.offset := offset + 1; r.res := 0
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteByte* (VAR r : Rider; x : SYSTEM.BYTE); (* added for compatibility with PO 2013, -- noch *)
|
||||
BEGIN
|
||||
Write(r, x);
|
||||
END WriteByte;
|
||||
|
||||
PROCEDURE WriteBytes* (VAR r: Rider; VAR x: ARRAY OF SYSTEM.BYTE; n: LONGINT);
|
||||
VAR xpos, min, restInBuf, offset: LONGINT; buf: Buffer;
|
||||
BEGIN
|
||||
|
|
@ -432,7 +426,6 @@ BEGIN
|
|||
buf.data[offset] := x; r.offset := offset + 1; buf.chg := TRUE
|
||||
END Write;
|
||||
|
||||
|
||||
PROCEDURE WriteBytes ...
|
||||
|
||||
PROCEDURE Read* (VAR r: Rider; VAR x: SYSTEM.BYTE);
|
||||
|
|
@ -560,23 +553,7 @@ Especially Length would become fairly complex.
|
|||
BEGIN i := 0;
|
||||
REPEAT Read(R, ch); x[i] := ch; INC(i) UNTIL ch = 0X
|
||||
END ReadString;
|
||||
|
||||
(* need to read line; -- noch *)
|
||||
PROCEDURE ReadLine* (VAR R: Rider; VAR x: ARRAY OF CHAR);
|
||||
VAR i: INTEGER; ch: CHAR; b : BOOLEAN;
|
||||
BEGIN i := 0;
|
||||
b := FALSE;
|
||||
REPEAT
|
||||
Read(R, ch);
|
||||
IF ((ch = 0X) OR (ch = 0AX) OR (ch = 0DX)) THEN
|
||||
b := TRUE
|
||||
ELSE
|
||||
x[i] := ch;
|
||||
INC(i);
|
||||
END;
|
||||
UNTIL b
|
||||
END ReadLine;
|
||||
|
||||
|
||||
PROCEDURE ReadNum* (VAR R: Rider; VAR x: LONGINT);
|
||||
VAR s: SHORTINT; ch: CHAR; n: LONGINT;
|
||||
BEGIN s := 0; n := 0; Read(R, ch);
|
||||
|
|
@ -632,11 +609,6 @@ Especially Length would become fairly complex.
|
|||
Write(R, CHR(x MOD 128))
|
||||
END WriteNum;
|
||||
|
||||
PROCEDURE GetName*(f: File; VAR name: ARRAY OF CHAR);
|
||||
BEGIN
|
||||
COPY (f.workName, name);
|
||||
END GetName;
|
||||
|
||||
PROCEDURE Finalize(o: SYSTEM.PTR);
|
||||
VAR f: File; res: LONGINT;
|
||||
BEGIN
|
||||
|
|
@ -655,4 +627,4 @@ Especially Length would become fairly complex.
|
|||
END Init;
|
||||
|
||||
BEGIN Init
|
||||
END OakFiles.
|
||||
END Files0.
|
||||
|
|
@ -4,13 +4,12 @@ MODULE Kernel;
|
|||
communication with C-runtime and storage management
|
||||
*)
|
||||
|
||||
IMPORT SYSTEM, Unix, Args, Strings := oocOakStrings, version;
|
||||
IMPORT SYSTEM, Unix, Args;
|
||||
|
||||
TYPE
|
||||
RealTime = POINTER TO TimeDesc;
|
||||
TimeDesc = RECORD
|
||||
sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: LONGINT
|
||||
(* sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: INTEGER*)
|
||||
END ;
|
||||
|
||||
KeyCmd* = PROCEDURE;
|
||||
|
|
@ -36,20 +35,15 @@ MODULE Kernel;
|
|||
|
||||
LIB*, CWD*: ARRAY 256 OF CHAR;
|
||||
OBERON*: ARRAY 1024 OF CHAR;
|
||||
MODULES-: ARRAY 1024 OF CHAR;
|
||||
|
||||
prefix*, fullprefix* : ARRAY 256 OF CHAR;
|
||||
|
||||
timeStart: LONGINT; (* milliseconds *)
|
||||
|
||||
|
||||
PROCEDURE -includesetjmp()
|
||||
'#include "setjmp.h"';
|
||||
(* for localtime *)
|
||||
PROCEDURE -includetime()
|
||||
'#include "time.h"';
|
||||
(* for getcwd() *)
|
||||
PROCEDURE -includeUnistd()
|
||||
'#include <unistd.h>';
|
||||
|
||||
PROCEDURE -Lock*()
|
||||
"SYSTEM_lock++";
|
||||
|
|
@ -61,13 +55,13 @@ MODULE Kernel;
|
|||
"exit(n)";
|
||||
|
||||
PROCEDURE -sigsetjmp*(VAR env: Unix.JmpBuf; savemask: LONGINT): LONGINT
|
||||
"__sigsetjmp(env, savemask)";
|
||||
"__sigsetjmp(env, savemask)";
|
||||
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix.JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix. JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
|
||||
PROCEDURE -heapsize*(): LONGINT
|
||||
"SYSTEM_heapsize";
|
||||
"SYSTEM_heapsize";
|
||||
|
||||
PROCEDURE -allocated*(): LONGINT
|
||||
"SYSTEM_allocated";
|
||||
|
|
@ -166,16 +160,8 @@ BEGIN
|
|||
EndianTest();
|
||||
SetHalt(Halt);
|
||||
CWD := ""; OBERON := "."; LIB := "";
|
||||
MODULES := ""; (* additional modules path which can be specified on commandline and will be added to the OBERON variable; noch *)
|
||||
getcwd(CWD);
|
||||
Args.GetEnv ("MODULES", MODULES);
|
||||
Args.GetEnv("OBERON", OBERON);
|
||||
(* always have current directory in module search path, noch *)
|
||||
Strings.Append(":.:", OBERON);
|
||||
Strings.Append(MODULES, OBERON);
|
||||
Strings.Append(":", OBERON);
|
||||
Strings.Append(version.prefix, OBERON);
|
||||
Strings.Append("/lib/voc/sym:", OBERON);
|
||||
Args.GetEnv("OBERON_LIB", LIB);
|
||||
TimeUnit := 1000; timeStart := 0; timeStart := Time()
|
||||
END Kernel.
|
||||
|
|
|
|||
179
src/lib/system/darwin/clang/Kernel0.Mod
Normal file
179
src/lib/system/darwin/clang/Kernel0.Mod
Normal file
|
|
@ -0,0 +1,179 @@
|
|||
MODULE Kernel0;
|
||||
(*
|
||||
J. Templ, 16.4.95
|
||||
communication with C-runtime and storage management
|
||||
*)
|
||||
(* version for bootstrapping voc *)
|
||||
|
||||
IMPORT SYSTEM, Unix, Args, Strings := oocOakStrings, version;
|
||||
|
||||
TYPE
|
||||
RealTime = POINTER TO TimeDesc;
|
||||
TimeDesc = RECORD
|
||||
sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: LONGINT
|
||||
(* sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: INTEGER*)
|
||||
END ;
|
||||
|
||||
KeyCmd* = PROCEDURE;
|
||||
|
||||
ObjFinalizer* = PROCEDURE(obj: SYSTEM.PTR);
|
||||
|
||||
|
||||
VAR
|
||||
(* trap handling *)
|
||||
trapEnv*: Unix.JmpBuf; (* saved stack environment for trap handling *)
|
||||
|
||||
(* oberon heap management *)
|
||||
nofiles*: LONGINT;
|
||||
|
||||
(* input event handling *)
|
||||
readSet*, readySet*: Unix.FdSet;
|
||||
|
||||
FKey*: ARRAY 16 OF KeyCmd;
|
||||
|
||||
littleEndian*: BOOLEAN;
|
||||
|
||||
TimeUnit*: LONGINT; (* 1 sec *)
|
||||
|
||||
LIB*, CWD*: ARRAY 256 OF CHAR;
|
||||
OBERON*: ARRAY 1024 OF CHAR;
|
||||
MODULES-: ARRAY 1024 OF CHAR;
|
||||
|
||||
prefix*, fullprefix* : ARRAY 256 OF CHAR;
|
||||
timeStart: LONGINT; (* milliseconds *)
|
||||
|
||||
|
||||
PROCEDURE -includesetjmp()
|
||||
'#include "setjmp.h"';
|
||||
(* for localtime *)
|
||||
PROCEDURE -includetime()
|
||||
'#include "time.h"';
|
||||
|
||||
PROCEDURE -Lock*()
|
||||
"SYSTEM_lock++";
|
||||
|
||||
PROCEDURE -Unlock*()
|
||||
"SYSTEM_lock--; if (SYSTEM_interrupted && SYSTEM_lock == 0) __HALT(-9)";
|
||||
|
||||
PROCEDURE -Exit*(n: LONGINT)
|
||||
"exit(n)";
|
||||
|
||||
PROCEDURE -sigsetjmp*(VAR env: Unix.JmpBuf; savemask: LONGINT): LONGINT
|
||||
"__sigsetjmp(env, savemask)";
|
||||
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix.JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
|
||||
PROCEDURE -heapsize*(): LONGINT
|
||||
"SYSTEM_heapsize";
|
||||
|
||||
PROCEDURE -allocated*(): LONGINT
|
||||
"SYSTEM_allocated";
|
||||
|
||||
PROCEDURE -localtime(VAR clock: LONGINT): RealTime
|
||||
"(Kernel0_RealTime)localtime(clock)";
|
||||
|
||||
PROCEDURE -malloc*(size: LONGINT): LONGINT
|
||||
"(LONGINT)malloc(size)";
|
||||
|
||||
PROCEDURE -free*(adr: LONGINT)
|
||||
"(void)free(adr)";
|
||||
|
||||
PROCEDURE -getcwd(VAR cwd: Unix.Name)
|
||||
"getcwd(cwd, cwd__len)";
|
||||
|
||||
|
||||
PROCEDURE GetClock* (VAR t, d: LONGINT);
|
||||
VAR tv: Unix.Timeval; tz: Unix.Timezone; time: RealTime;
|
||||
l : LONGINT;
|
||||
BEGIN
|
||||
l := Unix.Gettimeofday(tv, tz);
|
||||
time := localtime(tv.sec);
|
||||
t := time.sec + ASH(time.min, 6) + ASH(time.hour, 12);
|
||||
d := time.mday + ASH(time.mon+1, 5) + ASH(time.year MOD 100, 9);
|
||||
END GetClock;
|
||||
|
||||
PROCEDURE SetClock* (t, d: LONGINT);
|
||||
VAR err: ARRAY 25 OF CHAR;
|
||||
BEGIN err := "not yet implemented"; HALT(99)
|
||||
END SetClock;
|
||||
|
||||
PROCEDURE Time*(): LONGINT;
|
||||
VAR timeval: Unix.Timeval; timezone: Unix.Timezone;
|
||||
l : LONGINT;
|
||||
BEGIN
|
||||
l := Unix.Gettimeofday(timeval, timezone);
|
||||
RETURN (timeval.usec DIV 1000 + timeval.sec * 1000 - timeStart) MOD 7FFFFFFFH
|
||||
END Time;
|
||||
|
||||
(*
|
||||
PROCEDURE UserTime*(): LONGINT;
|
||||
VAR rusage: Unix.Rusage;
|
||||
BEGIN
|
||||
Unix.Getrusage(0, S.ADR(rusage));
|
||||
RETURN rusage.utime.sec*1000 + rusage.utime.usec DIV 1000
|
||||
(* + rusage.stime.sec*1000 + rusage.stime.usec DIV 1000*)
|
||||
END UserTime;
|
||||
*)
|
||||
|
||||
PROCEDURE Select*(delay: LONGINT);
|
||||
VAR rs, ws, xs: Unix.FdSet; n: LONGINT; tv: Unix.Timeval;
|
||||
BEGIN
|
||||
rs := readSet;
|
||||
FOR n := 0 TO 7 DO ws[n] := {}; xs[n] := {}; readySet[n] := {} END;
|
||||
IF delay < 0 THEN delay := 0 END ;
|
||||
tv.sec := delay DIV 1000; tv.usec := delay MOD 1000 * 1000;
|
||||
n := Unix.Select(256, rs, ws, xs, tv);
|
||||
IF n >= 0 THEN readySet := rs END
|
||||
END Select;
|
||||
|
||||
PROCEDURE -GC*(markStack: BOOLEAN)
|
||||
"SYSTEM_GC(markStack)";
|
||||
|
||||
PROCEDURE -RegisterObject*(obj: SYSTEM.PTR; finalize: ObjFinalizer)
|
||||
"SYSTEM_REGFIN(obj, finalize)";
|
||||
|
||||
PROCEDURE -SetHalt*(p: PROCEDURE(n: LONGINT))
|
||||
"SYSTEM_Halt = p";
|
||||
|
||||
PROCEDURE InstallTermHandler*(p: PROCEDURE);
|
||||
(* not yet supported; no Modules.Free *)
|
||||
END InstallTermHandler;
|
||||
|
||||
PROCEDURE LargestAvailable*(): LONGINT;
|
||||
BEGIN
|
||||
(* dummy proc for System 3 compatibility
|
||||
no meaningful value except may be the remaining swap space can be returned
|
||||
in the context of an extensible heap *)
|
||||
RETURN MAX(LONGINT)
|
||||
END LargestAvailable;
|
||||
|
||||
PROCEDURE Halt(n: LONGINT);
|
||||
VAR res: LONGINT;
|
||||
BEGIN res := Unix.Kill(Unix.Getpid(), 4);
|
||||
END Halt;
|
||||
|
||||
PROCEDURE EndianTest;
|
||||
VAR i: LONGINT; dmy: INTEGER;
|
||||
BEGIN
|
||||
dmy := 1; i := SYSTEM.ADR(dmy);
|
||||
SYSTEM.GET(i, littleEndian); (* indirection via i avoids warning on SUN cc -O *)
|
||||
END EndianTest;
|
||||
|
||||
BEGIN
|
||||
EndianTest();
|
||||
SetHalt(Halt);
|
||||
CWD := ""; OBERON := "."; LIB := "";
|
||||
MODULES := ""; (* additional modules path which can be specified on commandline and will be added to the OBERON variable; noch *)
|
||||
getcwd(CWD);
|
||||
Args.GetEnv ("MODULES", MODULES);
|
||||
Args.GetEnv("OBERON", OBERON);
|
||||
(* always have current directory in module search path, noch *)
|
||||
Strings.Append(":.:", OBERON);
|
||||
Strings.Append(MODULES, OBERON);
|
||||
Strings.Append(":", OBERON);
|
||||
Strings.Append(version.prefix, OBERON);
|
||||
Strings.Append("/lib/voc/sym:", OBERON);
|
||||
Args.GetEnv("OBERON_LIB", LIB);
|
||||
TimeUnit := 1000; timeStart := 0; timeStart := Time()
|
||||
END Kernel0.
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
MODULE CmdlnTexts; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12.91**) (* << RC, MB, JT *)
|
||||
MODULE Texts; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12.91**) (* << RC, MB, JT *)
|
||||
IMPORT
|
||||
Files, Modules, Reals;
|
||||
|
||||
|
|
@ -856,4 +856,4 @@ MODULE CmdlnTexts; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12
|
|||
END Close;
|
||||
|
||||
BEGIN del := NIL; NEW(FontsDefault); FontsDefault.name := "Syntax10.Scn.Fnt"
|
||||
END CmdlnTexts.
|
||||
END Texts.
|
||||
859
src/lib/system/darwin/clang/Texts0.Mod
Normal file
859
src/lib/system/darwin/clang/Texts0.Mod
Normal file
|
|
@ -0,0 +1,859 @@
|
|||
MODULE Texts0; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12.91**) (* << RC, MB, JT *)
|
||||
IMPORT
|
||||
Files := Files0, Modules, Reals;
|
||||
|
||||
(*--- insert field e: Elem into Texts.Scanner and change Texts.Scan to set it in case of class=6 *)
|
||||
(* this module is for bootstrapping voc, use Texts instead *)
|
||||
|
||||
CONST
|
||||
Displaywhite = 15;
|
||||
ElemChar* = 1CX;
|
||||
TAB = 9X; CR = 0DX; maxD = 9;
|
||||
(**FileMsg.id**)
|
||||
load* = 0; store* = 1;
|
||||
(**Notifier op**)
|
||||
replace* = 0; insert* = 1; delete* = 2;
|
||||
(**Scanner.class**)
|
||||
Inval* = 0; Name* = 1; String* = 2; Int* = 3; Real* = 4; LongReal* = 5; Char* = 6;
|
||||
|
||||
textTag = 0F0X; DocBlockId = 0F7X; version = 01X;
|
||||
|
||||
TYPE
|
||||
FontsFont = POINTER TO FontDesc;
|
||||
FontDesc = RECORD
|
||||
name: ARRAY 32 OF CHAR;
|
||||
END ;
|
||||
|
||||
Run = POINTER TO RunDesc;
|
||||
RunDesc = RECORD
|
||||
prev, next: Run;
|
||||
len: LONGINT;
|
||||
fnt: FontsFont;
|
||||
col, voff: SHORTINT;
|
||||
ascii: BOOLEAN (* << *)
|
||||
END;
|
||||
|
||||
Piece = POINTER TO PieceDesc;
|
||||
PieceDesc = RECORD (RunDesc)
|
||||
file: Files.File;
|
||||
org: LONGINT
|
||||
END;
|
||||
|
||||
Elem* = POINTER TO ElemDesc;
|
||||
Buffer* = POINTER TO BufDesc;
|
||||
Text* = POINTER TO TextDesc;
|
||||
|
||||
ElemMsg* = RECORD END;
|
||||
Handler* = PROCEDURE (e: Elem; VAR msg: ElemMsg);
|
||||
|
||||
ElemDesc* = RECORD (RunDesc)
|
||||
W*, H*: LONGINT;
|
||||
handle*: Handler;
|
||||
base: Text
|
||||
END;
|
||||
|
||||
FileMsg* = RECORD (ElemMsg)
|
||||
id*: INTEGER;
|
||||
pos*: LONGINT;
|
||||
r*: Files.Rider
|
||||
END;
|
||||
|
||||
CopyMsg* = RECORD (ElemMsg)
|
||||
e*: Elem
|
||||
END;
|
||||
|
||||
IdentifyMsg* = RECORD (ElemMsg)
|
||||
mod*, proc*: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
|
||||
BufDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head: Run
|
||||
END;
|
||||
|
||||
TextDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head, cache: Run;
|
||||
corg: LONGINT
|
||||
END;
|
||||
|
||||
Reader* = RECORD
|
||||
eot*: BOOLEAN;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
elem*: Elem;
|
||||
rider: Files.Rider;
|
||||
run: Run;
|
||||
org, off: LONGINT
|
||||
END;
|
||||
|
||||
Scanner* = RECORD (Reader)
|
||||
nextCh*: CHAR;
|
||||
line*, class*: INTEGER;
|
||||
i*: LONGINT;
|
||||
x*: REAL;
|
||||
y*: LONGREAL;
|
||||
c*: CHAR;
|
||||
len*: SHORTINT;
|
||||
s*: ARRAY 64 OF CHAR (* << *)
|
||||
END;
|
||||
|
||||
Writer* = RECORD
|
||||
buf*: Buffer;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
rider: Files.Rider;
|
||||
file: Files.File
|
||||
END;
|
||||
|
||||
Alien = POINTER TO RECORD (ElemDesc)
|
||||
file: Files.File;
|
||||
org, span: LONGINT;
|
||||
mod, proc: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
VAR
|
||||
new*: Elem;
|
||||
del: Buffer;
|
||||
FontsDefault: FontsFont;
|
||||
|
||||
|
||||
PROCEDURE FontsThis(VAR name: ARRAY OF CHAR): FontsFont;
|
||||
VAR F: FontsFont;
|
||||
BEGIN
|
||||
NEW(F); COPY(name, F.name); RETURN F
|
||||
END FontsThis;
|
||||
|
||||
(* run primitives *)
|
||||
|
||||
PROCEDURE Find (T: Text; VAR pos: LONGINT; VAR u: Run; VAR org, off: LONGINT);
|
||||
VAR v: Run; m: LONGINT;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len; u := T.head; org := T.len; off := 0; T.cache := T.head; T.corg := 0
|
||||
ELSE v := T.cache.next; m := pos - T.corg;
|
||||
IF pos >= T.corg THEN
|
||||
WHILE m >= v.len DO DEC(m, v.len); v := v.next END
|
||||
ELSE
|
||||
WHILE m < 0 DO v := v.prev; INC(m, v.len) END;
|
||||
END;
|
||||
u := v; org := pos - m; off := m; T.cache := v.prev; T.corg := org
|
||||
END
|
||||
END Find;
|
||||
|
||||
PROCEDURE Split (off: LONGINT; VAR u, un: Run);
|
||||
VAR p, U: Piece;
|
||||
BEGIN
|
||||
IF off = 0 THEN un := u; u := un.prev
|
||||
ELSIF off >= u.len THEN un := u.next
|
||||
ELSE NEW(p); un := p; U := u(Piece);
|
||||
p^ := U^; INC(p.org, off); DEC(p.len, off); DEC(U.len, p.len);
|
||||
p.ascii := u.ascii; p.prev := U; p.next := U.next; p.next.prev := p; U.next := p (* << *)
|
||||
END
|
||||
END Split;
|
||||
|
||||
PROCEDURE Merge (T: Text; u: Run; VAR v: Run);
|
||||
VAR p, q: Piece;
|
||||
BEGIN
|
||||
IF (u IS Piece) & (v IS Piece) & (u.fnt.name = v.fnt.name) & (u.col = v.col) & (u.voff = v.voff)
|
||||
& (u(Piece).ascii = v(Piece).ascii) THEN (* << *)
|
||||
p := u(Piece); q := v(Piece);
|
||||
IF (p.file = q.file) & (p.org + p.len = q.org) THEN
|
||||
IF T.cache = u THEN INC(T.corg, q.len)
|
||||
ELSIF T.cache = v THEN T.cache := T.head; T.corg := 0
|
||||
END;
|
||||
INC(p.len, q.len); v := v.next
|
||||
END
|
||||
END
|
||||
END Merge;
|
||||
|
||||
PROCEDURE Splice (un, v, w: Run; base: Text); (* (u, un) -> (u, v, w, un) *)
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF v # w.next THEN u := un.prev;
|
||||
u.next := v; v.prev := u; un.prev := w; w.next := un;
|
||||
REPEAT
|
||||
IF v IS Elem THEN v(Elem).base := base END;
|
||||
v := v.next
|
||||
UNTIL v = un
|
||||
END
|
||||
END Splice;
|
||||
|
||||
PROCEDURE ClonePiece (p: Piece): Piece;
|
||||
VAR q: Piece;
|
||||
BEGIN NEW(q); q^ := p^; RETURN q
|
||||
END ClonePiece;
|
||||
|
||||
PROCEDURE CloneElem (e: Elem): Elem;
|
||||
VAR msg: CopyMsg;
|
||||
BEGIN msg.e := NIL; e.handle(e, msg); RETURN msg.e
|
||||
END CloneElem;
|
||||
|
||||
|
||||
(** Elements **)
|
||||
|
||||
PROCEDURE CopyElem* (SE, DE: Elem);
|
||||
BEGIN DE.len := SE.len; DE.fnt := SE.fnt; DE.col := SE.col; DE.voff := SE.voff;
|
||||
DE.W := SE.W; DE.H := SE.H; DE.handle := SE.handle
|
||||
END CopyElem;
|
||||
|
||||
PROCEDURE ElemBase* (E: Elem): Text;
|
||||
BEGIN RETURN E.base
|
||||
END ElemBase;
|
||||
|
||||
PROCEDURE ElemPos* (E: Elem): LONGINT;
|
||||
VAR u: Run; pos: LONGINT;
|
||||
BEGIN u := E.base.head.next; pos := 0;
|
||||
WHILE u # E DO pos := pos + u.len; u := u.next END;
|
||||
RETURN pos
|
||||
END ElemPos;
|
||||
|
||||
|
||||
PROCEDURE HandleAlien (E: Elem; VAR msg: ElemMsg);
|
||||
VAR e: Alien; r: Files.Rider; i: LONGINT; ch: CHAR;
|
||||
BEGIN
|
||||
WITH E: Alien DO
|
||||
IF msg IS CopyMsg THEN
|
||||
WITH msg: CopyMsg DO NEW(e); CopyElem(E, e);
|
||||
e.file := E.file; e.org := E.org; e.span := E.span; e.mod := E.mod; e.proc := E.proc;
|
||||
msg.e := e
|
||||
END
|
||||
ELSIF msg IS IdentifyMsg THEN
|
||||
WITH msg: IdentifyMsg DO
|
||||
COPY(E.mod, msg.mod); COPY(E.proc, msg.proc); msg.mod[31] := 1X (*alien*)
|
||||
END
|
||||
ELSIF msg IS FileMsg THEN
|
||||
WITH msg: FileMsg DO
|
||||
IF msg.id = store THEN Files.Set(r, E.file, E.org); i := E.span;
|
||||
WHILE i > 0 DO Files.Read(r, ch); Files.Write(msg.r, ch); DEC(i) END
|
||||
END
|
||||
END
|
||||
END
|
||||
END
|
||||
END HandleAlien;
|
||||
|
||||
|
||||
(** Buffers **)
|
||||
|
||||
PROCEDURE OpenBuf* (B: Buffer);
|
||||
VAR u: Run;
|
||||
BEGIN NEW(u); u.next := u; u.prev := u; B.head := u; B.len := 0
|
||||
END OpenBuf;
|
||||
|
||||
PROCEDURE Copy* (SB, DB: Buffer);
|
||||
VAR u, v, vn: Run;
|
||||
BEGIN u := SB.head.next; v := DB.head.prev;
|
||||
WHILE u # SB.head DO
|
||||
IF u IS Piece THEN vn := ClonePiece(u(Piece)) ELSE vn := CloneElem(u(Elem)) END;
|
||||
v.next := vn; vn.prev := v; v := vn; u := u.next
|
||||
END;
|
||||
v.next := DB.head; DB.head.prev := v;
|
||||
INC(DB.len, SB.len)
|
||||
END Copy;
|
||||
|
||||
PROCEDURE Recall* (VAR B: Buffer);
|
||||
BEGIN B := del; del := NIL
|
||||
END Recall;
|
||||
|
||||
|
||||
(** Texts **)
|
||||
|
||||
PROCEDURE Save* (T: Text; beg, end: LONGINT; B: Buffer);
|
||||
VAR u, v, w, wn: Run; uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Find(T, end, v, vo, vd);
|
||||
w := B.head.prev;
|
||||
WHILE u # v DO
|
||||
IF u IS Piece THEN wn := ClonePiece(u(Piece)); DEC(wn.len, ud); INC(wn(Piece).org, ud)
|
||||
ELSE wn := CloneElem(u(Elem))
|
||||
END;
|
||||
w.next := wn; wn.prev := w; w := wn; u := u.next; ud := 0
|
||||
END;
|
||||
IF vd > 0 THEN (*v IS Piece*) wn := ClonePiece(v(Piece)); wn.len := vd - ud; INC(wn(Piece).org, ud);
|
||||
w.next := wn; wn.prev := w; w := wn
|
||||
END;
|
||||
w.next := B.head; B.head.prev := w;
|
||||
INC(B.len, end - beg)
|
||||
END Save;
|
||||
|
||||
PROCEDURE Insert* (T: Text; pos: LONGINT; B: Buffer);
|
||||
VAR u, un, v: Run; p, q: Piece; uo, ud, len: LONGINT;
|
||||
BEGIN Find(T, pos, u, uo, ud); Split(ud, u, un);
|
||||
len := B.len; v := B.head.next;
|
||||
Merge(T, u, v); Splice(un, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Insert;
|
||||
|
||||
PROCEDURE Append* (T: Text; B: Buffer);
|
||||
VAR v: Run; pos, len: LONGINT;
|
||||
BEGIN pos := T.len; len := B.len; v := B.head.next;
|
||||
Merge(T, T.head.prev, v); Splice(T.head, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Append;
|
||||
|
||||
PROCEDURE Delete* (T: Text; beg, end: LONGINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN
|
||||
Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
NEW(del); OpenBuf(del); del.len := end - beg;
|
||||
Splice(del.head, un, v, NIL);
|
||||
Merge(T, u, vn); u.next := vn; vn.prev := u;
|
||||
DEC(T.len, end - beg);
|
||||
END Delete;
|
||||
|
||||
PROCEDURE ChangeLooks* (T: Text; beg, end: LONGINT; sel: SET; fnt: FontsFont; col, voff: SHORTINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
WHILE un # vn DO
|
||||
IF (0 IN sel) & (fnt # NIL) THEN un.fnt := fnt END;
|
||||
IF 1 IN sel THEN un.col := col END;
|
||||
IF 2 IN sel THEN un.voff := voff END;
|
||||
Merge(T, u, un);
|
||||
IF u.next = un THEN u := un; un := un.next ELSE u.next := un; un.prev := u END
|
||||
END;
|
||||
Merge(T, u, un); u.next := un; un.prev := u;
|
||||
END ChangeLooks;
|
||||
|
||||
|
||||
(** Readers **)
|
||||
|
||||
PROCEDURE OpenReader* (VAR R: Reader; T: Text; pos: LONGINT);
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len END;
|
||||
Find(T, pos, u, R.org, R.off); R.run := u; R.eot := FALSE;
|
||||
IF u IS Piece THEN
|
||||
Files.Set(R.rider, u(Piece).file, u(Piece).org + R.off)
|
||||
END
|
||||
END OpenReader;
|
||||
|
||||
PROCEDURE Read* (VAR R: Reader; VAR ch: CHAR);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run; R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; INC(R.off);
|
||||
IF u IS Piece THEN Files.Read(R.rider, ch); R.elem := NIL;
|
||||
IF (ch = 0AX) & u(Piece).ascii THEN ch := CR END (* << LF to CR *)
|
||||
ELSIF u IS Elem THEN ch := ElemChar; R.elem := u(Elem)
|
||||
ELSE ch := 0X; R.elem := NIL; R.eot := TRUE
|
||||
END;
|
||||
IF R.off = u.len THEN INC(R.org, u.len); u := u.next;
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO Files.Set(R.rider, u.file, u.org) END
|
||||
END;
|
||||
R.run := u; R.off := 0
|
||||
END
|
||||
END Read;
|
||||
|
||||
PROCEDURE ReadElem* (VAR R: Reader);
|
||||
VAR u, un: Run;
|
||||
BEGIN u := R.run;
|
||||
WHILE u IS Piece DO INC(R.org, u.len); u := u.next END;
|
||||
IF u IS Elem THEN un := u.next; R.run := un; INC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem);
|
||||
IF un IS Piece THEN
|
||||
WITH un: Piece DO Files.Set(R.rider, un.file, un.org) END
|
||||
END
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadElem;
|
||||
|
||||
PROCEDURE ReadPrevElem* (VAR R: Reader);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run.prev;
|
||||
WHILE u IS Piece DO DEC(R.org, u.len); u := u.prev END;
|
||||
IF u IS Elem THEN R.run := u; DEC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem)
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadPrevElem;
|
||||
|
||||
PROCEDURE Pos* (VAR R: Reader): LONGINT;
|
||||
BEGIN RETURN R.org + R.off
|
||||
END Pos;
|
||||
|
||||
|
||||
(** Scanners --------------- NW --------------- **)
|
||||
|
||||
PROCEDURE OpenScanner* (VAR S: Scanner; T: Text; pos: LONGINT);
|
||||
BEGIN OpenReader(S, T, pos); S.line := 0; S.nextCh := " "
|
||||
END OpenScanner;
|
||||
|
||||
(*IEEE floating point formats:
|
||||
x = 2^(e-127) * 1.m bit 0: sign, bits 1- 8: e, bits 9-31: m
|
||||
x = 2^(e-1023) * 1.m bit 0: sign, bits 1-11: e, bits 12-63: m *)
|
||||
|
||||
PROCEDURE Scan* (VAR S: Scanner);
|
||||
CONST maxD = 32;
|
||||
VAR ch, term: CHAR;
|
||||
neg, negE, hex: BOOLEAN;
|
||||
i, j, h: SHORTINT;
|
||||
e: INTEGER; k: LONGINT;
|
||||
x, f: REAL; y, g: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE ReadScaleFactor;
|
||||
BEGIN Read(S, ch);
|
||||
IF ch = "-" THEN negE := TRUE; Read(S, ch)
|
||||
ELSE negE := FALSE;
|
||||
IF ch = "+" THEN Read(S, ch) END
|
||||
END;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO
|
||||
e := e*10 + ORD(ch) - 30H; Read(S, ch)
|
||||
END
|
||||
END ReadScaleFactor;
|
||||
|
||||
BEGIN ch := S.nextCh; i := 0;
|
||||
LOOP
|
||||
IF ch = CR THEN INC(S.line)
|
||||
ELSIF (ch # " ") & (ch # TAB) THEN EXIT
|
||||
END ;
|
||||
Read(S, ch)
|
||||
END;
|
||||
IF ("A" <= CAP(ch)) & (CAP(ch) <= "Z") OR (ch = "/") OR (ch = ".") THEN (*name*) (* << *)
|
||||
REPEAT S.s[i] := ch; INC(i); Read(S, ch)
|
||||
UNTIL (CAP(ch) > "Z") & (ch # "_") (* << *)
|
||||
OR ("A" > CAP(ch)) & (ch > "9")
|
||||
OR ("0" > ch) & (ch # ".") & (ch # "/") (* << *)
|
||||
OR (i = 63); (* << *)
|
||||
S.s[i] := 0X; S.len := i; S.class := 1
|
||||
ELSIF ch = 22X THEN (*literal string*)
|
||||
Read(S, ch);
|
||||
WHILE (ch # 22X) & (ch >= " ") & (i # 63) DO (* << *)
|
||||
S.s[i] := ch; INC(i); Read(S, ch)
|
||||
END;
|
||||
S.s[i] := 0X; S.len := i+1; Read(S, ch); S.class := 2
|
||||
ELSE
|
||||
IF ch = "-" THEN neg := TRUE; Read(S, ch) ELSE neg := FALSE END ;
|
||||
IF ("0" <= ch) & (ch <= "9") THEN (*number*)
|
||||
hex := FALSE; j := 0;
|
||||
LOOP d[i] := ch; INC(i); Read(S, ch);
|
||||
IF ch < "0" THEN EXIT END;
|
||||
IF "9" < ch THEN
|
||||
IF ("A" <= ch) & (ch <= "F") THEN hex := TRUE; ch := CHR(ORD(ch)-7)
|
||||
ELSIF ("a" <= ch) & (ch <= "f") THEN hex := TRUE; ch := CHR(ORD(ch)-27H)
|
||||
ELSE EXIT
|
||||
END
|
||||
END
|
||||
END;
|
||||
IF ch = "H" THEN (*hex number*)
|
||||
Read(S, ch); S.class := 3;
|
||||
IF i-j > 8 THEN j := i-8 END ;
|
||||
k := ORD(d[j]) - 30H; INC(j);
|
||||
IF (i-j = 7) & (k >= 8) THEN DEC(k, 16) END ;
|
||||
WHILE j < i DO k := k*10H + (ORD(d[j]) - 30H); INC(j) END ;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END
|
||||
ELSIF ch = "." THEN (*read real*)
|
||||
Read(S, ch); h := i;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO d[i] := ch; INC(i); Read(S, ch) END ;
|
||||
IF ch = "D" THEN
|
||||
e := 0; y := 0; g := 1;
|
||||
REPEAT y := y*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO g := g/10; y := (ORD(d[j]) - 30H)*g + y; INC(j) END ;
|
||||
ReadScaleFactor;
|
||||
IF negE THEN
|
||||
IF e <= 308 THEN y := y / Reals.TenL(e) ELSE y := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 308 THEN y := Reals.TenL(e) * y ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN y := -y END ;
|
||||
S.class := 5; S.y := y
|
||||
ELSE e := 0; x := 0; f := 1;
|
||||
REPEAT x := x*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO f := f/10; x := (ORD(d[j])-30H)*f + x; INC(j) END;
|
||||
IF ch = "E" THEN ReadScaleFactor END ;
|
||||
IF negE THEN
|
||||
IF e <= 38 THEN x := x / Reals.Ten(e) ELSE x := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 38 THEN x := Reals.Ten(e) * x ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN x := -x END ;
|
||||
S.class := 4; S.x := x
|
||||
END ;
|
||||
IF hex THEN S.class := 0 END
|
||||
ELSE (*decimal integer*)
|
||||
S.class := 3; k := 0;
|
||||
REPEAT k := k*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = i;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END;
|
||||
IF hex THEN S.class := 0 ELSE S.class := 3 END
|
||||
END
|
||||
ELSE S.class := 6;
|
||||
IF neg THEN S.c := "-" ELSE S.c := ch; Read(S, ch) END
|
||||
END
|
||||
END;
|
||||
S.nextCh := ch
|
||||
END Scan;
|
||||
|
||||
|
||||
(** Writers **)
|
||||
|
||||
PROCEDURE OpenWriter* (VAR W: Writer);
|
||||
BEGIN NEW(W.buf); OpenBuf(W.buf);
|
||||
W.fnt := FontsDefault; W.col := Displaywhite; W.voff := 0;
|
||||
W.file := Files.New(""); Files.Set(W.rider, W.file, 0)
|
||||
END OpenWriter;
|
||||
|
||||
PROCEDURE SetFont* (VAR W: Writer; fnt: FontsFont);
|
||||
BEGIN W.fnt := fnt
|
||||
END SetFont;
|
||||
|
||||
PROCEDURE SetColor* (VAR W: Writer; col: SHORTINT);
|
||||
BEGIN W.col := col
|
||||
END SetColor;
|
||||
|
||||
PROCEDURE SetOffset* (VAR W: Writer; voff: SHORTINT);
|
||||
BEGIN W.voff := voff
|
||||
END SetOffset;
|
||||
|
||||
|
||||
PROCEDURE Write* (VAR W: Writer; ch: CHAR);
|
||||
VAR u, un: Run; p: Piece;
|
||||
BEGIN Files.Write(W.rider, ch); INC(W.buf.len); un := W.buf.head; u := un.prev;
|
||||
IF (u IS Piece) & (u(Piece).file = W.file) & (u.fnt.name = W.fnt.name) & (u.col = W.col) & (u.voff = W.voff)
|
||||
& ~u(Piece).ascii THEN (* << *)
|
||||
INC(u.len)
|
||||
ELSE NEW(p); u.next := p; p.prev := u; p.next := un; un.prev := p;
|
||||
p.len := 1; p.fnt := W.fnt; p.col := W.col; p.voff := W.voff;
|
||||
p.file := W.file; p.org := Files.Length(W.file) - 1; p.ascii := FALSE (* << *)
|
||||
END
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteElem* (VAR W: Writer; e: Elem);
|
||||
VAR u, un: Run;
|
||||
BEGIN
|
||||
IF e.base # NIL THEN HALT(99) END;
|
||||
INC(W.buf.len); e.len := 1; e.fnt := W.fnt; e.col := W.col; e.voff := W.voff;
|
||||
un := W.buf.head; u := un.prev; u.next := e; e.prev := u; e.next := un; un.prev := e
|
||||
END WriteElem;
|
||||
|
||||
PROCEDURE WriteLn* (VAR W: Writer);
|
||||
BEGIN Write(W, CR)
|
||||
END WriteLn;
|
||||
|
||||
PROCEDURE WriteString* (VAR W: Writer; s: ARRAY OF CHAR);
|
||||
VAR i: INTEGER;
|
||||
BEGIN i := 0;
|
||||
WHILE s[i] >= " " DO Write(W, s[i]); INC(i) END
|
||||
END WriteString;
|
||||
|
||||
PROCEDURE WriteInt* (VAR W: Writer; x, n: LONGINT);
|
||||
VAR i: INTEGER; x0: LONGINT;
|
||||
a: ARRAY 11 OF CHAR;
|
||||
BEGIN i := 0;
|
||||
IF x < 0 THEN
|
||||
IF x = MIN(LONGINT) THEN WriteString(W, " -2147483648"); RETURN
|
||||
ELSE DEC(n); x0 := -x
|
||||
END
|
||||
ELSE x0 := x
|
||||
END;
|
||||
REPEAT
|
||||
a[i] := CHR(x0 MOD 10 + 30H); x0 := x0 DIV 10; INC(i)
|
||||
UNTIL x0 = 0;
|
||||
WHILE n > i DO Write(W, " "); DEC(n) END;
|
||||
IF x < 0 THEN Write(W, "-") END;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteInt;
|
||||
|
||||
PROCEDURE WriteHex* (VAR W: Writer; x: LONGINT);
|
||||
VAR i: INTEGER; y: LONGINT;
|
||||
a: ARRAY 10 OF CHAR;
|
||||
BEGIN i := 0; Write(W, " ");
|
||||
REPEAT y := x MOD 10H;
|
||||
IF y < 10 THEN a[i] := CHR(y + 30H) ELSE a[i] := CHR(y + 37H) END;
|
||||
x := x DIV 10H; INC(i)
|
||||
UNTIL i = 8;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteHex;
|
||||
|
||||
PROCEDURE WriteReal* (VAR W: Writer; x: REAL; n: INTEGER);
|
||||
VAR e: INTEGER; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 255 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 9 THEN n := 3 ELSE DEC(n, 6) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 8;
|
||||
(*there are 2 < n <= 8 digits to be written*)
|
||||
IF x < 0.0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := (e - 127) * 77 DIV 256;
|
||||
IF e >= 0 THEN x := x / Reals.Ten(e) ELSE x := Reals.Ten(-e) * x END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
x0 := Reals.Ten(n-1); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN x := x*0.1; INC(e) END;
|
||||
Reals.Convert(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "E");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 10 + 30H)); Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteReal;
|
||||
|
||||
PROCEDURE WriteRealFix* (VAR W: Writer; x: REAL; n, k: INTEGER);
|
||||
VAR e, i: INTEGER; sign: CHAR; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE seq(ch: CHAR; n: INTEGER);
|
||||
BEGIN WHILE n > 0 DO Write(W, ch); DEC(n) END
|
||||
END seq;
|
||||
|
||||
PROCEDURE dig(n: INTEGER);
|
||||
BEGIN
|
||||
WHILE n > 0 DO
|
||||
DEC(i); Write(W, d[i]); DEC(n)
|
||||
END
|
||||
END dig;
|
||||
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF k < 0 THEN k := 0 END;
|
||||
IF e = 0 THEN seq(" ", n-k-2); Write(W, "0"); seq(" ", k+1)
|
||||
ELSIF e = 255 THEN WriteString(W, " NaN"); seq(" ", n-4)
|
||||
ELSE e := (e - 127) * 77 DIV 256;
|
||||
IF x < 0 THEN sign := "-"; x := -x ELSE sign := " " END;
|
||||
IF e >= 0 THEN (*x >= 1.0, 77/256 = log 2*) x := x/Reals.Ten(e)
|
||||
ELSE (*x < 1.0*) x := Reals.Ten(-e) * x
|
||||
END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
(* 1 <= x < 10 *)
|
||||
IF k+e >= maxD-1 THEN k := maxD-1-e
|
||||
ELSIF k+e < 0 THEN k := -e; x := 0.0
|
||||
END;
|
||||
x0 := Reals.Ten(k+e); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN INC(e) END;
|
||||
(*e = no. of digits before decimal point*)
|
||||
INC(e); i := k+e; Reals.Convert(x, i, d);
|
||||
IF e > 0 THEN
|
||||
seq(" ", n-e-k-2); Write(W, sign); dig(e);
|
||||
Write(W, "."); dig(k)
|
||||
ELSE seq(" ", n-k-3);
|
||||
Write(W, sign); Write(W, "0"); Write(W, ".");
|
||||
seq("0", -e); dig(k+e)
|
||||
END
|
||||
END
|
||||
END WriteRealFix;
|
||||
|
||||
PROCEDURE WriteRealHex* (VAR W: Writer; x: REAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 8 OF CHAR;
|
||||
BEGIN Reals.ConvertH(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 8
|
||||
END WriteRealHex;
|
||||
|
||||
PROCEDURE WriteLongReal* (VAR W: Writer; x: LONGREAL; n: INTEGER);
|
||||
CONST maxD = 16;
|
||||
VAR e: INTEGER; x0: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.ExpoL(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 2047 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 10 THEN n := 3 ELSE DEC(n, 7) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= maxD;
|
||||
(*there are 2 <= n <= maxD digits to be written*)
|
||||
IF x < 0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := SHORT(LONG(e - 1023) * 77 DIV 256);
|
||||
IF e >= 0 THEN x := x / Reals.TenL(e) ELSE x := Reals.TenL(-e) * x END ;
|
||||
IF x >= 10.0D0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
x0 := Reals.TenL(n-1); x := x0*x + 0.5D0;
|
||||
IF x >= 10.0D0*x0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
Reals.ConvertL(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "D");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 100 + 30H)); e := e MOD 100;
|
||||
Write(W, CHR(e DIV 10 + 30H));
|
||||
Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteLongReal;
|
||||
|
||||
PROCEDURE WriteLongRealHex* (VAR W: Writer; x: LONGREAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 16 OF CHAR;
|
||||
BEGIN Reals.ConvertHL(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 16
|
||||
END WriteLongRealHex;
|
||||
|
||||
PROCEDURE WriteDate* (VAR W: Writer; t, d: LONGINT);
|
||||
|
||||
PROCEDURE WritePair(ch: CHAR; x: LONGINT);
|
||||
BEGIN Write(W, ch);
|
||||
Write(W, CHR(x DIV 10 + 30H)); Write(W, CHR(x MOD 10 + 30H))
|
||||
END WritePair;
|
||||
|
||||
BEGIN
|
||||
WritePair(" ", d MOD 32); WritePair(".", d DIV 32 MOD 16); WritePair(".", d DIV 512 MOD 128);
|
||||
WritePair(" ", t DIV 4096 MOD 32); WritePair(":", t DIV 64 MOD 64); WritePair(":", t MOD 64)
|
||||
END WriteDate;
|
||||
|
||||
|
||||
(** Text Filing **)
|
||||
|
||||
PROCEDURE Load0 (VAR r: Files.Rider; T: Text);
|
||||
VAR u, un: Run; p: Piece; e: Elem;
|
||||
org, pos, hlen, plen: LONGINT; ecnt, fno, fcnt, col, voff: SHORTINT;
|
||||
f: Files.File;
|
||||
msg: FileMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
name: ARRAY 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
|
||||
PROCEDURE LoadElem (VAR r: Files.Rider; pos, span: LONGINT; VAR e: Elem);
|
||||
VAR M: Modules.Module; Cmd: Modules.Command; a: Alien;
|
||||
org, ew, eh: LONGINT; eno: SHORTINT;
|
||||
BEGIN new := NIL;
|
||||
Files.ReadLInt(r, ew); Files.ReadLInt(r, eh); Files.Read(r, eno);
|
||||
IF eno > ecnt THEN ecnt := eno; Files.ReadString(r, mods[eno]); Files.ReadString(r, procs[eno]) END;
|
||||
org := Files.Pos(r); M := Modules.ThisMod(mods[eno]);
|
||||
IF M # NIL THEN Cmd := Modules.ThisCommand(M, procs[eno]);
|
||||
IF Cmd # NIL THEN Cmd END
|
||||
END;
|
||||
e := new;
|
||||
IF e # NIL THEN e.W := ew; e.H := eh; e.base := T;
|
||||
msg.pos := pos; e.handle(e, msg);
|
||||
IF Files.Pos(r) # org + span THEN e := NIL END
|
||||
END;
|
||||
IF e = NIL THEN Files.Set(r, f, org + span);
|
||||
NEW(a); a.W := ew; a.H := eh; a.handle := HandleAlien; a.base := T;
|
||||
a.file := f; a.org := org; a.span := span;
|
||||
COPY(mods[eno], a.mod); COPY(procs[eno], a.proc);
|
||||
e := a
|
||||
END
|
||||
END LoadElem;
|
||||
|
||||
BEGIN pos := Files.Pos(r); f := Files.Base(r);
|
||||
NEW(u); u.len := MAX(LONGINT); (*u.fnt := FontsDefault;*)u.fnt := NIL; u.col := Displaywhite;
|
||||
T.head := u; ecnt := 0; fcnt := 0;
|
||||
msg.id := load; msg.r := r;
|
||||
Files.ReadLInt(msg.r, hlen); (*!!!org := pos + hlen;*) org := pos -2 + hlen; pos := org; Files.Read(msg.r, fno);
|
||||
WHILE fno # 0 DO
|
||||
IF fno > fcnt THEN fcnt := fno; Files.ReadString(msg.r, name); fnts[fno] := FontsThis(name) END;
|
||||
Files.Read(msg.r, col); Files.Read(msg.r, voff); Files.ReadLInt(msg.r, plen);
|
||||
IF plen > 0 THEN NEW(p); p.file := f; p.org := pos; p.ascii := FALSE; un := p; un.len := plen
|
||||
ELSE LoadElem(msg.r, pos - org, -plen, e); un := e; un.len := 1
|
||||
END;
|
||||
un.fnt := fnts[fno]; un.col := col; un.voff := voff;
|
||||
INC(pos, un.len); u.next := un; un.prev := u; u := un; Files.Read(msg.r, fno)
|
||||
END;
|
||||
u.next := T.head; T.head.prev := u; T.cache := T.head; T.corg := 0;
|
||||
Files.ReadLInt(msg.r, T.len); Files.Set(r, f, Files.Pos(msg.r) + T.len)
|
||||
END Load0;
|
||||
|
||||
PROCEDURE Load* (VAR r: Files.Rider; T: Text);
|
||||
CONST oldTag = -4095;
|
||||
VAR tag: INTEGER;
|
||||
BEGIN
|
||||
(* for compatibility inner text tags are checked and skipped; remove this in a later version *)
|
||||
Files.ReadInt(r, tag); IF tag # oldTag THEN Files.Set(r, Files.Base(r), Files.Pos(r)-2) END;
|
||||
Load0(r, T)
|
||||
END Load;
|
||||
|
||||
PROCEDURE Open* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; u: Run; p: Piece; tag, version: CHAR; hlen: LONGINT;
|
||||
BEGIN f := Files.Old(name);
|
||||
IF f = NIL THEN f := Files.New("") END;
|
||||
Files.Set(r, f, 0); Files.Read(r, tag); Files.Read(r, version);
|
||||
IF (tag = textTag) OR (tag = 01X) & (version = textTag) THEN Load0(r, T)
|
||||
ELSE (*ascii*)
|
||||
NEW(u); u.len := MAX(LONGINT); u.fnt := NIL; u.col := Displaywhite;
|
||||
NEW(p);
|
||||
IF (tag = DocBlockId) & (version = 07X) THEN (* extract ascii text from System 3 text document *)
|
||||
Files.Set(r, f, 28); Files.ReadLInt(r, hlen);
|
||||
Files.Set(r, f, 22 + hlen); Files.ReadLInt(r, T.len); p.org := 26 + hlen
|
||||
ELSE
|
||||
T.len := Files.Length(f); p.org := 0
|
||||
END ;
|
||||
IF T.len > 0 THEN p.len := T.len; p.fnt := FontsDefault;
|
||||
p.col := Displaywhite; p.voff := 0; p.file := f; p.ascii := TRUE;
|
||||
u.next := p; u.prev := p; p.next := u; p.prev := u
|
||||
ELSE u.next := u; u.prev := u
|
||||
END;
|
||||
T.head := u; T.cache := T.head; T.corg := 0
|
||||
END
|
||||
END Open;
|
||||
|
||||
PROCEDURE Store* (VAR r: Files.Rider; T: Text);
|
||||
VAR r1: Files.Rider; u, un: Run; e: Elem; org, pos, delta, hlen, rlen: LONGINT; ecnt, fno, fcnt: SHORTINT; ch: CHAR; (* << *)
|
||||
msg: FileMsg; iden: IdentifyMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
block: ARRAY 1024 OF CHAR;
|
||||
|
||||
PROCEDURE StoreElem (VAR r: Files.Rider; pos: LONGINT; e: Elem);
|
||||
VAR r1: Files.Rider; org, span: LONGINT; eno: SHORTINT;
|
||||
BEGIN COPY(iden.mod, mods[ecnt]); COPY(iden.proc, procs[ecnt]); eno := 1;
|
||||
WHILE (mods[eno] # iden.mod) OR (procs[eno] # iden.proc) DO INC(eno) END;
|
||||
Files.Set(r1, Files.Base(r), Files.Pos(r));
|
||||
Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); (*fixup slot*)
|
||||
Files.Write(r, eno);
|
||||
IF eno = ecnt THEN INC(ecnt); Files.WriteString(r, iden.mod); Files.WriteString(r, iden.proc) END;
|
||||
msg.pos := pos; org := Files.Pos(r); e.handle(e, msg); span := Files.Pos(r) - org;
|
||||
Files.WriteLInt(r1, -span); Files.WriteLInt(r1, e.W); Files.WriteLInt(r1, e.H) (*fixup*)
|
||||
END StoreElem;
|
||||
|
||||
BEGIN
|
||||
org := Files.Pos(r); msg.id := store; msg.r := r; Files.WriteLInt(msg.r, 0); (*fixup slot*)
|
||||
u := T.head.next; pos := 0; delta := 0; fcnt := 1; ecnt := 1;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Elem THEN iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden) ELSE iden.mod[0] := 1X END;
|
||||
IF iden.mod[0] # 0X THEN
|
||||
fnts[fcnt] := u.fnt; fno := 1;
|
||||
WHILE fnts[fno].name # u.fnt.name DO INC(fno) END;
|
||||
Files.Write(msg.r, fno);
|
||||
IF fno = fcnt THEN INC(fcnt); Files.WriteString(msg.r, u.fnt.name) END;
|
||||
Files.Write(msg.r, u.col); Files.Write(msg.r, u.voff)
|
||||
END;
|
||||
IF u IS Piece THEN rlen := u.len; un := u.next;
|
||||
WHILE (un IS Piece) & (un.fnt = u.fnt) & (un.col = u.col) & (un.voff = u.voff) DO
|
||||
INC(rlen, un.len); un := un.next
|
||||
END;
|
||||
Files.WriteLInt(msg.r, rlen); INC(pos, rlen); u := un
|
||||
ELSIF iden.mod[0] # 0X THEN StoreElem(msg.r, pos, u(Elem)); INC(pos); u := u.next
|
||||
ELSE INC(delta); u := u.next
|
||||
END
|
||||
END;
|
||||
Files.Write(msg.r, 0); Files.WriteLInt(msg.r, T.len - delta);
|
||||
(*!!!hlen := Files.Pos(msg.r) - org;*) hlen := Files.Pos(msg.r) - org + 2;
|
||||
Files.Set(r1, Files.Base(msg.r), org); Files.WriteLInt(r1, hlen); (*fixup*)
|
||||
u := T.head.next;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO
|
||||
IF u.ascii THEN Files.Set(r1, u.file, u.org); delta := u.len; (* << LF to CR *)
|
||||
WHILE delta > 0 DO Files.Read(r1, ch); DEC(delta);
|
||||
IF ch = 0AX THEN Files.Write(msg.r, CR) ELSE Files.Write(msg.r, ch) END
|
||||
END
|
||||
ELSE Files.Set(r1, u.file, u.org); delta := u.len;
|
||||
WHILE delta > LEN(block) DO Files.ReadBytes(r1, block, LEN(block));
|
||||
Files.WriteBytes(msg.r, block, LEN(block)); DEC(delta, LEN(block))
|
||||
END;
|
||||
Files.ReadBytes(r1, block, delta); Files.WriteBytes(msg.r, block, delta)
|
||||
END
|
||||
END
|
||||
ELSE iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden);
|
||||
IF iden.mod[0] # 0X THEN Files.Write(msg.r, ElemChar) END
|
||||
END;
|
||||
u := u.next
|
||||
END;
|
||||
r := msg.r;
|
||||
END Store;
|
||||
|
||||
PROCEDURE Close* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; i, res: INTEGER; bak: ARRAY 64 OF CHAR;
|
||||
BEGIN
|
||||
f := Files.New(name); Files.Set(r, f, 0); Files.Write(r, textTag); Files.Write(r, version); Store(r, T);
|
||||
i := 0; WHILE name[i] # 0X DO INC(i) END;
|
||||
COPY(name, bak); bak[i] := "."; bak[i+1] := "B"; bak[i+2] := "a"; bak[i+3] := "k"; bak[i+4] := 0X;
|
||||
Files.Rename(name, bak, res); Files.Register(f)
|
||||
END Close;
|
||||
|
||||
BEGIN del := NIL; NEW(FontsDefault); FontsDefault.name := "Syntax10.Scn.Fnt"
|
||||
END Texts0.
|
||||
|
|
@ -1,5 +1,5 @@
|
|||
MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
|
||||
(* modified version of Files, which opens only the file provided and does not scan any path in any environment variable, also ReadLine procedure added; -- noch *)
|
||||
IMPORT SYSTEM, Unix, Kernel, Args, Console;
|
||||
|
||||
(* standard data type I/O
|
||||
|
|
@ -185,7 +185,7 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
f.fd := noDesc; f.state := create; f.len := 0; f.pos := 0; f.swapper := -1; (*all f.buf[i] = NIL*)
|
||||
RETURN f
|
||||
END New;
|
||||
|
||||
(*
|
||||
PROCEDURE ScanPath(VAR pos: INTEGER; VAR dir: ARRAY OF CHAR); (* supports ~, ~user and blanks inside path *)
|
||||
VAR i: INTEGER; ch: CHAR; home: ARRAY 256 OF CHAR;
|
||||
BEGIN
|
||||
|
|
@ -203,7 +203,7 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
WHILE (i > 0) & (dir[i-1] = " ") DO DEC(i) END ;
|
||||
dir[i] := 0X
|
||||
END ScanPath;
|
||||
|
||||
*)
|
||||
PROCEDURE HasDir(VAR name: ARRAY OF CHAR): BOOLEAN;
|
||||
VAR i: INTEGER; ch: CHAR;
|
||||
BEGIN i := 0; ch := name[0];
|
||||
|
|
@ -239,7 +239,10 @@ MODULE Files; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files
|
|||
BEGIN
|
||||
IF name # "" THEN
|
||||
IF HasDir(name) THEN dir := ""; COPY(name, path)
|
||||
ELSE pos := 0; ScanPath(pos, dir); MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
ELSE
|
||||
pos := 0;
|
||||
COPY(name, path); (* -- noch *)
|
||||
(*ScanPath(pos, dir);*) (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
END ;
|
||||
LOOP
|
||||
fd := Unix.Open(path, Unix.rdwr, {}); done := fd >= 0; errno := Unix.errno();
|
||||
|
|
@ -270,7 +273,8 @@ END ;
|
|||
RETURN f
|
||||
END
|
||||
ELSIF dir = "" THEN RETURN NIL
|
||||
ELSE MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
ELSE (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
RETURN NIL
|
||||
END
|
||||
END
|
||||
ELSE RETURN NIL
|
||||
|
|
@ -388,6 +392,11 @@ END ;
|
|||
r.offset := offset + 1; r.res := 0
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteByte* (VAR r : Rider; x : SYSTEM.BYTE); (* added for compatibility with PO 2013, -- noch *)
|
||||
BEGIN
|
||||
Write(r, x);
|
||||
END WriteByte;
|
||||
|
||||
PROCEDURE WriteBytes* (VAR r: Rider; VAR x: ARRAY OF SYSTEM.BYTE; n: LONGINT);
|
||||
VAR xpos, min, restInBuf, offset: LONGINT; buf: Buffer;
|
||||
BEGIN
|
||||
|
|
@ -423,6 +432,7 @@ BEGIN
|
|||
buf.data[offset] := x; r.offset := offset + 1; buf.chg := TRUE
|
||||
END Write;
|
||||
|
||||
|
||||
PROCEDURE WriteBytes ...
|
||||
|
||||
PROCEDURE Read* (VAR r: Rider; VAR x: SYSTEM.BYTE);
|
||||
|
|
@ -550,7 +560,23 @@ Especially Length would become fairly complex.
|
|||
BEGIN i := 0;
|
||||
REPEAT Read(R, ch); x[i] := ch; INC(i) UNTIL ch = 0X
|
||||
END ReadString;
|
||||
|
||||
|
||||
(* need to read line; -- noch *)
|
||||
PROCEDURE ReadLine* (VAR R: Rider; VAR x: ARRAY OF CHAR);
|
||||
VAR i: INTEGER; ch: CHAR; b : BOOLEAN;
|
||||
BEGIN i := 0;
|
||||
b := FALSE;
|
||||
REPEAT
|
||||
Read(R, ch);
|
||||
IF ((ch = 0X) OR (ch = 0AX) OR (ch = 0DX)) THEN
|
||||
b := TRUE
|
||||
ELSE
|
||||
x[i] := ch;
|
||||
INC(i);
|
||||
END;
|
||||
UNTIL b
|
||||
END ReadLine;
|
||||
|
||||
PROCEDURE ReadNum* (VAR R: Rider; VAR x: LONGINT);
|
||||
VAR s: SHORTINT; ch: CHAR; n: LONGINT;
|
||||
BEGIN s := 0; n := 0; Read(R, ch);
|
||||
|
|
@ -606,6 +632,11 @@ Especially Length would become fairly complex.
|
|||
Write(R, CHR(x MOD 128))
|
||||
END WriteNum;
|
||||
|
||||
PROCEDURE GetName*(f: File; VAR name: ARRAY OF CHAR);
|
||||
BEGIN
|
||||
COPY (f.workName, name);
|
||||
END GetName;
|
||||
|
||||
PROCEDURE Finalize(o: SYSTEM.PTR);
|
||||
VAR f: File; res: LONGINT;
|
||||
BEGIN
|
||||
|
|
|
|||
|
|
@ -1,6 +1,9 @@
|
|||
MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
(* modified version of Files, which opens only the file provided and does not scan any path in any environment variable, also ReadLine procedure added; -- noch *)
|
||||
IMPORT SYSTEM, Unix, Kernel, Args, Console;
|
||||
MODULE Files0; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix files *)
|
||||
|
||||
(* this module is not for use by developers and inteded to bootstrap voc *)
|
||||
(* for general use import Files module *)
|
||||
|
||||
IMPORT SYSTEM, Unix, Kernel := Kernel0, Args, Console;
|
||||
|
||||
(* standard data type I/O
|
||||
|
||||
|
|
@ -66,12 +69,8 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
PROCEDURE -includetime()
|
||||
'#include "time.h"';
|
||||
|
||||
(* for getcwd() *)
|
||||
PROCEDURE -includeUnistd()
|
||||
'#include <unistd.h>';
|
||||
|
||||
PROCEDURE -localtime(VAR clock: LONGINT): Time
|
||||
"(OakFiles_Time) localtime(clock)";
|
||||
"(Files0_Time) localtime(clock)";
|
||||
|
||||
PROCEDURE -getcwd(VAR cwd: Unix.Name)
|
||||
"getcwd(cwd, cwd__len)";
|
||||
|
|
@ -189,7 +188,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
f.fd := noDesc; f.state := create; f.len := 0; f.pos := 0; f.swapper := -1; (*all f.buf[i] = NIL*)
|
||||
RETURN f
|
||||
END New;
|
||||
(*
|
||||
|
||||
PROCEDURE ScanPath(VAR pos: INTEGER; VAR dir: ARRAY OF CHAR); (* supports ~, ~user and blanks inside path *)
|
||||
VAR i: INTEGER; ch: CHAR; home: ARRAY 256 OF CHAR;
|
||||
BEGIN
|
||||
|
|
@ -207,7 +206,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
WHILE (i > 0) & (dir[i-1] = " ") DO DEC(i) END ;
|
||||
dir[i] := 0X
|
||||
END ScanPath;
|
||||
*)
|
||||
|
||||
PROCEDURE HasDir(VAR name: ARRAY OF CHAR): BOOLEAN;
|
||||
VAR i: INTEGER; ch: CHAR;
|
||||
BEGIN i := 0; ch := name[0];
|
||||
|
|
@ -243,10 +242,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
BEGIN
|
||||
IF name # "" THEN
|
||||
IF HasDir(name) THEN dir := ""; COPY(name, path)
|
||||
ELSE
|
||||
pos := 0;
|
||||
COPY(name, path); (* -- noch *)
|
||||
(*ScanPath(pos, dir);*) (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
ELSE pos := 0; ScanPath(pos, dir); MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
END ;
|
||||
LOOP
|
||||
fd := Unix.Open(path, Unix.rdwr, {}); done := fd >= 0; errno := Unix.errno();
|
||||
|
|
@ -262,7 +258,7 @@ MODULE OakFiles; (* J. Templ 1.12. 89/12.4.95 Oberon files mapped onto Unix fil
|
|||
fd := Unix.Open(path, Unix.rdonly, {}); done := fd >= 0; errno := Unix.errno()
|
||||
END ;
|
||||
IF (~done) & (errno # Unix.ENOENT) THEN
|
||||
Console.String("warning Files.Old "); Console.String(name);
|
||||
Console.String("warning Files0.Old "); Console.String(name);
|
||||
Console.String(" errno = "); Console.Int(errno, 0); Console.Ln;
|
||||
END ;
|
||||
IF done THEN
|
||||
|
|
@ -277,8 +273,7 @@ END ;
|
|||
RETURN f
|
||||
END
|
||||
ELSIF dir = "" THEN RETURN NIL
|
||||
ELSE (*MakeFileName(dir, name, path);*) (*ScanPath(pos, dir)*)
|
||||
RETURN NIL
|
||||
ELSE MakeFileName(dir, name, path); ScanPath(pos, dir)
|
||||
END
|
||||
END
|
||||
ELSE RETURN NIL
|
||||
|
|
@ -396,11 +391,6 @@ END ;
|
|||
r.offset := offset + 1; r.res := 0
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteByte* (VAR r : Rider; x : SYSTEM.BYTE); (* added for compatibility with PO 2013, -- noch *)
|
||||
BEGIN
|
||||
Write(r, x);
|
||||
END WriteByte;
|
||||
|
||||
PROCEDURE WriteBytes* (VAR r: Rider; VAR x: ARRAY OF SYSTEM.BYTE; n: LONGINT);
|
||||
VAR xpos, min, restInBuf, offset: LONGINT; buf: Buffer;
|
||||
BEGIN
|
||||
|
|
@ -436,7 +426,6 @@ BEGIN
|
|||
buf.data[offset] := x; r.offset := offset + 1; buf.chg := TRUE
|
||||
END Write;
|
||||
|
||||
|
||||
PROCEDURE WriteBytes ...
|
||||
|
||||
PROCEDURE Read* (VAR r: Rider; VAR x: SYSTEM.BYTE);
|
||||
|
|
@ -564,23 +553,7 @@ Especially Length would become fairly complex.
|
|||
BEGIN i := 0;
|
||||
REPEAT Read(R, ch); x[i] := ch; INC(i) UNTIL ch = 0X
|
||||
END ReadString;
|
||||
|
||||
(* need to read line; -- noch *)
|
||||
PROCEDURE ReadLine* (VAR R: Rider; VAR x: ARRAY OF CHAR);
|
||||
VAR i: INTEGER; ch: CHAR; b : BOOLEAN;
|
||||
BEGIN i := 0;
|
||||
b := FALSE;
|
||||
REPEAT
|
||||
Read(R, ch);
|
||||
IF ((ch = 0X) OR (ch = 0AX) OR (ch = 0DX)) THEN
|
||||
b := TRUE
|
||||
ELSE
|
||||
x[i] := ch;
|
||||
INC(i);
|
||||
END;
|
||||
UNTIL b
|
||||
END ReadLine;
|
||||
|
||||
|
||||
PROCEDURE ReadNum* (VAR R: Rider; VAR x: LONGINT);
|
||||
VAR s: SHORTINT; ch: CHAR; n: LONGINT;
|
||||
BEGIN s := 0; n := 0; Read(R, ch);
|
||||
|
|
@ -636,11 +609,6 @@ Especially Length would become fairly complex.
|
|||
Write(R, CHR(x MOD 128))
|
||||
END WriteNum;
|
||||
|
||||
PROCEDURE GetName*(f: File; VAR name: ARRAY OF CHAR);
|
||||
BEGIN
|
||||
COPY (f.workName, name);
|
||||
END GetName;
|
||||
|
||||
PROCEDURE Finalize(o: SYSTEM.PTR);
|
||||
VAR f: File; res: LONGINT;
|
||||
BEGIN
|
||||
|
|
@ -659,4 +627,4 @@ Especially Length would become fairly complex.
|
|||
END Init;
|
||||
|
||||
BEGIN Init
|
||||
END OakFiles.
|
||||
END Files0.
|
||||
|
|
@ -4,13 +4,12 @@ MODULE Kernel;
|
|||
communication with C-runtime and storage management
|
||||
*)
|
||||
|
||||
IMPORT SYSTEM, Unix, Args, Strings := oocOakStrings, version;
|
||||
IMPORT SYSTEM, Unix, Args;
|
||||
|
||||
TYPE
|
||||
RealTime = POINTER TO TimeDesc;
|
||||
TimeDesc = RECORD
|
||||
sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: LONGINT
|
||||
(* sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: INTEGER*)
|
||||
END ;
|
||||
|
||||
KeyCmd* = PROCEDURE;
|
||||
|
|
@ -36,12 +35,10 @@ MODULE Kernel;
|
|||
|
||||
LIB*, CWD*: ARRAY 256 OF CHAR;
|
||||
OBERON*: ARRAY 1024 OF CHAR;
|
||||
MODULES-: ARRAY 1024 OF CHAR;
|
||||
|
||||
prefix*, fullprefix* : ARRAY 256 OF CHAR;
|
||||
|
||||
timeStart: LONGINT; (* milliseconds *)
|
||||
|
||||
|
||||
PROCEDURE -includesetjmp()
|
||||
'#include "setjmp.h"';
|
||||
(* for localtime *)
|
||||
|
|
@ -58,13 +55,13 @@ MODULE Kernel;
|
|||
"exit(n)";
|
||||
|
||||
PROCEDURE -sigsetjmp*(VAR env: Unix.JmpBuf; savemask: LONGINT): LONGINT
|
||||
"__sigsetjmp(env, savemask)";
|
||||
"__sigsetjmp(env, savemask)";
|
||||
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix.JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix. JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
|
||||
PROCEDURE -heapsize*(): LONGINT
|
||||
"SYSTEM_heapsize";
|
||||
"SYSTEM_heapsize";
|
||||
|
||||
PROCEDURE -allocated*(): LONGINT
|
||||
"SYSTEM_allocated";
|
||||
|
|
@ -163,16 +160,8 @@ BEGIN
|
|||
EndianTest();
|
||||
SetHalt(Halt);
|
||||
CWD := ""; OBERON := "."; LIB := "";
|
||||
MODULES := ""; (* additional modules path which can be specified on commandline and will be added to the OBERON variable; noch *)
|
||||
getcwd(CWD);
|
||||
Args.GetEnv ("MODULES", MODULES);
|
||||
Args.GetEnv("OBERON", OBERON);
|
||||
(* always have current directory in module search path, noch *)
|
||||
Strings.Append(":.:", OBERON);
|
||||
Strings.Append(MODULES, OBERON);
|
||||
Strings.Append(":", OBERON);
|
||||
Strings.Append(version.prefix, OBERON);
|
||||
Strings.Append("/lib/voc/sym:", OBERON);
|
||||
Args.GetEnv("OBERON_LIB", LIB);
|
||||
TimeUnit := 1000; timeStart := 0; timeStart := Time()
|
||||
END Kernel.
|
||||
|
|
|
|||
179
src/lib/system/linux/gnuc/Kernel0.Mod
Normal file
179
src/lib/system/linux/gnuc/Kernel0.Mod
Normal file
|
|
@ -0,0 +1,179 @@
|
|||
MODULE Kernel0;
|
||||
(*
|
||||
J. Templ, 16.4.95
|
||||
communication with C-runtime and storage management
|
||||
*)
|
||||
(* version for bootstrapping voc *)
|
||||
|
||||
IMPORT SYSTEM, Unix, Args, Strings := oocOakStrings, version;
|
||||
|
||||
TYPE
|
||||
RealTime = POINTER TO TimeDesc;
|
||||
TimeDesc = RECORD
|
||||
sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: LONGINT
|
||||
(* sec, min, hour, mday, mon, year, wday, isdst, zone, gmtoff: INTEGER*)
|
||||
END ;
|
||||
|
||||
KeyCmd* = PROCEDURE;
|
||||
|
||||
ObjFinalizer* = PROCEDURE(obj: SYSTEM.PTR);
|
||||
|
||||
|
||||
VAR
|
||||
(* trap handling *)
|
||||
trapEnv*: Unix.JmpBuf; (* saved stack environment for trap handling *)
|
||||
|
||||
(* oberon heap management *)
|
||||
nofiles*: LONGINT;
|
||||
|
||||
(* input event handling *)
|
||||
readSet*, readySet*: Unix.FdSet;
|
||||
|
||||
FKey*: ARRAY 16 OF KeyCmd;
|
||||
|
||||
littleEndian*: BOOLEAN;
|
||||
|
||||
TimeUnit*: LONGINT; (* 1 sec *)
|
||||
|
||||
LIB*, CWD*: ARRAY 256 OF CHAR;
|
||||
OBERON*: ARRAY 1024 OF CHAR;
|
||||
MODULES-: ARRAY 1024 OF CHAR;
|
||||
|
||||
prefix*, fullprefix* : ARRAY 256 OF CHAR;
|
||||
timeStart: LONGINT; (* milliseconds *)
|
||||
|
||||
|
||||
PROCEDURE -includesetjmp()
|
||||
'#include "setjmp.h"';
|
||||
(* for localtime *)
|
||||
PROCEDURE -includetime()
|
||||
'#include "time.h"';
|
||||
|
||||
PROCEDURE -Lock*()
|
||||
"SYSTEM_lock++";
|
||||
|
||||
PROCEDURE -Unlock*()
|
||||
"SYSTEM_lock--; if (SYSTEM_interrupted && SYSTEM_lock == 0) __HALT(-9)";
|
||||
|
||||
PROCEDURE -Exit*(n: LONGINT)
|
||||
"exit(n)";
|
||||
|
||||
PROCEDURE -sigsetjmp*(VAR env: Unix.JmpBuf; savemask: LONGINT): LONGINT
|
||||
"__sigsetjmp(env, savemask)";
|
||||
|
||||
PROCEDURE -siglongjmp*(VAR env:Unix.JmpBuf; val: LONGINT)
|
||||
"siglongjmp(env, val)";
|
||||
|
||||
PROCEDURE -heapsize*(): LONGINT
|
||||
"SYSTEM_heapsize";
|
||||
|
||||
PROCEDURE -allocated*(): LONGINT
|
||||
"SYSTEM_allocated";
|
||||
|
||||
PROCEDURE -localtime(VAR clock: LONGINT): RealTime
|
||||
"(Kernel0_RealTime)localtime(clock)";
|
||||
|
||||
PROCEDURE -malloc*(size: LONGINT): LONGINT
|
||||
"(LONGINT)malloc(size)";
|
||||
|
||||
PROCEDURE -free*(adr: LONGINT)
|
||||
"(void)free(adr)";
|
||||
|
||||
PROCEDURE -getcwd(VAR cwd: Unix.Name)
|
||||
"getcwd(cwd, cwd__len)";
|
||||
|
||||
|
||||
PROCEDURE GetClock* (VAR t, d: LONGINT);
|
||||
VAR tv: Unix.Timeval; tz: Unix.Timezone; time: RealTime;
|
||||
l : LONGINT;
|
||||
BEGIN
|
||||
l := Unix.Gettimeofday(tv, tz);
|
||||
time := localtime(tv.sec);
|
||||
t := time.sec + ASH(time.min, 6) + ASH(time.hour, 12);
|
||||
d := time.mday + ASH(time.mon+1, 5) + ASH(time.year MOD 100, 9);
|
||||
END GetClock;
|
||||
|
||||
PROCEDURE SetClock* (t, d: LONGINT);
|
||||
VAR err: ARRAY 25 OF CHAR;
|
||||
BEGIN err := "not yet implemented"; HALT(99)
|
||||
END SetClock;
|
||||
|
||||
PROCEDURE Time*(): LONGINT;
|
||||
VAR timeval: Unix.Timeval; timezone: Unix.Timezone;
|
||||
l : LONGINT;
|
||||
BEGIN
|
||||
l := Unix.Gettimeofday(timeval, timezone);
|
||||
RETURN (timeval.usec DIV 1000 + timeval.sec * 1000 - timeStart) MOD 7FFFFFFFH
|
||||
END Time;
|
||||
|
||||
(*
|
||||
PROCEDURE UserTime*(): LONGINT;
|
||||
VAR rusage: Unix.Rusage;
|
||||
BEGIN
|
||||
Unix.Getrusage(0, S.ADR(rusage));
|
||||
RETURN rusage.utime.sec*1000 + rusage.utime.usec DIV 1000
|
||||
(* + rusage.stime.sec*1000 + rusage.stime.usec DIV 1000*)
|
||||
END UserTime;
|
||||
*)
|
||||
|
||||
PROCEDURE Select*(delay: LONGINT);
|
||||
VAR rs, ws, xs: Unix.FdSet; n: LONGINT; tv: Unix.Timeval;
|
||||
BEGIN
|
||||
rs := readSet;
|
||||
FOR n := 0 TO 7 DO ws[n] := {}; xs[n] := {}; readySet[n] := {} END;
|
||||
IF delay < 0 THEN delay := 0 END ;
|
||||
tv.sec := delay DIV 1000; tv.usec := delay MOD 1000 * 1000;
|
||||
n := Unix.Select(256, rs, ws, xs, tv);
|
||||
IF n >= 0 THEN readySet := rs END
|
||||
END Select;
|
||||
|
||||
PROCEDURE -GC*(markStack: BOOLEAN)
|
||||
"SYSTEM_GC(markStack)";
|
||||
|
||||
PROCEDURE -RegisterObject*(obj: SYSTEM.PTR; finalize: ObjFinalizer)
|
||||
"SYSTEM_REGFIN(obj, finalize)";
|
||||
|
||||
PROCEDURE -SetHalt*(p: PROCEDURE(n: LONGINT))
|
||||
"SYSTEM_Halt = p";
|
||||
|
||||
PROCEDURE InstallTermHandler*(p: PROCEDURE);
|
||||
(* not yet supported; no Modules.Free *)
|
||||
END InstallTermHandler;
|
||||
|
||||
PROCEDURE LargestAvailable*(): LONGINT;
|
||||
BEGIN
|
||||
(* dummy proc for System 3 compatibility
|
||||
no meaningful value except may be the remaining swap space can be returned
|
||||
in the context of an extensible heap *)
|
||||
RETURN MAX(LONGINT)
|
||||
END LargestAvailable;
|
||||
|
||||
PROCEDURE Halt(n: LONGINT);
|
||||
VAR res: LONGINT;
|
||||
BEGIN res := Unix.Kill(Unix.Getpid(), 4);
|
||||
END Halt;
|
||||
|
||||
PROCEDURE EndianTest;
|
||||
VAR i: LONGINT; dmy: INTEGER;
|
||||
BEGIN
|
||||
dmy := 1; i := SYSTEM.ADR(dmy);
|
||||
SYSTEM.GET(i, littleEndian); (* indirection via i avoids warning on SUN cc -O *)
|
||||
END EndianTest;
|
||||
|
||||
BEGIN
|
||||
EndianTest();
|
||||
SetHalt(Halt);
|
||||
CWD := ""; OBERON := "."; LIB := "";
|
||||
MODULES := ""; (* additional modules path which can be specified on commandline and will be added to the OBERON variable; noch *)
|
||||
getcwd(CWD);
|
||||
Args.GetEnv ("MODULES", MODULES);
|
||||
Args.GetEnv("OBERON", OBERON);
|
||||
(* always have current directory in module search path, noch *)
|
||||
Strings.Append(":.:", OBERON);
|
||||
Strings.Append(MODULES, OBERON);
|
||||
Strings.Append(":", OBERON);
|
||||
Strings.Append(version.prefix, OBERON);
|
||||
Strings.Append("/lib/voc/sym:", OBERON);
|
||||
Args.GetEnv("OBERON_LIB", LIB);
|
||||
TimeUnit := 1000; timeStart := 0; timeStart := Time()
|
||||
END Kernel0.
|
||||
859
src/lib/system/linux/gnuc/Texts.Mod
Normal file
859
src/lib/system/linux/gnuc/Texts.Mod
Normal file
|
|
@ -0,0 +1,859 @@
|
|||
MODULE Texts; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12.91**) (* << RC, MB, JT *)
|
||||
IMPORT
|
||||
Files, Modules, Reals;
|
||||
|
||||
(*--- insert field e: Elem into Texts.Scanner and change Texts.Scan to set it in case of class=6 *)
|
||||
|
||||
|
||||
CONST
|
||||
Displaywhite = 15;
|
||||
ElemChar* = 1CX;
|
||||
TAB = 9X; CR = 0DX; maxD = 9;
|
||||
(**FileMsg.id**)
|
||||
load* = 0; store* = 1;
|
||||
(**Notifier op**)
|
||||
replace* = 0; insert* = 1; delete* = 2;
|
||||
(**Scanner.class**)
|
||||
Inval* = 0; Name* = 1; String* = 2; Int* = 3; Real* = 4; LongReal* = 5; Char* = 6;
|
||||
|
||||
textTag = 0F0X; DocBlockId = 0F7X; version = 01X;
|
||||
|
||||
TYPE
|
||||
FontsFont = POINTER TO FontDesc;
|
||||
FontDesc = RECORD
|
||||
name: ARRAY 32 OF CHAR;
|
||||
END ;
|
||||
|
||||
Run = POINTER TO RunDesc;
|
||||
RunDesc = RECORD
|
||||
prev, next: Run;
|
||||
len: LONGINT;
|
||||
fnt: FontsFont;
|
||||
col, voff: SHORTINT;
|
||||
ascii: BOOLEAN (* << *)
|
||||
END;
|
||||
|
||||
Piece = POINTER TO PieceDesc;
|
||||
PieceDesc = RECORD (RunDesc)
|
||||
file: Files.File;
|
||||
org: LONGINT
|
||||
END;
|
||||
|
||||
Elem* = POINTER TO ElemDesc;
|
||||
Buffer* = POINTER TO BufDesc;
|
||||
Text* = POINTER TO TextDesc;
|
||||
|
||||
ElemMsg* = RECORD END;
|
||||
Handler* = PROCEDURE (e: Elem; VAR msg: ElemMsg);
|
||||
|
||||
ElemDesc* = RECORD (RunDesc)
|
||||
W*, H*: LONGINT;
|
||||
handle*: Handler;
|
||||
base: Text
|
||||
END;
|
||||
|
||||
FileMsg* = RECORD (ElemMsg)
|
||||
id*: INTEGER;
|
||||
pos*: LONGINT;
|
||||
r*: Files.Rider
|
||||
END;
|
||||
|
||||
CopyMsg* = RECORD (ElemMsg)
|
||||
e*: Elem
|
||||
END;
|
||||
|
||||
IdentifyMsg* = RECORD (ElemMsg)
|
||||
mod*, proc*: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
|
||||
BufDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head: Run
|
||||
END;
|
||||
|
||||
TextDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head, cache: Run;
|
||||
corg: LONGINT
|
||||
END;
|
||||
|
||||
Reader* = RECORD
|
||||
eot*: BOOLEAN;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
elem*: Elem;
|
||||
rider: Files.Rider;
|
||||
run: Run;
|
||||
org, off: LONGINT
|
||||
END;
|
||||
|
||||
Scanner* = RECORD (Reader)
|
||||
nextCh*: CHAR;
|
||||
line*, class*: INTEGER;
|
||||
i*: LONGINT;
|
||||
x*: REAL;
|
||||
y*: LONGREAL;
|
||||
c*: CHAR;
|
||||
len*: SHORTINT;
|
||||
s*: ARRAY 64 OF CHAR (* << *)
|
||||
END;
|
||||
|
||||
Writer* = RECORD
|
||||
buf*: Buffer;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
rider: Files.Rider;
|
||||
file: Files.File
|
||||
END;
|
||||
|
||||
Alien = POINTER TO RECORD (ElemDesc)
|
||||
file: Files.File;
|
||||
org, span: LONGINT;
|
||||
mod, proc: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
VAR
|
||||
new*: Elem;
|
||||
del: Buffer;
|
||||
FontsDefault: FontsFont;
|
||||
|
||||
|
||||
PROCEDURE FontsThis(VAR name: ARRAY OF CHAR): FontsFont;
|
||||
VAR F: FontsFont;
|
||||
BEGIN
|
||||
NEW(F); COPY(name, F.name); RETURN F
|
||||
END FontsThis;
|
||||
|
||||
(* run primitives *)
|
||||
|
||||
PROCEDURE Find (T: Text; VAR pos: LONGINT; VAR u: Run; VAR org, off: LONGINT);
|
||||
VAR v: Run; m: LONGINT;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len; u := T.head; org := T.len; off := 0; T.cache := T.head; T.corg := 0
|
||||
ELSE v := T.cache.next; m := pos - T.corg;
|
||||
IF pos >= T.corg THEN
|
||||
WHILE m >= v.len DO DEC(m, v.len); v := v.next END
|
||||
ELSE
|
||||
WHILE m < 0 DO v := v.prev; INC(m, v.len) END;
|
||||
END;
|
||||
u := v; org := pos - m; off := m; T.cache := v.prev; T.corg := org
|
||||
END
|
||||
END Find;
|
||||
|
||||
PROCEDURE Split (off: LONGINT; VAR u, un: Run);
|
||||
VAR p, U: Piece;
|
||||
BEGIN
|
||||
IF off = 0 THEN un := u; u := un.prev
|
||||
ELSIF off >= u.len THEN un := u.next
|
||||
ELSE NEW(p); un := p; U := u(Piece);
|
||||
p^ := U^; INC(p.org, off); DEC(p.len, off); DEC(U.len, p.len);
|
||||
p.ascii := u.ascii; p.prev := U; p.next := U.next; p.next.prev := p; U.next := p (* << *)
|
||||
END
|
||||
END Split;
|
||||
|
||||
PROCEDURE Merge (T: Text; u: Run; VAR v: Run);
|
||||
VAR p, q: Piece;
|
||||
BEGIN
|
||||
IF (u IS Piece) & (v IS Piece) & (u.fnt.name = v.fnt.name) & (u.col = v.col) & (u.voff = v.voff)
|
||||
& (u(Piece).ascii = v(Piece).ascii) THEN (* << *)
|
||||
p := u(Piece); q := v(Piece);
|
||||
IF (p.file = q.file) & (p.org + p.len = q.org) THEN
|
||||
IF T.cache = u THEN INC(T.corg, q.len)
|
||||
ELSIF T.cache = v THEN T.cache := T.head; T.corg := 0
|
||||
END;
|
||||
INC(p.len, q.len); v := v.next
|
||||
END
|
||||
END
|
||||
END Merge;
|
||||
|
||||
PROCEDURE Splice (un, v, w: Run; base: Text); (* (u, un) -> (u, v, w, un) *)
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF v # w.next THEN u := un.prev;
|
||||
u.next := v; v.prev := u; un.prev := w; w.next := un;
|
||||
REPEAT
|
||||
IF v IS Elem THEN v(Elem).base := base END;
|
||||
v := v.next
|
||||
UNTIL v = un
|
||||
END
|
||||
END Splice;
|
||||
|
||||
PROCEDURE ClonePiece (p: Piece): Piece;
|
||||
VAR q: Piece;
|
||||
BEGIN NEW(q); q^ := p^; RETURN q
|
||||
END ClonePiece;
|
||||
|
||||
PROCEDURE CloneElem (e: Elem): Elem;
|
||||
VAR msg: CopyMsg;
|
||||
BEGIN msg.e := NIL; e.handle(e, msg); RETURN msg.e
|
||||
END CloneElem;
|
||||
|
||||
|
||||
(** Elements **)
|
||||
|
||||
PROCEDURE CopyElem* (SE, DE: Elem);
|
||||
BEGIN DE.len := SE.len; DE.fnt := SE.fnt; DE.col := SE.col; DE.voff := SE.voff;
|
||||
DE.W := SE.W; DE.H := SE.H; DE.handle := SE.handle
|
||||
END CopyElem;
|
||||
|
||||
PROCEDURE ElemBase* (E: Elem): Text;
|
||||
BEGIN RETURN E.base
|
||||
END ElemBase;
|
||||
|
||||
PROCEDURE ElemPos* (E: Elem): LONGINT;
|
||||
VAR u: Run; pos: LONGINT;
|
||||
BEGIN u := E.base.head.next; pos := 0;
|
||||
WHILE u # E DO pos := pos + u.len; u := u.next END;
|
||||
RETURN pos
|
||||
END ElemPos;
|
||||
|
||||
|
||||
PROCEDURE HandleAlien (E: Elem; VAR msg: ElemMsg);
|
||||
VAR e: Alien; r: Files.Rider; i: LONGINT; ch: CHAR;
|
||||
BEGIN
|
||||
WITH E: Alien DO
|
||||
IF msg IS CopyMsg THEN
|
||||
WITH msg: CopyMsg DO NEW(e); CopyElem(E, e);
|
||||
e.file := E.file; e.org := E.org; e.span := E.span; e.mod := E.mod; e.proc := E.proc;
|
||||
msg.e := e
|
||||
END
|
||||
ELSIF msg IS IdentifyMsg THEN
|
||||
WITH msg: IdentifyMsg DO
|
||||
COPY(E.mod, msg.mod); COPY(E.proc, msg.proc); msg.mod[31] := 1X (*alien*)
|
||||
END
|
||||
ELSIF msg IS FileMsg THEN
|
||||
WITH msg: FileMsg DO
|
||||
IF msg.id = store THEN Files.Set(r, E.file, E.org); i := E.span;
|
||||
WHILE i > 0 DO Files.Read(r, ch); Files.Write(msg.r, ch); DEC(i) END
|
||||
END
|
||||
END
|
||||
END
|
||||
END
|
||||
END HandleAlien;
|
||||
|
||||
|
||||
(** Buffers **)
|
||||
|
||||
PROCEDURE OpenBuf* (B: Buffer);
|
||||
VAR u: Run;
|
||||
BEGIN NEW(u); u.next := u; u.prev := u; B.head := u; B.len := 0
|
||||
END OpenBuf;
|
||||
|
||||
PROCEDURE Copy* (SB, DB: Buffer);
|
||||
VAR u, v, vn: Run;
|
||||
BEGIN u := SB.head.next; v := DB.head.prev;
|
||||
WHILE u # SB.head DO
|
||||
IF u IS Piece THEN vn := ClonePiece(u(Piece)) ELSE vn := CloneElem(u(Elem)) END;
|
||||
v.next := vn; vn.prev := v; v := vn; u := u.next
|
||||
END;
|
||||
v.next := DB.head; DB.head.prev := v;
|
||||
INC(DB.len, SB.len)
|
||||
END Copy;
|
||||
|
||||
PROCEDURE Recall* (VAR B: Buffer);
|
||||
BEGIN B := del; del := NIL
|
||||
END Recall;
|
||||
|
||||
|
||||
(** Texts **)
|
||||
|
||||
PROCEDURE Save* (T: Text; beg, end: LONGINT; B: Buffer);
|
||||
VAR u, v, w, wn: Run; uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Find(T, end, v, vo, vd);
|
||||
w := B.head.prev;
|
||||
WHILE u # v DO
|
||||
IF u IS Piece THEN wn := ClonePiece(u(Piece)); DEC(wn.len, ud); INC(wn(Piece).org, ud)
|
||||
ELSE wn := CloneElem(u(Elem))
|
||||
END;
|
||||
w.next := wn; wn.prev := w; w := wn; u := u.next; ud := 0
|
||||
END;
|
||||
IF vd > 0 THEN (*v IS Piece*) wn := ClonePiece(v(Piece)); wn.len := vd - ud; INC(wn(Piece).org, ud);
|
||||
w.next := wn; wn.prev := w; w := wn
|
||||
END;
|
||||
w.next := B.head; B.head.prev := w;
|
||||
INC(B.len, end - beg)
|
||||
END Save;
|
||||
|
||||
PROCEDURE Insert* (T: Text; pos: LONGINT; B: Buffer);
|
||||
VAR u, un, v: Run; p, q: Piece; uo, ud, len: LONGINT;
|
||||
BEGIN Find(T, pos, u, uo, ud); Split(ud, u, un);
|
||||
len := B.len; v := B.head.next;
|
||||
Merge(T, u, v); Splice(un, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Insert;
|
||||
|
||||
PROCEDURE Append* (T: Text; B: Buffer);
|
||||
VAR v: Run; pos, len: LONGINT;
|
||||
BEGIN pos := T.len; len := B.len; v := B.head.next;
|
||||
Merge(T, T.head.prev, v); Splice(T.head, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Append;
|
||||
|
||||
PROCEDURE Delete* (T: Text; beg, end: LONGINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN
|
||||
Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
NEW(del); OpenBuf(del); del.len := end - beg;
|
||||
Splice(del.head, un, v, NIL);
|
||||
Merge(T, u, vn); u.next := vn; vn.prev := u;
|
||||
DEC(T.len, end - beg);
|
||||
END Delete;
|
||||
|
||||
PROCEDURE ChangeLooks* (T: Text; beg, end: LONGINT; sel: SET; fnt: FontsFont; col, voff: SHORTINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
WHILE un # vn DO
|
||||
IF (0 IN sel) & (fnt # NIL) THEN un.fnt := fnt END;
|
||||
IF 1 IN sel THEN un.col := col END;
|
||||
IF 2 IN sel THEN un.voff := voff END;
|
||||
Merge(T, u, un);
|
||||
IF u.next = un THEN u := un; un := un.next ELSE u.next := un; un.prev := u END
|
||||
END;
|
||||
Merge(T, u, un); u.next := un; un.prev := u;
|
||||
END ChangeLooks;
|
||||
|
||||
|
||||
(** Readers **)
|
||||
|
||||
PROCEDURE OpenReader* (VAR R: Reader; T: Text; pos: LONGINT);
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len END;
|
||||
Find(T, pos, u, R.org, R.off); R.run := u; R.eot := FALSE;
|
||||
IF u IS Piece THEN
|
||||
Files.Set(R.rider, u(Piece).file, u(Piece).org + R.off)
|
||||
END
|
||||
END OpenReader;
|
||||
|
||||
PROCEDURE Read* (VAR R: Reader; VAR ch: CHAR);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run; R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; INC(R.off);
|
||||
IF u IS Piece THEN Files.Read(R.rider, ch); R.elem := NIL;
|
||||
IF (ch = 0AX) & u(Piece).ascii THEN ch := CR END (* << LF to CR *)
|
||||
ELSIF u IS Elem THEN ch := ElemChar; R.elem := u(Elem)
|
||||
ELSE ch := 0X; R.elem := NIL; R.eot := TRUE
|
||||
END;
|
||||
IF R.off = u.len THEN INC(R.org, u.len); u := u.next;
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO Files.Set(R.rider, u.file, u.org) END
|
||||
END;
|
||||
R.run := u; R.off := 0
|
||||
END
|
||||
END Read;
|
||||
|
||||
PROCEDURE ReadElem* (VAR R: Reader);
|
||||
VAR u, un: Run;
|
||||
BEGIN u := R.run;
|
||||
WHILE u IS Piece DO INC(R.org, u.len); u := u.next END;
|
||||
IF u IS Elem THEN un := u.next; R.run := un; INC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem);
|
||||
IF un IS Piece THEN
|
||||
WITH un: Piece DO Files.Set(R.rider, un.file, un.org) END
|
||||
END
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadElem;
|
||||
|
||||
PROCEDURE ReadPrevElem* (VAR R: Reader);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run.prev;
|
||||
WHILE u IS Piece DO DEC(R.org, u.len); u := u.prev END;
|
||||
IF u IS Elem THEN R.run := u; DEC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem)
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadPrevElem;
|
||||
|
||||
PROCEDURE Pos* (VAR R: Reader): LONGINT;
|
||||
BEGIN RETURN R.org + R.off
|
||||
END Pos;
|
||||
|
||||
|
||||
(** Scanners --------------- NW --------------- **)
|
||||
|
||||
PROCEDURE OpenScanner* (VAR S: Scanner; T: Text; pos: LONGINT);
|
||||
BEGIN OpenReader(S, T, pos); S.line := 0; S.nextCh := " "
|
||||
END OpenScanner;
|
||||
|
||||
(*IEEE floating point formats:
|
||||
x = 2^(e-127) * 1.m bit 0: sign, bits 1- 8: e, bits 9-31: m
|
||||
x = 2^(e-1023) * 1.m bit 0: sign, bits 1-11: e, bits 12-63: m *)
|
||||
|
||||
PROCEDURE Scan* (VAR S: Scanner);
|
||||
CONST maxD = 32;
|
||||
VAR ch, term: CHAR;
|
||||
neg, negE, hex: BOOLEAN;
|
||||
i, j, h: SHORTINT;
|
||||
e: INTEGER; k: LONGINT;
|
||||
x, f: REAL; y, g: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE ReadScaleFactor;
|
||||
BEGIN Read(S, ch);
|
||||
IF ch = "-" THEN negE := TRUE; Read(S, ch)
|
||||
ELSE negE := FALSE;
|
||||
IF ch = "+" THEN Read(S, ch) END
|
||||
END;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO
|
||||
e := e*10 + ORD(ch) - 30H; Read(S, ch)
|
||||
END
|
||||
END ReadScaleFactor;
|
||||
|
||||
BEGIN ch := S.nextCh; i := 0;
|
||||
LOOP
|
||||
IF ch = CR THEN INC(S.line)
|
||||
ELSIF (ch # " ") & (ch # TAB) THEN EXIT
|
||||
END ;
|
||||
Read(S, ch)
|
||||
END;
|
||||
IF ("A" <= CAP(ch)) & (CAP(ch) <= "Z") OR (ch = "/") OR (ch = ".") THEN (*name*) (* << *)
|
||||
REPEAT S.s[i] := ch; INC(i); Read(S, ch)
|
||||
UNTIL (CAP(ch) > "Z") & (ch # "_") (* << *)
|
||||
OR ("A" > CAP(ch)) & (ch > "9")
|
||||
OR ("0" > ch) & (ch # ".") & (ch # "/") (* << *)
|
||||
OR (i = 63); (* << *)
|
||||
S.s[i] := 0X; S.len := i; S.class := 1
|
||||
ELSIF ch = 22X THEN (*literal string*)
|
||||
Read(S, ch);
|
||||
WHILE (ch # 22X) & (ch >= " ") & (i # 63) DO (* << *)
|
||||
S.s[i] := ch; INC(i); Read(S, ch)
|
||||
END;
|
||||
S.s[i] := 0X; S.len := i+1; Read(S, ch); S.class := 2
|
||||
ELSE
|
||||
IF ch = "-" THEN neg := TRUE; Read(S, ch) ELSE neg := FALSE END ;
|
||||
IF ("0" <= ch) & (ch <= "9") THEN (*number*)
|
||||
hex := FALSE; j := 0;
|
||||
LOOP d[i] := ch; INC(i); Read(S, ch);
|
||||
IF ch < "0" THEN EXIT END;
|
||||
IF "9" < ch THEN
|
||||
IF ("A" <= ch) & (ch <= "F") THEN hex := TRUE; ch := CHR(ORD(ch)-7)
|
||||
ELSIF ("a" <= ch) & (ch <= "f") THEN hex := TRUE; ch := CHR(ORD(ch)-27H)
|
||||
ELSE EXIT
|
||||
END
|
||||
END
|
||||
END;
|
||||
IF ch = "H" THEN (*hex number*)
|
||||
Read(S, ch); S.class := 3;
|
||||
IF i-j > 8 THEN j := i-8 END ;
|
||||
k := ORD(d[j]) - 30H; INC(j);
|
||||
IF (i-j = 7) & (k >= 8) THEN DEC(k, 16) END ;
|
||||
WHILE j < i DO k := k*10H + (ORD(d[j]) - 30H); INC(j) END ;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END
|
||||
ELSIF ch = "." THEN (*read real*)
|
||||
Read(S, ch); h := i;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO d[i] := ch; INC(i); Read(S, ch) END ;
|
||||
IF ch = "D" THEN
|
||||
e := 0; y := 0; g := 1;
|
||||
REPEAT y := y*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO g := g/10; y := (ORD(d[j]) - 30H)*g + y; INC(j) END ;
|
||||
ReadScaleFactor;
|
||||
IF negE THEN
|
||||
IF e <= 308 THEN y := y / Reals.TenL(e) ELSE y := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 308 THEN y := Reals.TenL(e) * y ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN y := -y END ;
|
||||
S.class := 5; S.y := y
|
||||
ELSE e := 0; x := 0; f := 1;
|
||||
REPEAT x := x*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO f := f/10; x := (ORD(d[j])-30H)*f + x; INC(j) END;
|
||||
IF ch = "E" THEN ReadScaleFactor END ;
|
||||
IF negE THEN
|
||||
IF e <= 38 THEN x := x / Reals.Ten(e) ELSE x := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 38 THEN x := Reals.Ten(e) * x ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN x := -x END ;
|
||||
S.class := 4; S.x := x
|
||||
END ;
|
||||
IF hex THEN S.class := 0 END
|
||||
ELSE (*decimal integer*)
|
||||
S.class := 3; k := 0;
|
||||
REPEAT k := k*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = i;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END;
|
||||
IF hex THEN S.class := 0 ELSE S.class := 3 END
|
||||
END
|
||||
ELSE S.class := 6;
|
||||
IF neg THEN S.c := "-" ELSE S.c := ch; Read(S, ch) END
|
||||
END
|
||||
END;
|
||||
S.nextCh := ch
|
||||
END Scan;
|
||||
|
||||
|
||||
(** Writers **)
|
||||
|
||||
PROCEDURE OpenWriter* (VAR W: Writer);
|
||||
BEGIN NEW(W.buf); OpenBuf(W.buf);
|
||||
W.fnt := FontsDefault; W.col := Displaywhite; W.voff := 0;
|
||||
W.file := Files.New(""); Files.Set(W.rider, W.file, 0)
|
||||
END OpenWriter;
|
||||
|
||||
PROCEDURE SetFont* (VAR W: Writer; fnt: FontsFont);
|
||||
BEGIN W.fnt := fnt
|
||||
END SetFont;
|
||||
|
||||
PROCEDURE SetColor* (VAR W: Writer; col: SHORTINT);
|
||||
BEGIN W.col := col
|
||||
END SetColor;
|
||||
|
||||
PROCEDURE SetOffset* (VAR W: Writer; voff: SHORTINT);
|
||||
BEGIN W.voff := voff
|
||||
END SetOffset;
|
||||
|
||||
|
||||
PROCEDURE Write* (VAR W: Writer; ch: CHAR);
|
||||
VAR u, un: Run; p: Piece;
|
||||
BEGIN Files.Write(W.rider, ch); INC(W.buf.len); un := W.buf.head; u := un.prev;
|
||||
IF (u IS Piece) & (u(Piece).file = W.file) & (u.fnt.name = W.fnt.name) & (u.col = W.col) & (u.voff = W.voff)
|
||||
& ~u(Piece).ascii THEN (* << *)
|
||||
INC(u.len)
|
||||
ELSE NEW(p); u.next := p; p.prev := u; p.next := un; un.prev := p;
|
||||
p.len := 1; p.fnt := W.fnt; p.col := W.col; p.voff := W.voff;
|
||||
p.file := W.file; p.org := Files.Length(W.file) - 1; p.ascii := FALSE (* << *)
|
||||
END
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteElem* (VAR W: Writer; e: Elem);
|
||||
VAR u, un: Run;
|
||||
BEGIN
|
||||
IF e.base # NIL THEN HALT(99) END;
|
||||
INC(W.buf.len); e.len := 1; e.fnt := W.fnt; e.col := W.col; e.voff := W.voff;
|
||||
un := W.buf.head; u := un.prev; u.next := e; e.prev := u; e.next := un; un.prev := e
|
||||
END WriteElem;
|
||||
|
||||
PROCEDURE WriteLn* (VAR W: Writer);
|
||||
BEGIN Write(W, CR)
|
||||
END WriteLn;
|
||||
|
||||
PROCEDURE WriteString* (VAR W: Writer; s: ARRAY OF CHAR);
|
||||
VAR i: INTEGER;
|
||||
BEGIN i := 0;
|
||||
WHILE s[i] >= " " DO Write(W, s[i]); INC(i) END
|
||||
END WriteString;
|
||||
|
||||
PROCEDURE WriteInt* (VAR W: Writer; x, n: LONGINT);
|
||||
VAR i: INTEGER; x0: LONGINT;
|
||||
a: ARRAY 11 OF CHAR;
|
||||
BEGIN i := 0;
|
||||
IF x < 0 THEN
|
||||
IF x = MIN(LONGINT) THEN WriteString(W, " -2147483648"); RETURN
|
||||
ELSE DEC(n); x0 := -x
|
||||
END
|
||||
ELSE x0 := x
|
||||
END;
|
||||
REPEAT
|
||||
a[i] := CHR(x0 MOD 10 + 30H); x0 := x0 DIV 10; INC(i)
|
||||
UNTIL x0 = 0;
|
||||
WHILE n > i DO Write(W, " "); DEC(n) END;
|
||||
IF x < 0 THEN Write(W, "-") END;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteInt;
|
||||
|
||||
PROCEDURE WriteHex* (VAR W: Writer; x: LONGINT);
|
||||
VAR i: INTEGER; y: LONGINT;
|
||||
a: ARRAY 10 OF CHAR;
|
||||
BEGIN i := 0; Write(W, " ");
|
||||
REPEAT y := x MOD 10H;
|
||||
IF y < 10 THEN a[i] := CHR(y + 30H) ELSE a[i] := CHR(y + 37H) END;
|
||||
x := x DIV 10H; INC(i)
|
||||
UNTIL i = 8;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteHex;
|
||||
|
||||
PROCEDURE WriteReal* (VAR W: Writer; x: REAL; n: INTEGER);
|
||||
VAR e: INTEGER; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 255 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 9 THEN n := 3 ELSE DEC(n, 6) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 8;
|
||||
(*there are 2 < n <= 8 digits to be written*)
|
||||
IF x < 0.0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := (e - 127) * 77 DIV 256;
|
||||
IF e >= 0 THEN x := x / Reals.Ten(e) ELSE x := Reals.Ten(-e) * x END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
x0 := Reals.Ten(n-1); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN x := x*0.1; INC(e) END;
|
||||
Reals.Convert(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "E");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 10 + 30H)); Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteReal;
|
||||
|
||||
PROCEDURE WriteRealFix* (VAR W: Writer; x: REAL; n, k: INTEGER);
|
||||
VAR e, i: INTEGER; sign: CHAR; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE seq(ch: CHAR; n: INTEGER);
|
||||
BEGIN WHILE n > 0 DO Write(W, ch); DEC(n) END
|
||||
END seq;
|
||||
|
||||
PROCEDURE dig(n: INTEGER);
|
||||
BEGIN
|
||||
WHILE n > 0 DO
|
||||
DEC(i); Write(W, d[i]); DEC(n)
|
||||
END
|
||||
END dig;
|
||||
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF k < 0 THEN k := 0 END;
|
||||
IF e = 0 THEN seq(" ", n-k-2); Write(W, "0"); seq(" ", k+1)
|
||||
ELSIF e = 255 THEN WriteString(W, " NaN"); seq(" ", n-4)
|
||||
ELSE e := (e - 127) * 77 DIV 256;
|
||||
IF x < 0 THEN sign := "-"; x := -x ELSE sign := " " END;
|
||||
IF e >= 0 THEN (*x >= 1.0, 77/256 = log 2*) x := x/Reals.Ten(e)
|
||||
ELSE (*x < 1.0*) x := Reals.Ten(-e) * x
|
||||
END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
(* 1 <= x < 10 *)
|
||||
IF k+e >= maxD-1 THEN k := maxD-1-e
|
||||
ELSIF k+e < 0 THEN k := -e; x := 0.0
|
||||
END;
|
||||
x0 := Reals.Ten(k+e); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN INC(e) END;
|
||||
(*e = no. of digits before decimal point*)
|
||||
INC(e); i := k+e; Reals.Convert(x, i, d);
|
||||
IF e > 0 THEN
|
||||
seq(" ", n-e-k-2); Write(W, sign); dig(e);
|
||||
Write(W, "."); dig(k)
|
||||
ELSE seq(" ", n-k-3);
|
||||
Write(W, sign); Write(W, "0"); Write(W, ".");
|
||||
seq("0", -e); dig(k+e)
|
||||
END
|
||||
END
|
||||
END WriteRealFix;
|
||||
|
||||
PROCEDURE WriteRealHex* (VAR W: Writer; x: REAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 8 OF CHAR;
|
||||
BEGIN Reals.ConvertH(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 8
|
||||
END WriteRealHex;
|
||||
|
||||
PROCEDURE WriteLongReal* (VAR W: Writer; x: LONGREAL; n: INTEGER);
|
||||
CONST maxD = 16;
|
||||
VAR e: INTEGER; x0: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.ExpoL(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 2047 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 10 THEN n := 3 ELSE DEC(n, 7) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= maxD;
|
||||
(*there are 2 <= n <= maxD digits to be written*)
|
||||
IF x < 0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := SHORT(LONG(e - 1023) * 77 DIV 256);
|
||||
IF e >= 0 THEN x := x / Reals.TenL(e) ELSE x := Reals.TenL(-e) * x END ;
|
||||
IF x >= 10.0D0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
x0 := Reals.TenL(n-1); x := x0*x + 0.5D0;
|
||||
IF x >= 10.0D0*x0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
Reals.ConvertL(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "D");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 100 + 30H)); e := e MOD 100;
|
||||
Write(W, CHR(e DIV 10 + 30H));
|
||||
Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteLongReal;
|
||||
|
||||
PROCEDURE WriteLongRealHex* (VAR W: Writer; x: LONGREAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 16 OF CHAR;
|
||||
BEGIN Reals.ConvertHL(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 16
|
||||
END WriteLongRealHex;
|
||||
|
||||
PROCEDURE WriteDate* (VAR W: Writer; t, d: LONGINT);
|
||||
|
||||
PROCEDURE WritePair(ch: CHAR; x: LONGINT);
|
||||
BEGIN Write(W, ch);
|
||||
Write(W, CHR(x DIV 10 + 30H)); Write(W, CHR(x MOD 10 + 30H))
|
||||
END WritePair;
|
||||
|
||||
BEGIN
|
||||
WritePair(" ", d MOD 32); WritePair(".", d DIV 32 MOD 16); WritePair(".", d DIV 512 MOD 128);
|
||||
WritePair(" ", t DIV 4096 MOD 32); WritePair(":", t DIV 64 MOD 64); WritePair(":", t MOD 64)
|
||||
END WriteDate;
|
||||
|
||||
|
||||
(** Text Filing **)
|
||||
|
||||
PROCEDURE Load0 (VAR r: Files.Rider; T: Text);
|
||||
VAR u, un: Run; p: Piece; e: Elem;
|
||||
org, pos, hlen, plen: LONGINT; ecnt, fno, fcnt, col, voff: SHORTINT;
|
||||
f: Files.File;
|
||||
msg: FileMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
name: ARRAY 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
|
||||
PROCEDURE LoadElem (VAR r: Files.Rider; pos, span: LONGINT; VAR e: Elem);
|
||||
VAR M: Modules.Module; Cmd: Modules.Command; a: Alien;
|
||||
org, ew, eh: LONGINT; eno: SHORTINT;
|
||||
BEGIN new := NIL;
|
||||
Files.ReadLInt(r, ew); Files.ReadLInt(r, eh); Files.Read(r, eno);
|
||||
IF eno > ecnt THEN ecnt := eno; Files.ReadString(r, mods[eno]); Files.ReadString(r, procs[eno]) END;
|
||||
org := Files.Pos(r); M := Modules.ThisMod(mods[eno]);
|
||||
IF M # NIL THEN Cmd := Modules.ThisCommand(M, procs[eno]);
|
||||
IF Cmd # NIL THEN Cmd END
|
||||
END;
|
||||
e := new;
|
||||
IF e # NIL THEN e.W := ew; e.H := eh; e.base := T;
|
||||
msg.pos := pos; e.handle(e, msg);
|
||||
IF Files.Pos(r) # org + span THEN e := NIL END
|
||||
END;
|
||||
IF e = NIL THEN Files.Set(r, f, org + span);
|
||||
NEW(a); a.W := ew; a.H := eh; a.handle := HandleAlien; a.base := T;
|
||||
a.file := f; a.org := org; a.span := span;
|
||||
COPY(mods[eno], a.mod); COPY(procs[eno], a.proc);
|
||||
e := a
|
||||
END
|
||||
END LoadElem;
|
||||
|
||||
BEGIN pos := Files.Pos(r); f := Files.Base(r);
|
||||
NEW(u); u.len := MAX(LONGINT); (*u.fnt := FontsDefault;*)u.fnt := NIL; u.col := Displaywhite;
|
||||
T.head := u; ecnt := 0; fcnt := 0;
|
||||
msg.id := load; msg.r := r;
|
||||
Files.ReadLInt(msg.r, hlen); (*!!!org := pos + hlen;*) org := pos -2 + hlen; pos := org; Files.Read(msg.r, fno);
|
||||
WHILE fno # 0 DO
|
||||
IF fno > fcnt THEN fcnt := fno; Files.ReadString(msg.r, name); fnts[fno] := FontsThis(name) END;
|
||||
Files.Read(msg.r, col); Files.Read(msg.r, voff); Files.ReadLInt(msg.r, plen);
|
||||
IF plen > 0 THEN NEW(p); p.file := f; p.org := pos; p.ascii := FALSE; un := p; un.len := plen
|
||||
ELSE LoadElem(msg.r, pos - org, -plen, e); un := e; un.len := 1
|
||||
END;
|
||||
un.fnt := fnts[fno]; un.col := col; un.voff := voff;
|
||||
INC(pos, un.len); u.next := un; un.prev := u; u := un; Files.Read(msg.r, fno)
|
||||
END;
|
||||
u.next := T.head; T.head.prev := u; T.cache := T.head; T.corg := 0;
|
||||
Files.ReadLInt(msg.r, T.len); Files.Set(r, f, Files.Pos(msg.r) + T.len)
|
||||
END Load0;
|
||||
|
||||
PROCEDURE Load* (VAR r: Files.Rider; T: Text);
|
||||
CONST oldTag = -4095;
|
||||
VAR tag: INTEGER;
|
||||
BEGIN
|
||||
(* for compatibility inner text tags are checked and skipped; remove this in a later version *)
|
||||
Files.ReadInt(r, tag); IF tag # oldTag THEN Files.Set(r, Files.Base(r), Files.Pos(r)-2) END;
|
||||
Load0(r, T)
|
||||
END Load;
|
||||
|
||||
PROCEDURE Open* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; u: Run; p: Piece; tag, version: CHAR; hlen: LONGINT;
|
||||
BEGIN f := Files.Old(name);
|
||||
IF f = NIL THEN f := Files.New("") END;
|
||||
Files.Set(r, f, 0); Files.Read(r, tag); Files.Read(r, version);
|
||||
IF (tag = textTag) OR (tag = 01X) & (version = textTag) THEN Load0(r, T)
|
||||
ELSE (*ascii*)
|
||||
NEW(u); u.len := MAX(LONGINT); u.fnt := NIL; u.col := Displaywhite;
|
||||
NEW(p);
|
||||
IF (tag = DocBlockId) & (version = 07X) THEN (* extract ascii text from System 3 text document *)
|
||||
Files.Set(r, f, 28); Files.ReadLInt(r, hlen);
|
||||
Files.Set(r, f, 22 + hlen); Files.ReadLInt(r, T.len); p.org := 26 + hlen
|
||||
ELSE
|
||||
T.len := Files.Length(f); p.org := 0
|
||||
END ;
|
||||
IF T.len > 0 THEN p.len := T.len; p.fnt := FontsDefault;
|
||||
p.col := Displaywhite; p.voff := 0; p.file := f; p.ascii := TRUE;
|
||||
u.next := p; u.prev := p; p.next := u; p.prev := u
|
||||
ELSE u.next := u; u.prev := u
|
||||
END;
|
||||
T.head := u; T.cache := T.head; T.corg := 0
|
||||
END
|
||||
END Open;
|
||||
|
||||
PROCEDURE Store* (VAR r: Files.Rider; T: Text);
|
||||
VAR r1: Files.Rider; u, un: Run; e: Elem; org, pos, delta, hlen, rlen: LONGINT; ecnt, fno, fcnt: SHORTINT; ch: CHAR; (* << *)
|
||||
msg: FileMsg; iden: IdentifyMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
block: ARRAY 1024 OF CHAR;
|
||||
|
||||
PROCEDURE StoreElem (VAR r: Files.Rider; pos: LONGINT; e: Elem);
|
||||
VAR r1: Files.Rider; org, span: LONGINT; eno: SHORTINT;
|
||||
BEGIN COPY(iden.mod, mods[ecnt]); COPY(iden.proc, procs[ecnt]); eno := 1;
|
||||
WHILE (mods[eno] # iden.mod) OR (procs[eno] # iden.proc) DO INC(eno) END;
|
||||
Files.Set(r1, Files.Base(r), Files.Pos(r));
|
||||
Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); (*fixup slot*)
|
||||
Files.Write(r, eno);
|
||||
IF eno = ecnt THEN INC(ecnt); Files.WriteString(r, iden.mod); Files.WriteString(r, iden.proc) END;
|
||||
msg.pos := pos; org := Files.Pos(r); e.handle(e, msg); span := Files.Pos(r) - org;
|
||||
Files.WriteLInt(r1, -span); Files.WriteLInt(r1, e.W); Files.WriteLInt(r1, e.H) (*fixup*)
|
||||
END StoreElem;
|
||||
|
||||
BEGIN
|
||||
org := Files.Pos(r); msg.id := store; msg.r := r; Files.WriteLInt(msg.r, 0); (*fixup slot*)
|
||||
u := T.head.next; pos := 0; delta := 0; fcnt := 1; ecnt := 1;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Elem THEN iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden) ELSE iden.mod[0] := 1X END;
|
||||
IF iden.mod[0] # 0X THEN
|
||||
fnts[fcnt] := u.fnt; fno := 1;
|
||||
WHILE fnts[fno].name # u.fnt.name DO INC(fno) END;
|
||||
Files.Write(msg.r, fno);
|
||||
IF fno = fcnt THEN INC(fcnt); Files.WriteString(msg.r, u.fnt.name) END;
|
||||
Files.Write(msg.r, u.col); Files.Write(msg.r, u.voff)
|
||||
END;
|
||||
IF u IS Piece THEN rlen := u.len; un := u.next;
|
||||
WHILE (un IS Piece) & (un.fnt = u.fnt) & (un.col = u.col) & (un.voff = u.voff) DO
|
||||
INC(rlen, un.len); un := un.next
|
||||
END;
|
||||
Files.WriteLInt(msg.r, rlen); INC(pos, rlen); u := un
|
||||
ELSIF iden.mod[0] # 0X THEN StoreElem(msg.r, pos, u(Elem)); INC(pos); u := u.next
|
||||
ELSE INC(delta); u := u.next
|
||||
END
|
||||
END;
|
||||
Files.Write(msg.r, 0); Files.WriteLInt(msg.r, T.len - delta);
|
||||
(*!!!hlen := Files.Pos(msg.r) - org;*) hlen := Files.Pos(msg.r) - org + 2;
|
||||
Files.Set(r1, Files.Base(msg.r), org); Files.WriteLInt(r1, hlen); (*fixup*)
|
||||
u := T.head.next;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO
|
||||
IF u.ascii THEN Files.Set(r1, u.file, u.org); delta := u.len; (* << LF to CR *)
|
||||
WHILE delta > 0 DO Files.Read(r1, ch); DEC(delta);
|
||||
IF ch = 0AX THEN Files.Write(msg.r, CR) ELSE Files.Write(msg.r, ch) END
|
||||
END
|
||||
ELSE Files.Set(r1, u.file, u.org); delta := u.len;
|
||||
WHILE delta > LEN(block) DO Files.ReadBytes(r1, block, LEN(block));
|
||||
Files.WriteBytes(msg.r, block, LEN(block)); DEC(delta, LEN(block))
|
||||
END;
|
||||
Files.ReadBytes(r1, block, delta); Files.WriteBytes(msg.r, block, delta)
|
||||
END
|
||||
END
|
||||
ELSE iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden);
|
||||
IF iden.mod[0] # 0X THEN Files.Write(msg.r, ElemChar) END
|
||||
END;
|
||||
u := u.next
|
||||
END;
|
||||
r := msg.r;
|
||||
END Store;
|
||||
|
||||
PROCEDURE Close* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; i, res: INTEGER; bak: ARRAY 64 OF CHAR;
|
||||
BEGIN
|
||||
f := Files.New(name); Files.Set(r, f, 0); Files.Write(r, textTag); Files.Write(r, version); Store(r, T);
|
||||
i := 0; WHILE name[i] # 0X DO INC(i) END;
|
||||
COPY(name, bak); bak[i] := "."; bak[i+1] := "B"; bak[i+2] := "a"; bak[i+3] := "k"; bak[i+4] := 0X;
|
||||
Files.Rename(name, bak, res); Files.Register(f)
|
||||
END Close;
|
||||
|
||||
BEGIN del := NIL; NEW(FontsDefault); FontsDefault.name := "Syntax10.Scn.Fnt"
|
||||
END Texts.
|
||||
859
src/lib/system/linux/gnuc/Texts0.Mod
Normal file
859
src/lib/system/linux/gnuc/Texts0.Mod
Normal file
|
|
@ -0,0 +1,859 @@
|
|||
MODULE Texts0; (** CAS/HM 23.9.93 -- interface based on Texts by JG/NW 6.12.91**) (* << RC, MB, JT *)
|
||||
IMPORT
|
||||
Files := Files0, Modules, Reals;
|
||||
|
||||
(*--- insert field e: Elem into Texts.Scanner and change Texts.Scan to set it in case of class=6 *)
|
||||
(* this module is for bootstrapping voc, use Texts instead *)
|
||||
|
||||
CONST
|
||||
Displaywhite = 15;
|
||||
ElemChar* = 1CX;
|
||||
TAB = 9X; CR = 0DX; maxD = 9;
|
||||
(**FileMsg.id**)
|
||||
load* = 0; store* = 1;
|
||||
(**Notifier op**)
|
||||
replace* = 0; insert* = 1; delete* = 2;
|
||||
(**Scanner.class**)
|
||||
Inval* = 0; Name* = 1; String* = 2; Int* = 3; Real* = 4; LongReal* = 5; Char* = 6;
|
||||
|
||||
textTag = 0F0X; DocBlockId = 0F7X; version = 01X;
|
||||
|
||||
TYPE
|
||||
FontsFont = POINTER TO FontDesc;
|
||||
FontDesc = RECORD
|
||||
name: ARRAY 32 OF CHAR;
|
||||
END ;
|
||||
|
||||
Run = POINTER TO RunDesc;
|
||||
RunDesc = RECORD
|
||||
prev, next: Run;
|
||||
len: LONGINT;
|
||||
fnt: FontsFont;
|
||||
col, voff: SHORTINT;
|
||||
ascii: BOOLEAN (* << *)
|
||||
END;
|
||||
|
||||
Piece = POINTER TO PieceDesc;
|
||||
PieceDesc = RECORD (RunDesc)
|
||||
file: Files.File;
|
||||
org: LONGINT
|
||||
END;
|
||||
|
||||
Elem* = POINTER TO ElemDesc;
|
||||
Buffer* = POINTER TO BufDesc;
|
||||
Text* = POINTER TO TextDesc;
|
||||
|
||||
ElemMsg* = RECORD END;
|
||||
Handler* = PROCEDURE (e: Elem; VAR msg: ElemMsg);
|
||||
|
||||
ElemDesc* = RECORD (RunDesc)
|
||||
W*, H*: LONGINT;
|
||||
handle*: Handler;
|
||||
base: Text
|
||||
END;
|
||||
|
||||
FileMsg* = RECORD (ElemMsg)
|
||||
id*: INTEGER;
|
||||
pos*: LONGINT;
|
||||
r*: Files.Rider
|
||||
END;
|
||||
|
||||
CopyMsg* = RECORD (ElemMsg)
|
||||
e*: Elem
|
||||
END;
|
||||
|
||||
IdentifyMsg* = RECORD (ElemMsg)
|
||||
mod*, proc*: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
|
||||
BufDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head: Run
|
||||
END;
|
||||
|
||||
TextDesc* = RECORD
|
||||
len*: LONGINT;
|
||||
head, cache: Run;
|
||||
corg: LONGINT
|
||||
END;
|
||||
|
||||
Reader* = RECORD
|
||||
eot*: BOOLEAN;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
elem*: Elem;
|
||||
rider: Files.Rider;
|
||||
run: Run;
|
||||
org, off: LONGINT
|
||||
END;
|
||||
|
||||
Scanner* = RECORD (Reader)
|
||||
nextCh*: CHAR;
|
||||
line*, class*: INTEGER;
|
||||
i*: LONGINT;
|
||||
x*: REAL;
|
||||
y*: LONGREAL;
|
||||
c*: CHAR;
|
||||
len*: SHORTINT;
|
||||
s*: ARRAY 64 OF CHAR (* << *)
|
||||
END;
|
||||
|
||||
Writer* = RECORD
|
||||
buf*: Buffer;
|
||||
fnt*: FontsFont;
|
||||
col*, voff*: SHORTINT;
|
||||
rider: Files.Rider;
|
||||
file: Files.File
|
||||
END;
|
||||
|
||||
Alien = POINTER TO RECORD (ElemDesc)
|
||||
file: Files.File;
|
||||
org, span: LONGINT;
|
||||
mod, proc: ARRAY 32 OF CHAR
|
||||
END;
|
||||
|
||||
VAR
|
||||
new*: Elem;
|
||||
del: Buffer;
|
||||
FontsDefault: FontsFont;
|
||||
|
||||
|
||||
PROCEDURE FontsThis(VAR name: ARRAY OF CHAR): FontsFont;
|
||||
VAR F: FontsFont;
|
||||
BEGIN
|
||||
NEW(F); COPY(name, F.name); RETURN F
|
||||
END FontsThis;
|
||||
|
||||
(* run primitives *)
|
||||
|
||||
PROCEDURE Find (T: Text; VAR pos: LONGINT; VAR u: Run; VAR org, off: LONGINT);
|
||||
VAR v: Run; m: LONGINT;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len; u := T.head; org := T.len; off := 0; T.cache := T.head; T.corg := 0
|
||||
ELSE v := T.cache.next; m := pos - T.corg;
|
||||
IF pos >= T.corg THEN
|
||||
WHILE m >= v.len DO DEC(m, v.len); v := v.next END
|
||||
ELSE
|
||||
WHILE m < 0 DO v := v.prev; INC(m, v.len) END;
|
||||
END;
|
||||
u := v; org := pos - m; off := m; T.cache := v.prev; T.corg := org
|
||||
END
|
||||
END Find;
|
||||
|
||||
PROCEDURE Split (off: LONGINT; VAR u, un: Run);
|
||||
VAR p, U: Piece;
|
||||
BEGIN
|
||||
IF off = 0 THEN un := u; u := un.prev
|
||||
ELSIF off >= u.len THEN un := u.next
|
||||
ELSE NEW(p); un := p; U := u(Piece);
|
||||
p^ := U^; INC(p.org, off); DEC(p.len, off); DEC(U.len, p.len);
|
||||
p.ascii := u.ascii; p.prev := U; p.next := U.next; p.next.prev := p; U.next := p (* << *)
|
||||
END
|
||||
END Split;
|
||||
|
||||
PROCEDURE Merge (T: Text; u: Run; VAR v: Run);
|
||||
VAR p, q: Piece;
|
||||
BEGIN
|
||||
IF (u IS Piece) & (v IS Piece) & (u.fnt.name = v.fnt.name) & (u.col = v.col) & (u.voff = v.voff)
|
||||
& (u(Piece).ascii = v(Piece).ascii) THEN (* << *)
|
||||
p := u(Piece); q := v(Piece);
|
||||
IF (p.file = q.file) & (p.org + p.len = q.org) THEN
|
||||
IF T.cache = u THEN INC(T.corg, q.len)
|
||||
ELSIF T.cache = v THEN T.cache := T.head; T.corg := 0
|
||||
END;
|
||||
INC(p.len, q.len); v := v.next
|
||||
END
|
||||
END
|
||||
END Merge;
|
||||
|
||||
PROCEDURE Splice (un, v, w: Run; base: Text); (* (u, un) -> (u, v, w, un) *)
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF v # w.next THEN u := un.prev;
|
||||
u.next := v; v.prev := u; un.prev := w; w.next := un;
|
||||
REPEAT
|
||||
IF v IS Elem THEN v(Elem).base := base END;
|
||||
v := v.next
|
||||
UNTIL v = un
|
||||
END
|
||||
END Splice;
|
||||
|
||||
PROCEDURE ClonePiece (p: Piece): Piece;
|
||||
VAR q: Piece;
|
||||
BEGIN NEW(q); q^ := p^; RETURN q
|
||||
END ClonePiece;
|
||||
|
||||
PROCEDURE CloneElem (e: Elem): Elem;
|
||||
VAR msg: CopyMsg;
|
||||
BEGIN msg.e := NIL; e.handle(e, msg); RETURN msg.e
|
||||
END CloneElem;
|
||||
|
||||
|
||||
(** Elements **)
|
||||
|
||||
PROCEDURE CopyElem* (SE, DE: Elem);
|
||||
BEGIN DE.len := SE.len; DE.fnt := SE.fnt; DE.col := SE.col; DE.voff := SE.voff;
|
||||
DE.W := SE.W; DE.H := SE.H; DE.handle := SE.handle
|
||||
END CopyElem;
|
||||
|
||||
PROCEDURE ElemBase* (E: Elem): Text;
|
||||
BEGIN RETURN E.base
|
||||
END ElemBase;
|
||||
|
||||
PROCEDURE ElemPos* (E: Elem): LONGINT;
|
||||
VAR u: Run; pos: LONGINT;
|
||||
BEGIN u := E.base.head.next; pos := 0;
|
||||
WHILE u # E DO pos := pos + u.len; u := u.next END;
|
||||
RETURN pos
|
||||
END ElemPos;
|
||||
|
||||
|
||||
PROCEDURE HandleAlien (E: Elem; VAR msg: ElemMsg);
|
||||
VAR e: Alien; r: Files.Rider; i: LONGINT; ch: CHAR;
|
||||
BEGIN
|
||||
WITH E: Alien DO
|
||||
IF msg IS CopyMsg THEN
|
||||
WITH msg: CopyMsg DO NEW(e); CopyElem(E, e);
|
||||
e.file := E.file; e.org := E.org; e.span := E.span; e.mod := E.mod; e.proc := E.proc;
|
||||
msg.e := e
|
||||
END
|
||||
ELSIF msg IS IdentifyMsg THEN
|
||||
WITH msg: IdentifyMsg DO
|
||||
COPY(E.mod, msg.mod); COPY(E.proc, msg.proc); msg.mod[31] := 1X (*alien*)
|
||||
END
|
||||
ELSIF msg IS FileMsg THEN
|
||||
WITH msg: FileMsg DO
|
||||
IF msg.id = store THEN Files.Set(r, E.file, E.org); i := E.span;
|
||||
WHILE i > 0 DO Files.Read(r, ch); Files.Write(msg.r, ch); DEC(i) END
|
||||
END
|
||||
END
|
||||
END
|
||||
END
|
||||
END HandleAlien;
|
||||
|
||||
|
||||
(** Buffers **)
|
||||
|
||||
PROCEDURE OpenBuf* (B: Buffer);
|
||||
VAR u: Run;
|
||||
BEGIN NEW(u); u.next := u; u.prev := u; B.head := u; B.len := 0
|
||||
END OpenBuf;
|
||||
|
||||
PROCEDURE Copy* (SB, DB: Buffer);
|
||||
VAR u, v, vn: Run;
|
||||
BEGIN u := SB.head.next; v := DB.head.prev;
|
||||
WHILE u # SB.head DO
|
||||
IF u IS Piece THEN vn := ClonePiece(u(Piece)) ELSE vn := CloneElem(u(Elem)) END;
|
||||
v.next := vn; vn.prev := v; v := vn; u := u.next
|
||||
END;
|
||||
v.next := DB.head; DB.head.prev := v;
|
||||
INC(DB.len, SB.len)
|
||||
END Copy;
|
||||
|
||||
PROCEDURE Recall* (VAR B: Buffer);
|
||||
BEGIN B := del; del := NIL
|
||||
END Recall;
|
||||
|
||||
|
||||
(** Texts **)
|
||||
|
||||
PROCEDURE Save* (T: Text; beg, end: LONGINT; B: Buffer);
|
||||
VAR u, v, w, wn: Run; uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Find(T, end, v, vo, vd);
|
||||
w := B.head.prev;
|
||||
WHILE u # v DO
|
||||
IF u IS Piece THEN wn := ClonePiece(u(Piece)); DEC(wn.len, ud); INC(wn(Piece).org, ud)
|
||||
ELSE wn := CloneElem(u(Elem))
|
||||
END;
|
||||
w.next := wn; wn.prev := w; w := wn; u := u.next; ud := 0
|
||||
END;
|
||||
IF vd > 0 THEN (*v IS Piece*) wn := ClonePiece(v(Piece)); wn.len := vd - ud; INC(wn(Piece).org, ud);
|
||||
w.next := wn; wn.prev := w; w := wn
|
||||
END;
|
||||
w.next := B.head; B.head.prev := w;
|
||||
INC(B.len, end - beg)
|
||||
END Save;
|
||||
|
||||
PROCEDURE Insert* (T: Text; pos: LONGINT; B: Buffer);
|
||||
VAR u, un, v: Run; p, q: Piece; uo, ud, len: LONGINT;
|
||||
BEGIN Find(T, pos, u, uo, ud); Split(ud, u, un);
|
||||
len := B.len; v := B.head.next;
|
||||
Merge(T, u, v); Splice(un, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Insert;
|
||||
|
||||
PROCEDURE Append* (T: Text; B: Buffer);
|
||||
VAR v: Run; pos, len: LONGINT;
|
||||
BEGIN pos := T.len; len := B.len; v := B.head.next;
|
||||
Merge(T, T.head.prev, v); Splice(T.head, v, B.head.prev, T);
|
||||
INC(T.len, len); B.head.next := B.head; B.head.prev := B.head; B.len := 0;
|
||||
END Append;
|
||||
|
||||
PROCEDURE Delete* (T: Text; beg, end: LONGINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN
|
||||
Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
NEW(del); OpenBuf(del); del.len := end - beg;
|
||||
Splice(del.head, un, v, NIL);
|
||||
Merge(T, u, vn); u.next := vn; vn.prev := u;
|
||||
DEC(T.len, end - beg);
|
||||
END Delete;
|
||||
|
||||
PROCEDURE ChangeLooks* (T: Text; beg, end: LONGINT; sel: SET; fnt: FontsFont; col, voff: SHORTINT);
|
||||
VAR c, u, un, v, vn: Run; co, uo, ud, vo, vd: LONGINT;
|
||||
BEGIN Find(T, beg, u, uo, ud); Split(ud, u, un); c := T.cache; co := T.corg;
|
||||
Find(T, end, v, vo, vd); Split(vd, v, vn); T.cache := c; T.corg := co;
|
||||
WHILE un # vn DO
|
||||
IF (0 IN sel) & (fnt # NIL) THEN un.fnt := fnt END;
|
||||
IF 1 IN sel THEN un.col := col END;
|
||||
IF 2 IN sel THEN un.voff := voff END;
|
||||
Merge(T, u, un);
|
||||
IF u.next = un THEN u := un; un := un.next ELSE u.next := un; un.prev := u END
|
||||
END;
|
||||
Merge(T, u, un); u.next := un; un.prev := u;
|
||||
END ChangeLooks;
|
||||
|
||||
|
||||
(** Readers **)
|
||||
|
||||
PROCEDURE OpenReader* (VAR R: Reader; T: Text; pos: LONGINT);
|
||||
VAR u: Run;
|
||||
BEGIN
|
||||
IF pos >= T.len THEN pos := T.len END;
|
||||
Find(T, pos, u, R.org, R.off); R.run := u; R.eot := FALSE;
|
||||
IF u IS Piece THEN
|
||||
Files.Set(R.rider, u(Piece).file, u(Piece).org + R.off)
|
||||
END
|
||||
END OpenReader;
|
||||
|
||||
PROCEDURE Read* (VAR R: Reader; VAR ch: CHAR);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run; R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; INC(R.off);
|
||||
IF u IS Piece THEN Files.Read(R.rider, ch); R.elem := NIL;
|
||||
IF (ch = 0AX) & u(Piece).ascii THEN ch := CR END (* << LF to CR *)
|
||||
ELSIF u IS Elem THEN ch := ElemChar; R.elem := u(Elem)
|
||||
ELSE ch := 0X; R.elem := NIL; R.eot := TRUE
|
||||
END;
|
||||
IF R.off = u.len THEN INC(R.org, u.len); u := u.next;
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO Files.Set(R.rider, u.file, u.org) END
|
||||
END;
|
||||
R.run := u; R.off := 0
|
||||
END
|
||||
END Read;
|
||||
|
||||
PROCEDURE ReadElem* (VAR R: Reader);
|
||||
VAR u, un: Run;
|
||||
BEGIN u := R.run;
|
||||
WHILE u IS Piece DO INC(R.org, u.len); u := u.next END;
|
||||
IF u IS Elem THEN un := u.next; R.run := un; INC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem);
|
||||
IF un IS Piece THEN
|
||||
WITH un: Piece DO Files.Set(R.rider, un.file, un.org) END
|
||||
END
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadElem;
|
||||
|
||||
PROCEDURE ReadPrevElem* (VAR R: Reader);
|
||||
VAR u: Run;
|
||||
BEGIN u := R.run.prev;
|
||||
WHILE u IS Piece DO DEC(R.org, u.len); u := u.prev END;
|
||||
IF u IS Elem THEN R.run := u; DEC(R.org); R.off := 0;
|
||||
R.fnt := u.fnt; R.col := u.col; R.voff := u.voff; R.elem := u(Elem)
|
||||
ELSE R.eot := TRUE; R.elem := NIL
|
||||
END
|
||||
END ReadPrevElem;
|
||||
|
||||
PROCEDURE Pos* (VAR R: Reader): LONGINT;
|
||||
BEGIN RETURN R.org + R.off
|
||||
END Pos;
|
||||
|
||||
|
||||
(** Scanners --------------- NW --------------- **)
|
||||
|
||||
PROCEDURE OpenScanner* (VAR S: Scanner; T: Text; pos: LONGINT);
|
||||
BEGIN OpenReader(S, T, pos); S.line := 0; S.nextCh := " "
|
||||
END OpenScanner;
|
||||
|
||||
(*IEEE floating point formats:
|
||||
x = 2^(e-127) * 1.m bit 0: sign, bits 1- 8: e, bits 9-31: m
|
||||
x = 2^(e-1023) * 1.m bit 0: sign, bits 1-11: e, bits 12-63: m *)
|
||||
|
||||
PROCEDURE Scan* (VAR S: Scanner);
|
||||
CONST maxD = 32;
|
||||
VAR ch, term: CHAR;
|
||||
neg, negE, hex: BOOLEAN;
|
||||
i, j, h: SHORTINT;
|
||||
e: INTEGER; k: LONGINT;
|
||||
x, f: REAL; y, g: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE ReadScaleFactor;
|
||||
BEGIN Read(S, ch);
|
||||
IF ch = "-" THEN negE := TRUE; Read(S, ch)
|
||||
ELSE negE := FALSE;
|
||||
IF ch = "+" THEN Read(S, ch) END
|
||||
END;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO
|
||||
e := e*10 + ORD(ch) - 30H; Read(S, ch)
|
||||
END
|
||||
END ReadScaleFactor;
|
||||
|
||||
BEGIN ch := S.nextCh; i := 0;
|
||||
LOOP
|
||||
IF ch = CR THEN INC(S.line)
|
||||
ELSIF (ch # " ") & (ch # TAB) THEN EXIT
|
||||
END ;
|
||||
Read(S, ch)
|
||||
END;
|
||||
IF ("A" <= CAP(ch)) & (CAP(ch) <= "Z") OR (ch = "/") OR (ch = ".") THEN (*name*) (* << *)
|
||||
REPEAT S.s[i] := ch; INC(i); Read(S, ch)
|
||||
UNTIL (CAP(ch) > "Z") & (ch # "_") (* << *)
|
||||
OR ("A" > CAP(ch)) & (ch > "9")
|
||||
OR ("0" > ch) & (ch # ".") & (ch # "/") (* << *)
|
||||
OR (i = 63); (* << *)
|
||||
S.s[i] := 0X; S.len := i; S.class := 1
|
||||
ELSIF ch = 22X THEN (*literal string*)
|
||||
Read(S, ch);
|
||||
WHILE (ch # 22X) & (ch >= " ") & (i # 63) DO (* << *)
|
||||
S.s[i] := ch; INC(i); Read(S, ch)
|
||||
END;
|
||||
S.s[i] := 0X; S.len := i+1; Read(S, ch); S.class := 2
|
||||
ELSE
|
||||
IF ch = "-" THEN neg := TRUE; Read(S, ch) ELSE neg := FALSE END ;
|
||||
IF ("0" <= ch) & (ch <= "9") THEN (*number*)
|
||||
hex := FALSE; j := 0;
|
||||
LOOP d[i] := ch; INC(i); Read(S, ch);
|
||||
IF ch < "0" THEN EXIT END;
|
||||
IF "9" < ch THEN
|
||||
IF ("A" <= ch) & (ch <= "F") THEN hex := TRUE; ch := CHR(ORD(ch)-7)
|
||||
ELSIF ("a" <= ch) & (ch <= "f") THEN hex := TRUE; ch := CHR(ORD(ch)-27H)
|
||||
ELSE EXIT
|
||||
END
|
||||
END
|
||||
END;
|
||||
IF ch = "H" THEN (*hex number*)
|
||||
Read(S, ch); S.class := 3;
|
||||
IF i-j > 8 THEN j := i-8 END ;
|
||||
k := ORD(d[j]) - 30H; INC(j);
|
||||
IF (i-j = 7) & (k >= 8) THEN DEC(k, 16) END ;
|
||||
WHILE j < i DO k := k*10H + (ORD(d[j]) - 30H); INC(j) END ;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END
|
||||
ELSIF ch = "." THEN (*read real*)
|
||||
Read(S, ch); h := i;
|
||||
WHILE ("0" <= ch) & (ch <= "9") DO d[i] := ch; INC(i); Read(S, ch) END ;
|
||||
IF ch = "D" THEN
|
||||
e := 0; y := 0; g := 1;
|
||||
REPEAT y := y*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO g := g/10; y := (ORD(d[j]) - 30H)*g + y; INC(j) END ;
|
||||
ReadScaleFactor;
|
||||
IF negE THEN
|
||||
IF e <= 308 THEN y := y / Reals.TenL(e) ELSE y := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 308 THEN y := Reals.TenL(e) * y ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN y := -y END ;
|
||||
S.class := 5; S.y := y
|
||||
ELSE e := 0; x := 0; f := 1;
|
||||
REPEAT x := x*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = h;
|
||||
WHILE j < i DO f := f/10; x := (ORD(d[j])-30H)*f + x; INC(j) END;
|
||||
IF ch = "E" THEN ReadScaleFactor END ;
|
||||
IF negE THEN
|
||||
IF e <= 38 THEN x := x / Reals.Ten(e) ELSE x := 0 END
|
||||
ELSIF e > 0 THEN
|
||||
IF e <= 38 THEN x := Reals.Ten(e) * x ELSE HALT(40) END
|
||||
END ;
|
||||
IF neg THEN x := -x END ;
|
||||
S.class := 4; S.x := x
|
||||
END ;
|
||||
IF hex THEN S.class := 0 END
|
||||
ELSE (*decimal integer*)
|
||||
S.class := 3; k := 0;
|
||||
REPEAT k := k*10 + (ORD(d[j]) - 30H); INC(j) UNTIL j = i;
|
||||
IF neg THEN S.i := -k ELSE S.i := k END;
|
||||
IF hex THEN S.class := 0 ELSE S.class := 3 END
|
||||
END
|
||||
ELSE S.class := 6;
|
||||
IF neg THEN S.c := "-" ELSE S.c := ch; Read(S, ch) END
|
||||
END
|
||||
END;
|
||||
S.nextCh := ch
|
||||
END Scan;
|
||||
|
||||
|
||||
(** Writers **)
|
||||
|
||||
PROCEDURE OpenWriter* (VAR W: Writer);
|
||||
BEGIN NEW(W.buf); OpenBuf(W.buf);
|
||||
W.fnt := FontsDefault; W.col := Displaywhite; W.voff := 0;
|
||||
W.file := Files.New(""); Files.Set(W.rider, W.file, 0)
|
||||
END OpenWriter;
|
||||
|
||||
PROCEDURE SetFont* (VAR W: Writer; fnt: FontsFont);
|
||||
BEGIN W.fnt := fnt
|
||||
END SetFont;
|
||||
|
||||
PROCEDURE SetColor* (VAR W: Writer; col: SHORTINT);
|
||||
BEGIN W.col := col
|
||||
END SetColor;
|
||||
|
||||
PROCEDURE SetOffset* (VAR W: Writer; voff: SHORTINT);
|
||||
BEGIN W.voff := voff
|
||||
END SetOffset;
|
||||
|
||||
|
||||
PROCEDURE Write* (VAR W: Writer; ch: CHAR);
|
||||
VAR u, un: Run; p: Piece;
|
||||
BEGIN Files.Write(W.rider, ch); INC(W.buf.len); un := W.buf.head; u := un.prev;
|
||||
IF (u IS Piece) & (u(Piece).file = W.file) & (u.fnt.name = W.fnt.name) & (u.col = W.col) & (u.voff = W.voff)
|
||||
& ~u(Piece).ascii THEN (* << *)
|
||||
INC(u.len)
|
||||
ELSE NEW(p); u.next := p; p.prev := u; p.next := un; un.prev := p;
|
||||
p.len := 1; p.fnt := W.fnt; p.col := W.col; p.voff := W.voff;
|
||||
p.file := W.file; p.org := Files.Length(W.file) - 1; p.ascii := FALSE (* << *)
|
||||
END
|
||||
END Write;
|
||||
|
||||
PROCEDURE WriteElem* (VAR W: Writer; e: Elem);
|
||||
VAR u, un: Run;
|
||||
BEGIN
|
||||
IF e.base # NIL THEN HALT(99) END;
|
||||
INC(W.buf.len); e.len := 1; e.fnt := W.fnt; e.col := W.col; e.voff := W.voff;
|
||||
un := W.buf.head; u := un.prev; u.next := e; e.prev := u; e.next := un; un.prev := e
|
||||
END WriteElem;
|
||||
|
||||
PROCEDURE WriteLn* (VAR W: Writer);
|
||||
BEGIN Write(W, CR)
|
||||
END WriteLn;
|
||||
|
||||
PROCEDURE WriteString* (VAR W: Writer; s: ARRAY OF CHAR);
|
||||
VAR i: INTEGER;
|
||||
BEGIN i := 0;
|
||||
WHILE s[i] >= " " DO Write(W, s[i]); INC(i) END
|
||||
END WriteString;
|
||||
|
||||
PROCEDURE WriteInt* (VAR W: Writer; x, n: LONGINT);
|
||||
VAR i: INTEGER; x0: LONGINT;
|
||||
a: ARRAY 11 OF CHAR;
|
||||
BEGIN i := 0;
|
||||
IF x < 0 THEN
|
||||
IF x = MIN(LONGINT) THEN WriteString(W, " -2147483648"); RETURN
|
||||
ELSE DEC(n); x0 := -x
|
||||
END
|
||||
ELSE x0 := x
|
||||
END;
|
||||
REPEAT
|
||||
a[i] := CHR(x0 MOD 10 + 30H); x0 := x0 DIV 10; INC(i)
|
||||
UNTIL x0 = 0;
|
||||
WHILE n > i DO Write(W, " "); DEC(n) END;
|
||||
IF x < 0 THEN Write(W, "-") END;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteInt;
|
||||
|
||||
PROCEDURE WriteHex* (VAR W: Writer; x: LONGINT);
|
||||
VAR i: INTEGER; y: LONGINT;
|
||||
a: ARRAY 10 OF CHAR;
|
||||
BEGIN i := 0; Write(W, " ");
|
||||
REPEAT y := x MOD 10H;
|
||||
IF y < 10 THEN a[i] := CHR(y + 30H) ELSE a[i] := CHR(y + 37H) END;
|
||||
x := x DIV 10H; INC(i)
|
||||
UNTIL i = 8;
|
||||
REPEAT DEC(i); Write(W, a[i]) UNTIL i = 0
|
||||
END WriteHex;
|
||||
|
||||
PROCEDURE WriteReal* (VAR W: Writer; x: REAL; n: INTEGER);
|
||||
VAR e: INTEGER; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 255 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 9 THEN n := 3 ELSE DEC(n, 6) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 8;
|
||||
(*there are 2 < n <= 8 digits to be written*)
|
||||
IF x < 0.0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := (e - 127) * 77 DIV 256;
|
||||
IF e >= 0 THEN x := x / Reals.Ten(e) ELSE x := Reals.Ten(-e) * x END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
x0 := Reals.Ten(n-1); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN x := x*0.1; INC(e) END;
|
||||
Reals.Convert(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "E");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 10 + 30H)); Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteReal;
|
||||
|
||||
PROCEDURE WriteRealFix* (VAR W: Writer; x: REAL; n, k: INTEGER);
|
||||
VAR e, i: INTEGER; sign: CHAR; x0: REAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
|
||||
PROCEDURE seq(ch: CHAR; n: INTEGER);
|
||||
BEGIN WHILE n > 0 DO Write(W, ch); DEC(n) END
|
||||
END seq;
|
||||
|
||||
PROCEDURE dig(n: INTEGER);
|
||||
BEGIN
|
||||
WHILE n > 0 DO
|
||||
DEC(i); Write(W, d[i]); DEC(n)
|
||||
END
|
||||
END dig;
|
||||
|
||||
BEGIN e := Reals.Expo(x);
|
||||
IF k < 0 THEN k := 0 END;
|
||||
IF e = 0 THEN seq(" ", n-k-2); Write(W, "0"); seq(" ", k+1)
|
||||
ELSIF e = 255 THEN WriteString(W, " NaN"); seq(" ", n-4)
|
||||
ELSE e := (e - 127) * 77 DIV 256;
|
||||
IF x < 0 THEN sign := "-"; x := -x ELSE sign := " " END;
|
||||
IF e >= 0 THEN (*x >= 1.0, 77/256 = log 2*) x := x/Reals.Ten(e)
|
||||
ELSE (*x < 1.0*) x := Reals.Ten(-e) * x
|
||||
END;
|
||||
IF x >= 10.0 THEN x := 0.1*x; INC(e) END;
|
||||
(* 1 <= x < 10 *)
|
||||
IF k+e >= maxD-1 THEN k := maxD-1-e
|
||||
ELSIF k+e < 0 THEN k := -e; x := 0.0
|
||||
END;
|
||||
x0 := Reals.Ten(k+e); x := x0*x + 0.5;
|
||||
IF x >= 10.0*x0 THEN INC(e) END;
|
||||
(*e = no. of digits before decimal point*)
|
||||
INC(e); i := k+e; Reals.Convert(x, i, d);
|
||||
IF e > 0 THEN
|
||||
seq(" ", n-e-k-2); Write(W, sign); dig(e);
|
||||
Write(W, "."); dig(k)
|
||||
ELSE seq(" ", n-k-3);
|
||||
Write(W, sign); Write(W, "0"); Write(W, ".");
|
||||
seq("0", -e); dig(k+e)
|
||||
END
|
||||
END
|
||||
END WriteRealFix;
|
||||
|
||||
PROCEDURE WriteRealHex* (VAR W: Writer; x: REAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 8 OF CHAR;
|
||||
BEGIN Reals.ConvertH(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 8
|
||||
END WriteRealHex;
|
||||
|
||||
PROCEDURE WriteLongReal* (VAR W: Writer; x: LONGREAL; n: INTEGER);
|
||||
CONST maxD = 16;
|
||||
VAR e: INTEGER; x0: LONGREAL;
|
||||
d: ARRAY maxD OF CHAR;
|
||||
BEGIN e := Reals.ExpoL(x);
|
||||
IF e = 0 THEN
|
||||
WriteString(W, " 0");
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= 3
|
||||
ELSIF e = 2047 THEN
|
||||
WriteString(W, " NaN");
|
||||
WHILE n > 4 DO Write(W, " "); DEC(n) END
|
||||
ELSE
|
||||
IF n <= 10 THEN n := 3 ELSE DEC(n, 7) END;
|
||||
REPEAT Write(W, " "); DEC(n) UNTIL n <= maxD;
|
||||
(*there are 2 <= n <= maxD digits to be written*)
|
||||
IF x < 0 THEN Write(W, "-"); x := -x ELSE Write(W, " ") END;
|
||||
e := SHORT(LONG(e - 1023) * 77 DIV 256);
|
||||
IF e >= 0 THEN x := x / Reals.TenL(e) ELSE x := Reals.TenL(-e) * x END ;
|
||||
IF x >= 10.0D0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
x0 := Reals.TenL(n-1); x := x0*x + 0.5D0;
|
||||
IF x >= 10.0D0*x0 THEN x := 0.1D0 * x; INC(e) END ;
|
||||
Reals.ConvertL(x, n, d);
|
||||
DEC(n); Write(W, d[n]); Write(W, ".");
|
||||
REPEAT DEC(n); Write(W, d[n]) UNTIL n = 0;
|
||||
Write(W, "D");
|
||||
IF e < 0 THEN Write(W, "-"); e := -e ELSE Write(W, "+") END;
|
||||
Write(W, CHR(e DIV 100 + 30H)); e := e MOD 100;
|
||||
Write(W, CHR(e DIV 10 + 30H));
|
||||
Write(W, CHR(e MOD 10 + 30H))
|
||||
END
|
||||
END WriteLongReal;
|
||||
|
||||
PROCEDURE WriteLongRealHex* (VAR W: Writer; x: LONGREAL);
|
||||
VAR i: INTEGER;
|
||||
d: ARRAY 16 OF CHAR;
|
||||
BEGIN Reals.ConvertHL(x, d); i := 0;
|
||||
REPEAT Write(W, d[i]); INC(i) UNTIL i = 16
|
||||
END WriteLongRealHex;
|
||||
|
||||
PROCEDURE WriteDate* (VAR W: Writer; t, d: LONGINT);
|
||||
|
||||
PROCEDURE WritePair(ch: CHAR; x: LONGINT);
|
||||
BEGIN Write(W, ch);
|
||||
Write(W, CHR(x DIV 10 + 30H)); Write(W, CHR(x MOD 10 + 30H))
|
||||
END WritePair;
|
||||
|
||||
BEGIN
|
||||
WritePair(" ", d MOD 32); WritePair(".", d DIV 32 MOD 16); WritePair(".", d DIV 512 MOD 128);
|
||||
WritePair(" ", t DIV 4096 MOD 32); WritePair(":", t DIV 64 MOD 64); WritePair(":", t MOD 64)
|
||||
END WriteDate;
|
||||
|
||||
|
||||
(** Text Filing **)
|
||||
|
||||
PROCEDURE Load0 (VAR r: Files.Rider; T: Text);
|
||||
VAR u, un: Run; p: Piece; e: Elem;
|
||||
org, pos, hlen, plen: LONGINT; ecnt, fno, fcnt, col, voff: SHORTINT;
|
||||
f: Files.File;
|
||||
msg: FileMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
name: ARRAY 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
|
||||
PROCEDURE LoadElem (VAR r: Files.Rider; pos, span: LONGINT; VAR e: Elem);
|
||||
VAR M: Modules.Module; Cmd: Modules.Command; a: Alien;
|
||||
org, ew, eh: LONGINT; eno: SHORTINT;
|
||||
BEGIN new := NIL;
|
||||
Files.ReadLInt(r, ew); Files.ReadLInt(r, eh); Files.Read(r, eno);
|
||||
IF eno > ecnt THEN ecnt := eno; Files.ReadString(r, mods[eno]); Files.ReadString(r, procs[eno]) END;
|
||||
org := Files.Pos(r); M := Modules.ThisMod(mods[eno]);
|
||||
IF M # NIL THEN Cmd := Modules.ThisCommand(M, procs[eno]);
|
||||
IF Cmd # NIL THEN Cmd END
|
||||
END;
|
||||
e := new;
|
||||
IF e # NIL THEN e.W := ew; e.H := eh; e.base := T;
|
||||
msg.pos := pos; e.handle(e, msg);
|
||||
IF Files.Pos(r) # org + span THEN e := NIL END
|
||||
END;
|
||||
IF e = NIL THEN Files.Set(r, f, org + span);
|
||||
NEW(a); a.W := ew; a.H := eh; a.handle := HandleAlien; a.base := T;
|
||||
a.file := f; a.org := org; a.span := span;
|
||||
COPY(mods[eno], a.mod); COPY(procs[eno], a.proc);
|
||||
e := a
|
||||
END
|
||||
END LoadElem;
|
||||
|
||||
BEGIN pos := Files.Pos(r); f := Files.Base(r);
|
||||
NEW(u); u.len := MAX(LONGINT); (*u.fnt := FontsDefault;*)u.fnt := NIL; u.col := Displaywhite;
|
||||
T.head := u; ecnt := 0; fcnt := 0;
|
||||
msg.id := load; msg.r := r;
|
||||
Files.ReadLInt(msg.r, hlen); (*!!!org := pos + hlen;*) org := pos -2 + hlen; pos := org; Files.Read(msg.r, fno);
|
||||
WHILE fno # 0 DO
|
||||
IF fno > fcnt THEN fcnt := fno; Files.ReadString(msg.r, name); fnts[fno] := FontsThis(name) END;
|
||||
Files.Read(msg.r, col); Files.Read(msg.r, voff); Files.ReadLInt(msg.r, plen);
|
||||
IF plen > 0 THEN NEW(p); p.file := f; p.org := pos; p.ascii := FALSE; un := p; un.len := plen
|
||||
ELSE LoadElem(msg.r, pos - org, -plen, e); un := e; un.len := 1
|
||||
END;
|
||||
un.fnt := fnts[fno]; un.col := col; un.voff := voff;
|
||||
INC(pos, un.len); u.next := un; un.prev := u; u := un; Files.Read(msg.r, fno)
|
||||
END;
|
||||
u.next := T.head; T.head.prev := u; T.cache := T.head; T.corg := 0;
|
||||
Files.ReadLInt(msg.r, T.len); Files.Set(r, f, Files.Pos(msg.r) + T.len)
|
||||
END Load0;
|
||||
|
||||
PROCEDURE Load* (VAR r: Files.Rider; T: Text);
|
||||
CONST oldTag = -4095;
|
||||
VAR tag: INTEGER;
|
||||
BEGIN
|
||||
(* for compatibility inner text tags are checked and skipped; remove this in a later version *)
|
||||
Files.ReadInt(r, tag); IF tag # oldTag THEN Files.Set(r, Files.Base(r), Files.Pos(r)-2) END;
|
||||
Load0(r, T)
|
||||
END Load;
|
||||
|
||||
PROCEDURE Open* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; u: Run; p: Piece; tag, version: CHAR; hlen: LONGINT;
|
||||
BEGIN f := Files.Old(name);
|
||||
IF f = NIL THEN f := Files.New("") END;
|
||||
Files.Set(r, f, 0); Files.Read(r, tag); Files.Read(r, version);
|
||||
IF (tag = textTag) OR (tag = 01X) & (version = textTag) THEN Load0(r, T)
|
||||
ELSE (*ascii*)
|
||||
NEW(u); u.len := MAX(LONGINT); u.fnt := NIL; u.col := Displaywhite;
|
||||
NEW(p);
|
||||
IF (tag = DocBlockId) & (version = 07X) THEN (* extract ascii text from System 3 text document *)
|
||||
Files.Set(r, f, 28); Files.ReadLInt(r, hlen);
|
||||
Files.Set(r, f, 22 + hlen); Files.ReadLInt(r, T.len); p.org := 26 + hlen
|
||||
ELSE
|
||||
T.len := Files.Length(f); p.org := 0
|
||||
END ;
|
||||
IF T.len > 0 THEN p.len := T.len; p.fnt := FontsDefault;
|
||||
p.col := Displaywhite; p.voff := 0; p.file := f; p.ascii := TRUE;
|
||||
u.next := p; u.prev := p; p.next := u; p.prev := u
|
||||
ELSE u.next := u; u.prev := u
|
||||
END;
|
||||
T.head := u; T.cache := T.head; T.corg := 0
|
||||
END
|
||||
END Open;
|
||||
|
||||
PROCEDURE Store* (VAR r: Files.Rider; T: Text);
|
||||
VAR r1: Files.Rider; u, un: Run; e: Elem; org, pos, delta, hlen, rlen: LONGINT; ecnt, fno, fcnt: SHORTINT; ch: CHAR; (* << *)
|
||||
msg: FileMsg; iden: IdentifyMsg;
|
||||
mods, procs: ARRAY 64, 32 OF CHAR;
|
||||
fnts: ARRAY 32 OF FontsFont;
|
||||
block: ARRAY 1024 OF CHAR;
|
||||
|
||||
PROCEDURE StoreElem (VAR r: Files.Rider; pos: LONGINT; e: Elem);
|
||||
VAR r1: Files.Rider; org, span: LONGINT; eno: SHORTINT;
|
||||
BEGIN COPY(iden.mod, mods[ecnt]); COPY(iden.proc, procs[ecnt]); eno := 1;
|
||||
WHILE (mods[eno] # iden.mod) OR (procs[eno] # iden.proc) DO INC(eno) END;
|
||||
Files.Set(r1, Files.Base(r), Files.Pos(r));
|
||||
Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); Files.WriteLInt(r, 0); (*fixup slot*)
|
||||
Files.Write(r, eno);
|
||||
IF eno = ecnt THEN INC(ecnt); Files.WriteString(r, iden.mod); Files.WriteString(r, iden.proc) END;
|
||||
msg.pos := pos; org := Files.Pos(r); e.handle(e, msg); span := Files.Pos(r) - org;
|
||||
Files.WriteLInt(r1, -span); Files.WriteLInt(r1, e.W); Files.WriteLInt(r1, e.H) (*fixup*)
|
||||
END StoreElem;
|
||||
|
||||
BEGIN
|
||||
org := Files.Pos(r); msg.id := store; msg.r := r; Files.WriteLInt(msg.r, 0); (*fixup slot*)
|
||||
u := T.head.next; pos := 0; delta := 0; fcnt := 1; ecnt := 1;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Elem THEN iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden) ELSE iden.mod[0] := 1X END;
|
||||
IF iden.mod[0] # 0X THEN
|
||||
fnts[fcnt] := u.fnt; fno := 1;
|
||||
WHILE fnts[fno].name # u.fnt.name DO INC(fno) END;
|
||||
Files.Write(msg.r, fno);
|
||||
IF fno = fcnt THEN INC(fcnt); Files.WriteString(msg.r, u.fnt.name) END;
|
||||
Files.Write(msg.r, u.col); Files.Write(msg.r, u.voff)
|
||||
END;
|
||||
IF u IS Piece THEN rlen := u.len; un := u.next;
|
||||
WHILE (un IS Piece) & (un.fnt = u.fnt) & (un.col = u.col) & (un.voff = u.voff) DO
|
||||
INC(rlen, un.len); un := un.next
|
||||
END;
|
||||
Files.WriteLInt(msg.r, rlen); INC(pos, rlen); u := un
|
||||
ELSIF iden.mod[0] # 0X THEN StoreElem(msg.r, pos, u(Elem)); INC(pos); u := u.next
|
||||
ELSE INC(delta); u := u.next
|
||||
END
|
||||
END;
|
||||
Files.Write(msg.r, 0); Files.WriteLInt(msg.r, T.len - delta);
|
||||
(*!!!hlen := Files.Pos(msg.r) - org;*) hlen := Files.Pos(msg.r) - org + 2;
|
||||
Files.Set(r1, Files.Base(msg.r), org); Files.WriteLInt(r1, hlen); (*fixup*)
|
||||
u := T.head.next;
|
||||
WHILE u # T.head DO
|
||||
IF u IS Piece THEN
|
||||
WITH u: Piece DO
|
||||
IF u.ascii THEN Files.Set(r1, u.file, u.org); delta := u.len; (* << LF to CR *)
|
||||
WHILE delta > 0 DO Files.Read(r1, ch); DEC(delta);
|
||||
IF ch = 0AX THEN Files.Write(msg.r, CR) ELSE Files.Write(msg.r, ch) END
|
||||
END
|
||||
ELSE Files.Set(r1, u.file, u.org); delta := u.len;
|
||||
WHILE delta > LEN(block) DO Files.ReadBytes(r1, block, LEN(block));
|
||||
Files.WriteBytes(msg.r, block, LEN(block)); DEC(delta, LEN(block))
|
||||
END;
|
||||
Files.ReadBytes(r1, block, delta); Files.WriteBytes(msg.r, block, delta)
|
||||
END
|
||||
END
|
||||
ELSE iden.mod[0] := 0X; u(Elem).handle(u(Elem), iden);
|
||||
IF iden.mod[0] # 0X THEN Files.Write(msg.r, ElemChar) END
|
||||
END;
|
||||
u := u.next
|
||||
END;
|
||||
r := msg.r;
|
||||
END Store;
|
||||
|
||||
PROCEDURE Close* (T: Text; name: ARRAY OF CHAR);
|
||||
VAR f: Files.File; r: Files.Rider; i, res: INTEGER; bak: ARRAY 64 OF CHAR;
|
||||
BEGIN
|
||||
f := Files.New(name); Files.Set(r, f, 0); Files.Write(r, textTag); Files.Write(r, version); Store(r, T);
|
||||
i := 0; WHILE name[i] # 0X DO INC(i) END;
|
||||
COPY(name, bak); bak[i] := "."; bak[i+1] := "B"; bak[i+2] := "a"; bak[i+3] := "k"; bak[i+4] := 0X;
|
||||
Files.Rename(name, bak, res); Files.Register(f)
|
||||
END Close;
|
||||
|
||||
BEGIN del := NIL; NEW(FontsDefault); FontsDefault.name := "Syntax10.Scn.Fnt"
|
||||
END Texts0.
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
MODULE Sets;
|
||||
|
||||
IMPORT Texts := CmdlnTexts;
|
||||
IMPORT Texts;
|
||||
|
||||
CONST (*size* = 32;*)
|
||||
size* = MAX(SET) + 1;
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@ MODULE BrowserCmd; (* RC 29.10.93 *) (* object model 4.12.93, command line ver
|
|||
|
||||
IMPORT
|
||||
OPM, OPS, OPT, OPV,
|
||||
Texts := CmdlnTexts, Console, Args;
|
||||
Texts := Texts0, Console, Args;
|
||||
|
||||
CONST
|
||||
OptionChar = "-";
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@ MODULE OCatCmd; (* J. Templ, 13-Jan-96 *)
|
|||
|
||||
(* looks at the OBERON search path and writes one or more Oberon or ascii texts to standard out *)
|
||||
|
||||
IMPORT Args, Console, Files, Texts := CmdlnTexts;
|
||||
IMPORT Args, Console, Files := Files0, Texts := Texts0;
|
||||
|
||||
PROCEDURE Cat*;
|
||||
VAR path: ARRAY 128 OF CHAR; i: INTEGER; T: Texts.Text; R: Texts.Reader; ch: CHAR; tab: BOOLEAN;
|
||||
|
|
|
|||
|
|
@ -5,7 +5,7 @@ VOC = /opt/voc/bin/voc
|
|||
|
||||
|
||||
all:
|
||||
$(VOC) -M vmake.Mod
|
||||
$(VOC) -s compatIn.Mod vmake.Mod -M
|
||||
|
||||
clean:
|
||||
rm *.o
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@ MODULE OPM; (* RC 6.3.89 / 28.6.89, J.Templ 10.7.89 / 22.7.96 *)
|
|||
31.1.2007 jt synchronized with BlackBox version, in particular PromoteIntConstToLInt added
|
||||
*)
|
||||
|
||||
IMPORT SYSTEM, Texts := CmdlnTexts, Files, Args, Console, errors, version;
|
||||
IMPORT SYSTEM, Texts := Texts0, Files := Files0, Args, Console, errors, version;
|
||||
|
||||
CONST
|
||||
OptionChar* = "-";
|
||||
|
|
|
|||
|
|
@ -20,7 +20,7 @@ Strings.Append(date, versionLong);
|
|||
COPY (prefix0, prefix);
|
||||
Strings.Append ("/voc-", prefix);
|
||||
Strings.Append(version, prefix); (* /opt/voc-1.0 *)
|
||||
(* will be used later in Kernel.Mod to set OBERON default path *)
|
||||
(* will be used later in Kernel0.Mod to set OBERON default path *)
|
||||
|
||||
IF arch = "x86_64" THEN
|
||||
defaultTarget := gnux8664
|
||||
|
|
|
|||
|
|
@ -1,7 +1,7 @@
|
|||
MODULE voc; (* J. Templ 3.2.95 *)
|
||||
|
||||
IMPORT
|
||||
SYSTEM, Unix, Kernel,
|
||||
SYSTEM, Unix, Kernel := Kernel0,
|
||||
OPP, OPB, OPT,
|
||||
OPV, OPC, OPM,
|
||||
extTools, Strings := oocOakStrings;
|
||||
|
|
|
|||
|
|
@ -1 +1 @@
|
|||
7a2e4239363cb69847cb7f5ab6f2cd5ff1f5e1f5
|
||||
333eeef2144c1ef803126d3273b69ca32cfca91d
|
||||
|
|
@ -1 +0,0 @@
|
|||
99591bf85a5b55a73eadb7ede936147844672838
|
||||
|
|
@ -1 +1 @@
|
|||
09acf3b2f6d3f33994333fc479a84f9e07a4620a
|
||||
1ca0276819a9bf5057381a36394ebd436928059a
|
||||
Loading…
Add table
Add a link
Reference in a new issue