StdMap_iso8859_6.txt 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. MODULE EncStdMap_iso8859_6;
  2. (* This file was generated automatically *)
  3. (* Source: http://www.unicode.org/Public/MAPPINGS/ISO8859/8859-6.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 := x
  16. | 0A4H: y := 0A4H
  17. | 0ADH: y := 0ADH
  18. | 060CH: y := 0ACH
  19. | 061BH: y := 0BBH
  20. | 061FH: y := 0BFH
  21. | 0621H..063AH: y := x - 0560H
  22. | 0640H..0652H: y := x - 0560H
  23. ELSE
  24. RETURN
  25. END;
  26. t[tW] := SHORT(CHR(y)); INC(tW);
  27. INC(fR); DEC(fLen)
  28. END
  29. END Encode;
  30. PROCEDURE NewEncoder* (): Codecs.Encoder;
  31. VAR e: Encoder;
  32. BEGIN
  33. NEW(e); RETURN e
  34. END NewEncoder;
  35. (* Decoder *)
  36. PROCEDURE (d: Decoder) Decode (IN f: ARRAY OF SHORTCHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF CHAR; VAR tW: INTEGER; OUT state: BOOLEAN);
  37. VAR x, y: INTEGER;
  38. BEGIN
  39. WHILE fLen > 0 DO
  40. x := ORD(f[fR]);
  41. CASE x OF
  42. | 00H..0A0H: y := x
  43. | 0A4H: y := 0A4H
  44. | 0ACH: y := 060CH
  45. | 0ADH: y := 0ADH
  46. | 0BBH: y := 061BH
  47. | 0BFH: y := 061FH
  48. | 0C1H..0DAH: y := x + 0560H
  49. | 0E0H..0F2H: y := x + 0560H
  50. ELSE
  51. RETURN
  52. END;
  53. t[tW] := CHR(y); INC(tW);
  54. INC(fR); DEC(fLen)
  55. END;
  56. state := FALSE
  57. END Decode;
  58. PROCEDURE (d: Decoder) Reset, EMPTY;
  59. PROCEDURE NewDecoder* (): Codecs.Decoder;
  60. VAR d: Decoder;
  61. BEGIN
  62. NEW(d); RETURN d
  63. END NewDecoder;
  64. END EncStdMap_iso8859_6.