"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
|