XUserDefinedDecoder.js 1.2 KB

123456789101112131415161718192021222324252627282930313233
  1. import { finished } from "../../encoding/finished";
  2. import { end_of_stream, isASCIIByte } from "../../encoding/terminology";
  3. /**
  4. * @constructor
  5. * @implements {Decoder}
  6. * @param {{fatal: boolean}} options
  7. */
  8. var XUserDefinedDecoder = /** @class */ (function () {
  9. function XUserDefinedDecoder(options) {
  10. this.fatal = options.fatal;
  11. }
  12. /**
  13. * @param {Stream} stream The stream of bytes being decoded.
  14. * @param {number} bite The next byte read from the stream.
  15. * @return {?(number|!Array.<number>)} The next code point(s)
  16. * decoded, or null if not enough data exists in the input
  17. * stream to decode a complete code point.
  18. */
  19. XUserDefinedDecoder.prototype.handler = function (stream, bite) {
  20. // 1. If byte is end-of-stream, return finished.
  21. if (bite === end_of_stream)
  22. return finished;
  23. // 2. If byte is an ASCII byte, return a code point whose value
  24. // is byte.
  25. if (isASCIIByte(bite))
  26. return bite;
  27. // 3. Return a code point whose value is 0xF780 + byte − 0x80.
  28. return 0xF780 + bite - 0x80;
  29. };
  30. return XUserDefinedDecoder;
  31. }());
  32. export { XUserDefinedDecoder };
  33. //# sourceMappingURL=XUserDefinedDecoder.js.map