EUCKREncoder.js 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. var encodings_1 = require("../../encoding/encodings");
  4. var finished_1 = require("../../encoding/finished");
  5. var indexes_1 = require("../../encoding/indexes");
  6. var terminology_1 = require("../../encoding/terminology");
  7. /**
  8. * @constructor
  9. * @implements {Encoder}
  10. * @param {{fatal: boolean}} options
  11. */
  12. var EUCKREncoder = /** @class */ (function () {
  13. function EUCKREncoder(options) {
  14. this.fatal = options.fatal;
  15. }
  16. /**
  17. * @param {Stream} stream Input stream.
  18. * @param {number} code_point Next code point read from the stream.
  19. * @return {(number|!Array.<number>)} Byte(s) to emit.
  20. */
  21. EUCKREncoder.prototype.handler = function (stream, code_point) {
  22. // 1. If code point is end-of-stream, return finished.
  23. if (code_point === terminology_1.end_of_stream)
  24. return finished_1.finished;
  25. // 2. If code point is an ASCII code point, return a byte whose
  26. // value is code point.
  27. if (terminology_1.isASCIICodePoint(code_point))
  28. return code_point;
  29. // 3. Let pointer be the index pointer for code point in index
  30. // euc-kr.
  31. var pointer = indexes_1.indexPointerFor(code_point, indexes_1.index('euc-kr'));
  32. // 4. If pointer is null, return error with code point.
  33. if (pointer === null)
  34. return encodings_1.encoderError(code_point);
  35. // 5. Let lead be Math.floor(pointer / 190) + 0x81.
  36. var lead = Math.floor(pointer / 190) + 0x81;
  37. // 6. Let trail be pointer % 190 + 0x41.
  38. var trail = (pointer % 190) + 0x41;
  39. // 7. Return two bytes whose values are lead and trail.
  40. return [lead, trail];
  41. };
  42. return EUCKREncoder;
  43. }());
  44. exports.EUCKREncoder = EUCKREncoder;
  45. //# sourceMappingURL=EUCKREncoder.js.map