StdMap_iso8859_8.txt 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. MODULE EncStdMap_iso8859_8;
  2. (* This file was generated automatically *)
  3. (* Source: http://www.unicode.org/Public/MAPPINGS/ISO8859/8859-8.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,0A2H..0A9H,0ABH..0B9H,0BBH..0BEH: y := 00H + x
  16. | 0F7H: y := 0BAH
  17. | 2017H: y := 0DFH
  18. | 200EH,200FH: y := -1F11H + x
  19. | 05D0H..05EAH: y := -04F0H + x
  20. | 0D7H: y := 0AAH
  21. ELSE
  22. RETURN
  23. END;
  24. t[tW] := SHORT(CHR(y)); INC(tW);
  25. INC(fR); DEC(fLen)
  26. END
  27. END Encode;
  28. PROCEDURE NewEncoder* (): Codecs.Encoder;
  29. VAR e: Encoder;
  30. BEGIN
  31. NEW(e); RETURN e
  32. END NewEncoder;
  33. (* Decoder *)
  34. PROCEDURE (d: Decoder) Decode (IN f: ARRAY OF SHORTCHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF CHAR; VAR tW: INTEGER; OUT state: BOOLEAN);
  35. VAR x, y: INTEGER;
  36. BEGIN
  37. WHILE fLen > 0 DO
  38. x := ORD(f[fR]);
  39. CASE x OF
  40. | 00H..0A0H,0A2H..0A9H,0ABH..0B9H,0BBH..0BEH: y := 00H + x
  41. | 0AAH: y := 0D7H
  42. | 0E0H..0FAH: y := 04F0H + x
  43. | 0FDH,0FEH: y := 1F11H + x
  44. | 0DFH: y := 2017H
  45. | 0BAH: y := 0F7H
  46. ELSE
  47. RETURN
  48. END;
  49. t[tW] := CHR(y); INC(tW);
  50. INC(fR); DEC(fLen)
  51. END;
  52. state := FALSE
  53. END Decode;
  54. PROCEDURE (d: Decoder) Reset, EMPTY;
  55. PROCEDURE NewDecoder* (): Codecs.Decoder;
  56. VAR d: Decoder;
  57. BEGIN
  58. NEW(d); RETURN d
  59. END NewDecoder;
  60. END EncStdMap_iso8859_8.