StdMap_iso8859_11.txt 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. MODULE EncStdMap_iso8859_11;
  2. (* This file was generated automatically *)
  3. (* Source: http://www.unicode.org/Public/MAPPINGS/ISO8859/8859-11.TXT *)
  4. IMPORT Codecs := EncCodecs;
  5. TYPE
  6. Encoder = POINTER TO RECORD (Codecs.Encoder) END;
  7. Decoder = POINTER TO RECORD (Codecs.Decoder) END;
  8. (* Encoder *)
  9. PROCEDURE (e: Encoder) Encode (IN f: ARRAY OF CHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF SHORTCHAR; VAR tW: INTEGER);
  10. VAR x, y: INTEGER;
  11. BEGIN
  12. WHILE fLen > 0 DO
  13. x := ORD(f[fR]);
  14. CASE x OF
  15. | 00H..0A0H: y := 00H + x
  16. | 0E01H..0E3AH,0E3FH..0E5BH: y := -0D60H + x
  17. ELSE
  18. RETURN
  19. END;
  20. t[tW] := SHORT(CHR(y)); INC(tW);
  21. INC(fR); DEC(fLen)
  22. END
  23. END Encode;
  24. PROCEDURE NewEncoder* (): Codecs.Encoder;
  25. VAR e: Encoder;
  26. BEGIN
  27. NEW(e); RETURN e
  28. END NewEncoder;
  29. (* Decoder *)
  30. PROCEDURE (d: Decoder) Decode (IN f: ARRAY OF SHORTCHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF CHAR; VAR tW: INTEGER; OUT state: BOOLEAN);
  31. VAR x, y: INTEGER;
  32. BEGIN
  33. WHILE fLen > 0 DO
  34. x := ORD(f[fR]);
  35. CASE x OF
  36. | 00H..0A0H: y := 00H + x
  37. | 0A1H..0DAH,0DFH..0FBH: y := 0D60H + x
  38. ELSE
  39. RETURN
  40. END;
  41. t[tW] := CHR(y); INC(tW);
  42. INC(fR); DEC(fLen)
  43. END;
  44. state := FALSE
  45. END Decode;
  46. PROCEDURE (d: Decoder) Reset, EMPTY;
  47. PROCEDURE NewDecoder* (): Codecs.Decoder;
  48. VAR d: Decoder;
  49. BEGIN
  50. NEW(d); RETURN d
  51. END NewDecoder;
  52. END EncStdMap_iso8859_11.