2020-05-25 20:48:33 +00:00
|
|
|
(*
|
|
|
|
BSD 2-Clause License
|
|
|
|
|
|
|
|
Copyright (c) 2020, Anton Krotov
|
|
|
|
All rights reserved.
|
|
|
|
*)
|
|
|
|
|
|
|
|
MODULE HEX;
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
IMPORT WRITER, CHL := CHUNKLISTS, UTILS;
|
2020-05-25 20:48:33 +00:00
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
VAR
|
2020-05-25 20:48:33 +00:00
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
chksum: INTEGER;
|
2020-05-25 20:48:33 +00:00
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE Byte (byte: BYTE);
|
2020-05-25 20:48:33 +00:00
|
|
|
BEGIN
|
2020-10-13 07:58:51 +00:00
|
|
|
WRITER.WriteByte(UTILS.hexdgt(byte DIV 16));
|
|
|
|
WRITER.WriteByte(UTILS.hexdgt(byte MOD 16));
|
|
|
|
INC(chksum, byte)
|
2020-05-25 20:48:33 +00:00
|
|
|
END Byte;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE Byte4 (a, b, c, d: BYTE);
|
|
|
|
BEGIN
|
|
|
|
Byte(a);
|
|
|
|
Byte(b);
|
|
|
|
Byte(c);
|
|
|
|
Byte(d)
|
|
|
|
END Byte4;
|
|
|
|
|
|
|
|
|
|
|
|
PROCEDURE NewLine;
|
2020-05-25 20:48:33 +00:00
|
|
|
BEGIN
|
2020-10-13 07:58:51 +00:00
|
|
|
Byte((-chksum) MOD 256);
|
|
|
|
chksum := 0;
|
|
|
|
WRITER.WriteByte(0DH);
|
|
|
|
WRITER.WriteByte(0AH)
|
2020-05-25 20:48:33 +00:00
|
|
|
END NewLine;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE StartCode;
|
2020-05-25 20:48:33 +00:00
|
|
|
BEGIN
|
2020-10-13 07:58:51 +00:00
|
|
|
WRITER.WriteByte(ORD(":"));
|
|
|
|
chksum := 0
|
2020-05-25 20:48:33 +00:00
|
|
|
END StartCode;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE Data* (mem: ARRAY OF BYTE; idx, cnt: INTEGER);
|
2020-05-25 20:48:33 +00:00
|
|
|
VAR
|
|
|
|
i, len: INTEGER;
|
|
|
|
|
|
|
|
BEGIN
|
|
|
|
WHILE cnt > 0 DO
|
|
|
|
len := MIN(cnt, 16);
|
2020-10-13 07:58:51 +00:00
|
|
|
StartCode;
|
|
|
|
Byte4(len, idx DIV 256, idx MOD 256, 0);
|
2020-05-25 20:48:33 +00:00
|
|
|
FOR i := 1 TO len DO
|
2020-10-13 07:58:51 +00:00
|
|
|
Byte(mem[idx]);
|
2020-05-25 20:48:33 +00:00
|
|
|
INC(idx)
|
|
|
|
END;
|
|
|
|
DEC(cnt, len);
|
2020-10-13 07:58:51 +00:00
|
|
|
NewLine
|
2020-05-25 20:48:33 +00:00
|
|
|
END
|
|
|
|
END Data;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE ExtLA* (LA: INTEGER);
|
2020-05-25 20:48:33 +00:00
|
|
|
BEGIN
|
|
|
|
ASSERT((0 <= LA) & (LA <= 0FFFFH));
|
2020-10-13 07:58:51 +00:00
|
|
|
StartCode;
|
|
|
|
Byte4(2, 0, 0, 4);
|
|
|
|
Byte(LA DIV 256);
|
|
|
|
Byte(LA MOD 256);
|
|
|
|
NewLine
|
2020-05-25 20:48:33 +00:00
|
|
|
END ExtLA;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE Data2* (mem: CHL.BYTELIST; idx, cnt, LA: INTEGER);
|
2020-05-25 20:48:33 +00:00
|
|
|
VAR
|
|
|
|
i, len, offset: INTEGER;
|
|
|
|
|
|
|
|
BEGIN
|
2020-10-13 07:58:51 +00:00
|
|
|
ExtLA(LA);
|
2020-05-25 20:48:33 +00:00
|
|
|
offset := 0;
|
|
|
|
WHILE cnt > 0 DO
|
|
|
|
ASSERT(offset <= 65536);
|
|
|
|
IF offset = 65536 THEN
|
|
|
|
INC(LA);
|
2020-10-13 07:58:51 +00:00
|
|
|
ExtLA(LA);
|
2020-05-25 20:48:33 +00:00
|
|
|
offset := 0
|
|
|
|
END;
|
|
|
|
len := MIN(cnt, 16);
|
2020-10-13 07:58:51 +00:00
|
|
|
StartCode;
|
|
|
|
Byte4(len, offset DIV 256, offset MOD 256, 0);
|
2020-05-25 20:48:33 +00:00
|
|
|
FOR i := 1 TO len DO
|
2020-10-13 07:58:51 +00:00
|
|
|
Byte(CHL.GetByte(mem, idx));
|
2020-05-25 20:48:33 +00:00
|
|
|
INC(idx);
|
|
|
|
INC(offset)
|
|
|
|
END;
|
|
|
|
DEC(cnt, len);
|
2020-10-13 07:58:51 +00:00
|
|
|
NewLine
|
2020-05-25 20:48:33 +00:00
|
|
|
END
|
|
|
|
END Data2;
|
|
|
|
|
|
|
|
|
2020-10-13 07:58:51 +00:00
|
|
|
PROCEDURE End*;
|
2020-05-25 20:48:33 +00:00
|
|
|
BEGIN
|
2020-10-13 07:58:51 +00:00
|
|
|
StartCode;
|
|
|
|
Byte4(0, 0, 0, 1);
|
|
|
|
NewLine
|
2020-05-25 20:48:33 +00:00
|
|
|
END End;
|
|
|
|
|
|
|
|
|
|
|
|
END HEX.
|