StdMap_iso8859_9.txt 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. MODULE EncStdMap_iso8859_9;
  2. (* This file was generated automatically *)
  3. (* Source: http://www.unicode.org/Public/MAPPINGS/ISO8859/8859-9.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..0CFH,0D1H..0DCH,0DFH..0EFH,0F1H..0FCH,0FFH: y := 00H + x
  16. | 015EH: y := 0DEH
  17. | 0131H: y := 0FDH
  18. | 0130H: y := 0DDH
  19. | 011FH: y := 0F0H
  20. | 011EH: y := 0D0H
  21. | 015FH: y := 0FEH
  22. ELSE
  23. RETURN
  24. END;
  25. t[tW] := SHORT(CHR(y)); INC(tW);
  26. INC(fR); DEC(fLen)
  27. END
  28. END Encode;
  29. PROCEDURE NewEncoder* (): Codecs.Encoder;
  30. VAR e: Encoder;
  31. BEGIN
  32. NEW(e); RETURN e
  33. END NewEncoder;
  34. (* Decoder *)
  35. PROCEDURE (d: Decoder) Decode (IN f: ARRAY OF SHORTCHAR; VAR fR, fLen: INTEGER; VAR t: ARRAY OF CHAR; VAR tW: INTEGER; OUT state: BOOLEAN);
  36. VAR x, y: INTEGER;
  37. BEGIN
  38. WHILE fLen > 0 DO
  39. x := ORD(f[fR]);
  40. CASE x OF
  41. | 00H..0CFH,0D1H..0DCH,0DFH..0EFH,0F1H..0FCH,0FFH: y := 00H + x
  42. | 0DEH: y := 015EH
  43. | 0FEH: y := 015FH
  44. | 0D0H: y := 011EH
  45. | 0F0H: y := 011FH
  46. | 0DDH: y := 0130H
  47. | 0FDH: y := 0131H
  48. ELSE
  49. RETURN
  50. END;
  51. t[tW] := CHR(y); INC(tW);
  52. INC(fR); DEC(fLen)
  53. END;
  54. state := FALSE
  55. END Decode;
  56. PROCEDURE (d: Decoder) Reset, EMPTY;
  57. PROCEDURE NewDecoder* (): Codecs.Decoder;
  58. VAR d: Decoder;
  59. BEGIN
  60. NEW(d); RETURN d
  61. END NewDecoder;
  62. END EncStdMap_iso8859_9.