1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- MODULE EncStdMap_iso8859_15;
- (* This file was generated automatically *)
- (* Source: http://www.unicode.org/Public/MAPPINGS/ISO8859/8859-15.TXT *)
- IMPORT Codecs := EncCodecs;
- TYPE
- Encoder = POINTER TO RECORD (Codecs.Encoder) END;
- Decoder = POINTER TO RECORD (Codecs.Decoder) END;
- (* Encoder *)
- PROCEDURE (e: Encoder) Encode (IN f: ARRAY OF CHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF SHORTCHAR; VAR tW: INTEGER);
- VAR x, y: INTEGER;
- BEGIN
- WHILE fLen > 0 DO
- x := ORD(f[fR]);
- CASE x OF
- | 00H..0A3H,0A5H,0A7H,0A9H..0B3H,0B5H..0B7H,0B9H..0BBH,0BFH..0FFH: y := 00H + x
- | 0160H,0178H: y := -0BAH + x
- | 0161H: y := 0A8H
- | 0152H,0153H: y := -96H + x
- | 017DH: y := 0B4H
- | 20ACH: y := 0A4H
- | 017EH: y := 0B8H
- ELSE
- RETURN
- END;
- t[tW] := SHORT(CHR(y)); INC(tW);
- INC(fR); DEC(fLen)
- END
- END Encode;
- PROCEDURE NewEncoder* (): Codecs.Encoder;
- VAR e: Encoder;
- BEGIN
- NEW(e); RETURN e
- END NewEncoder;
- (* Decoder *)
- PROCEDURE (d: Decoder) Decode (IN f: ARRAY OF SHORTCHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF CHAR; VAR tW: INTEGER; OUT state: BOOLEAN);
- VAR x, y: INTEGER;
- BEGIN
- WHILE fLen > 0 DO
- x := ORD(f[fR]);
- CASE x OF
- | 00H..0A3H,0A5H,0A7H,0A9H..0B3H,0B5H..0B7H,0B9H..0BBH,0BFH..0FFH: y := 00H + x
- | 0B8H: y := 017EH
- | 0A4H: y := 20ACH
- | 0B4H: y := 017DH
- | 0BCH,0BDH: y := 96H + x
- | 0A8H: y := 0161H
- | 0A6H,0BEH: y := 0BAH + x
- ELSE
- RETURN
- END;
- t[tW] := CHR(y); INC(tW);
- INC(fR); DEC(fLen)
- END;
- state := FALSE
- END Decode;
- PROCEDURE (d: Decoder) Reset, EMPTY;
- PROCEDURE NewDecoder* (): Codecs.Decoder;
- VAR d: Decoder;
- BEGIN
- NEW(d); RETURN d
- END NewDecoder;
- END EncStdMap_iso8859_15.
|