You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

137 lines
5.9 KiB

11 months ago
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var defaultEncoding_1 = require("../encoding/defaultEncoding");
var encoding_factory_1 = require("../encoding/encoding-factory");
var encodings_1 = require("../encoding/encodings");
var finished_1 = require("../encoding/finished");
var terminology_1 = require("../encoding/terminology");
var utilities_1 = require("../encoding/utilities");
var getGlobalScope_1 = require("../helper/getGlobalScope");
var Stream_1 = require("./Stream");
/**
* @constructor
* @param {string=} label The label of the encoding. NONSTANDARD.
* @param {Object=} options NONSTANDARD.
*/
var TextEncoder = /** @class */ (function () {
function TextEncoder(label, options) {
var optionsMap = utilities_1.ToDictionary(options);
// A TextEncoder object has an associated encoding and encoder.
/** @private */
this._encoding = null;
/** @private @type {?Encoder} */
this._encoder = null;
// Non-standard
/** @private @type {boolean} */
this._do_not_flush = false;
/** @private @type {string} */
this._fatal = Boolean(optionsMap['fatal']) ? 'fatal' : 'replacement';
// 1. Let enc be a new TextEncoder object.
// const enc = this;
// no need to do this as this is a proper class
// now and TSC will handle transpilation to older platforms
// 2. Set enc's encoding to UTF-8's encoder.
if (Boolean(optionsMap['NONSTANDARD_allowLegacyEncoding'])) {
// NONSTANDARD behavior.
label = !!label ? String(label) : defaultEncoding_1.DEFAULT_ENCODING;
var encoding = encodings_1.getEncoding(label);
if (encoding === null || encoding.name === 'replacement')
throw RangeError('Unknown encoding: ' + label);
if (!encoding_factory_1.encoders[encoding.name]) {
throw Error('Encoder not present.' +
' Did you forget to include encoding-indexes.js first?');
}
this._encoding = encoding;
// EXPERIMENTAL_CODE
// } else if (["iso-8859-1", "ISO-8859-1", "latin-1", "latin1", "LATIN-1", "LATIN1"].indexOf(label) !== -1) {
// this._encoding = getEncoding('iso-8859-1');
}
else {
// Standard behavior.
this._encoding = encodings_1.getEncoding('utf-8');
var glo = getGlobalScope_1.getGlobalScope() || {};
if (label !== undefined && 'console' in glo) {
console.warn('TextEncoder constructor called with encoding label, '
+ 'which is ignored.');
}
}
// For pre-ES5 runtimes:
// if (!Object.defineProperty)
// this.encoding = enc._encoding.name.toLowerCase();
// 3. Return enc.
// return enc;
}
Object.defineProperty(TextEncoder.prototype, "encoding", {
// if(Object.defineProperty) {
// // The encoding attribute's getter must return encoding's name.
// Object.defineProperty(TextEncoder.prototype, 'encoding', {
// /** @this {TextEncoder} */
// get: function () { return this._encoding.name.toLowerCase(); }
// });
// }
get: function () {
return this._encoding.name.toLowerCase();
},
enumerable: true,
configurable: true
});
/**
* @param {string=} opt_string The string to encode.
* @param {Object=} options
* @return {!Uint8Array} Encoded bytes, as a Uint8Array.
*/
TextEncoder.prototype.encode = function (opt_string, options) {
opt_string = opt_string === undefined ? '' : String(opt_string);
var optionsMap = utilities_1.ToDictionary(options);
// NOTE: This option is nonstandard. None of the encodings
// permitted for encoding (i.e. UTF-8, UTF-16) are stateful when
// the input is a USVString so streaming is not necessary.
if (!this._do_not_flush)
this._encoder = encoding_factory_1.encoders[this._encoding.name]({
fatal: this._fatal === 'fatal'
});
this._do_not_flush = Boolean(optionsMap['stream']);
// 1. Convert input to a stream.
var input = new Stream_1.Stream(utilities_1.stringToCodePoints(opt_string));
// 2. Let output be a new stream
var output = [];
/** @type {?(number|!Array.<number>)} */
var result;
// 3. While true, run these substeps:
while (true) {
// 1. Let token be the result of reading from input.
var token = input.read();
if (token === terminology_1.end_of_stream)
break;
// 2. Let result be the result of processing token for encoder,
// input, output.
result = this._encoder.handler(input, token);
if (result === finished_1.finished)
break;
if (Array.isArray(result))
output.push.apply(output, /**@type {!Array.<number>}*/ (result));
else
output.push(result);
}
// TODO: Align with spec algorithm.
if (!this._do_not_flush) {
while (true) {
result = this._encoder.handler(input, input.read());
if (result === finished_1.finished)
break;
if (Array.isArray(result))
output.push.apply(output, /**@type {!Array.<number>}*/ (result));
else
output.push(result);
}
this._encoder = null;
}
// 3. If result is finished, convert output into a byte sequence,
// and then return a Uint8Array object wrapping an ArrayBuffer
// containing output.
return new Uint8Array(output);
};
return TextEncoder;
}());
exports.TextEncoder = TextEncoder;
//# sourceMappingURL=TextEncoder.js.map