mirror of
https://github.com/vishapoberon/compiler.git
synced 2026-04-06 13:22:26 +00:00
146 lines
5.6 KiB
Modula-2
146 lines
5.6 KiB
Modula-2
MODULE Fonts; (*JG 18.11.90; PDR 8.6.12; NW 25.3.2013*)
|
|
IMPORT SYSTEM, Files := CompatFiles;
|
|
|
|
TYPE INTEGER = LONGINT; (* voc adaptation by noch *)
|
|
BYTE = CHAR;
|
|
|
|
CONST FontFileId = 0DBH;
|
|
|
|
TYPE Font* = POINTER TO FontDesc;
|
|
FontDesc* = RECORD
|
|
name*: ARRAY 32 OF CHAR;
|
|
height*, minX*, maxX*, minY*, maxY*: INTEGER;
|
|
next*: Font;
|
|
T: ARRAY 128 OF INTEGER;
|
|
raster: ARRAY 2360 OF BYTE
|
|
END ;
|
|
|
|
LargeFontDesc = RECORD (FontDesc) ext: ARRAY 2560 OF BYTE END ;
|
|
LargeFont = POINTER TO LargeFontDesc;
|
|
|
|
(* raster sizes: Syntax8 1367, Syntax10 1628, Syntax12 1688, Syntax14 1843, Syntax14b 1983,
|
|
Syntax16 2271, Syntax20 3034, Syntac24 4274, Syntax24b 4302 *)
|
|
|
|
VAR Default*, root*: Font;
|
|
|
|
PROCEDURE GetPat*(fnt: Font; ch: CHAR; VAR dx, x, y, w, h, patadr: INTEGER);
|
|
VAR pa: INTEGER; dxb, xb, yb, wb, hb: BYTE;
|
|
BEGIN pa := fnt.T[ORD(ch) MOD 80H]; patadr := pa;
|
|
SYSTEM.GET(pa-3, dxb); SYSTEM.GET(pa-2, xb); SYSTEM.GET(pa-1, yb); SYSTEM.GET(pa, wb); SYSTEM.GET(pa+1, hb);
|
|
(*dx := dxb;*)
|
|
dx := ORD(dxb); (* voc adaptation by noch *)
|
|
(*x := xb;*)
|
|
x := ORD(xb); (* voc adaptation by noch *)
|
|
(*y := yb;*)
|
|
y := ORD(yb); (* voc adaptation by noch *)
|
|
(*w := wb;*)
|
|
w := ORD(wb); (* voc adaptation by noch *)
|
|
(*h := hb;*)
|
|
h := ORD(hb); (* voc adaptation by noch *)
|
|
(*IF yb < 128 THEN y := yb ELSE y := yb - 256 END*)
|
|
IF ORD(yb) < 128 THEN y := ORD(yb) ELSE y := ORD(yb) - 256 END (* voc adaptation by noch *)
|
|
END GetPat;
|
|
|
|
PROCEDURE This*(name: ARRAY OF CHAR): Font;
|
|
|
|
TYPE RunRec = RECORD beg, end: BYTE END ;
|
|
BoxRec = RECORD dx, x, y, w, h: BYTE END ;
|
|
|
|
VAR F: Font; LF: LargeFont;
|
|
f: Files.File; R: Files.Rider;
|
|
NofRuns, NofBoxes: BYTE;
|
|
NofBytes: INTEGER;
|
|
height, minX, maxX, minY, maxY: BYTE;
|
|
i, j, k, m, n: INTEGER;
|
|
a, a0: INTEGER;
|
|
b, beg, end: BYTE;
|
|
run: ARRAY 16 OF RunRec;
|
|
box: ARRAY 512 OF BoxRec;
|
|
|
|
PROCEDURE RdInt16(VAR R: Files.Rider; VAR b0: BYTE);
|
|
VAR b1: BYTE;
|
|
BEGIN Files.ReadByte(R, b0); Files.ReadByte(R, b1)
|
|
END RdInt16;
|
|
|
|
BEGIN F := root;
|
|
WHILE (F # NIL) & (name # F.name) DO F := F.next END;
|
|
IF F = NIL THEN
|
|
f := Files.Old(name);
|
|
IF f # NIL THEN
|
|
Files.Set(R, f, 0); Files.ReadByte(R, b);
|
|
(*IF b = FontFileId THEN*)
|
|
IF ORD(b) = FontFileId THEN (* voc adaptation by noch *)
|
|
Files.ReadByte(R, b); (*abstraction*)
|
|
Files.ReadByte(R, b); (*family*)
|
|
Files.ReadByte(R, b); (*variant*)
|
|
NEW(F);
|
|
(*F.name := name;*)
|
|
COPY(name, F.name); (* voc adaptation by noch *)
|
|
RdInt16(R, height); RdInt16(R, minX); RdInt16(R, maxX); RdInt16(R, minY); RdInt16(R, maxY); RdInt16(R, NofRuns);
|
|
(*NofBoxes := 0;*) (* voc adaptation by noch *)
|
|
NofBoxes := 0X;
|
|
k := 0;
|
|
(*WHILE k # NofRuns DO*)
|
|
WHILE k # ORD(NofRuns) DO (* voc adaptation by noch *)
|
|
RdInt16(R, beg);
|
|
run[k].beg := beg; RdInt16(R, end);
|
|
run[k].end := end;
|
|
(*NofBoxes := NofBoxes + end - beg;*)
|
|
NofBoxes := CHR(ORD(NofBoxes) + ORD(end) - ORD(beg)); (* voc adaptation by noch *)
|
|
INC(k)
|
|
END;
|
|
NofBytes := 5; j := 0;
|
|
(*WHILE j # NofBoxes DO*)
|
|
WHILE j # ORD(NofBoxes) DO (* voc adaptation by noch *)
|
|
RdInt16(R, box[j].dx); RdInt16(R, box[j].x); RdInt16(R, box[j].y);
|
|
RdInt16(R, box[j].w); RdInt16(R, box[j].h);
|
|
(*NofBytes := NofBytes + 5 + (box[j].w + 7) DIV 8 * box[j].h;*)
|
|
NofBytes := (NofBytes + 5 + (ORD(box[j].w) + 7) DIV 8 * ORD(box[j].h)); (* voc adaptation by noch *)
|
|
INC(j)
|
|
END;
|
|
IF NofBytes < 2300 THEN NEW(F) ELSE NEW(LF); F := LF END ;
|
|
(*F.name := name;*)
|
|
COPY(name, F.name); (* voc adaptation by noch *)
|
|
(*F.height := height; F.minX := minX; F.maxX := maxX; F.maxY := maxY;*)
|
|
F.height := ORD(height); F.minX := ORD(minX); F.maxX := ORD(maxX); F.maxY := ORD(maxY); (* voc adaptation by noch *)
|
|
(*IF minY >= 80H THEN F.minY := minY - 100H ELSE F.minY := minY END ;*)
|
|
IF ORD(minY) >= 80H THEN F.minY := ORD(minY) - 100H ELSE F.minY := ORD(minY) END ; (* voc adaptation by noch *)
|
|
a0 := SYSTEM.ADR(F.raster);
|
|
SYSTEM.PUT(a0, 0X); SYSTEM.PUT(a0+1, 0X); SYSTEM.PUT(a0+2, 0X); SYSTEM.PUT(a0+3, 0X); SYSTEM.PUT(a0+4, 0X);
|
|
(*null pattern for characters not in a run*)
|
|
INC(a0, 2); a := a0+3; j := 0; k := 0; m := 0;
|
|
(*WHILE k < NofRuns DO*)
|
|
WHILE k < ORD(NofRuns) DO
|
|
(*WHILE (m < run[k].beg) & (m < 128) DO F.T[m] := a0; INC(m) END;*)
|
|
WHILE (m < ORD(run[k].beg)) & (m < 128) DO F.T[m] := a0; INC(m) END; (* voc adaptation by noch *)
|
|
(*WHILE (m < run[k].end) & (m < 128) DO*) (* voc adaptation by noch *)
|
|
WHILE (m < ORD(run[k].end)) & (m < 128) DO
|
|
F.T[m] := a+3;
|
|
SYSTEM.PUT(a, box[j].dx); SYSTEM.PUT(a+1, box[j].x); SYSTEM.PUT(a+2, box[j].y);
|
|
SYSTEM.PUT(a+3, box[j].w); SYSTEM.PUT(a+4, box[j].h); INC(a, 5);
|
|
(*n := (box[j].w + 7) DIV 8 * box[j].h;*)
|
|
n := (ORD(box[j].w) + 7) DIV 8 * ORD(box[j].h); (* voc adaptation by noch *)
|
|
WHILE n # 0 DO DEC(n); Files.ReadByte(R, b); SYSTEM.PUT(a, b); INC(a) END ;
|
|
INC(j); INC(m)
|
|
END;
|
|
INC(k)
|
|
END;
|
|
WHILE m < 128 DO F.T[m] := a0; INC(m) END ;
|
|
F.next := root; root := F
|
|
ELSE (*bad file id*) F := Default
|
|
END
|
|
ELSE (*font file not available*) F := Default
|
|
END
|
|
END;
|
|
RETURN F
|
|
END This;
|
|
|
|
PROCEDURE Free*; (*remove all but first two from font list*)
|
|
VAR f: Font;
|
|
BEGIN f := root.next;
|
|
IF f # NIL THEN f := f.next END ;
|
|
f.next := NIL
|
|
END Free;
|
|
|
|
BEGIN root := NIL; Default := This("Oberon10.Scn.Fnt")
|
|
END Fonts.
|