--- /dev/null
+
+// Single-byte codec. Needs a 'chars' string parameter that contains 256 or 128 chars that
+// correspond to encoded bytes (if 128 - then lower half is ASCII).
+
+exports._sbcs = function(options) {
+ if (!options)
+ throw new Error("SBCS codec is called without the data.")
+
+ // Prepare char buffer for decoding.
+ if (!options.chars || (options.chars.length !== 128 && options.chars.length !== 256))
+ throw new Error("Encoding '"+options.type+"' has incorrect 'chars' (must be of len 128 or 256)");
+
+ if (options.chars.length === 128) {
+ var asciiString = "";
+ for (var i = 0; i < 128; i++)
+ asciiString += String.fromCharCode(i);
+ options.chars = asciiString + options.chars;
+ }
+
+ var decodeBuf = new Buffer(options.chars, 'ucs2');
+
+ // Encoding buffer.
+ var encodeBuf = new Buffer(65536);
+ encodeBuf.fill(options.iconv.defaultCharSingleByte.charCodeAt(0));
+
+ for (var i = 0; i < options.chars.length; i++)
+ encodeBuf[options.chars.charCodeAt(i)] = i;
+
+ return {
+ encoder: encoderSBCS,
+ decoder: decoderSBCS,
+
+ encodeBuf: encodeBuf,
+ decodeBuf: decodeBuf,
+ };
+}
+
+function encoderSBCS(options) {
+ return {
+ write: encoderSBCSWrite,
+ end: function() {},
+
+ encodeBuf: this.encodeBuf,
+ };
+}
+
+function encoderSBCSWrite(str) {
+ var buf = new Buffer(str.length);
+ for (var i = 0; i < str.length; i++)
+ buf[i] = this.encodeBuf[str.charCodeAt(i)];
+
+ return buf;
+}
+
+
+function decoderSBCS(options) {
+ return {
+ write: decoderSBCSWrite,
+ end: function() {},
+
+ decodeBuf: this.decodeBuf,
+ };
+}
+
+function decoderSBCSWrite(buf) {
+ // Strings are immutable in JS -> we use ucs2 buffer to speed up computations.
+ var decodeBuf = this.decodeBuf;
+ var newBuf = new Buffer(buf.length*2);
+ var idx1 = 0, idx2 = 0;
+ for (var i = 0, _len = buf.length; i < _len; i++) {
+ idx1 = buf[i]*2; idx2 = i*2;
+ newBuf[idx2] = decodeBuf[idx1];
+ newBuf[idx2+1] = decodeBuf[idx1+1];
+ }
+ return newBuf.toString('ucs2');
+}