forked from sheetjs/sheetjs
SheetJS
a3d9c4d9ac
- basic style + theme parsing, option .cellStyles (h/t @eladxxx) - more XLSB writing stubs - correct resolution of .xml/.bin files - sheet_to_json improvements from js-xls o opts.header = 1 for array of arrays o opts.header = 'A' for spreadsheet column labels o custom opts.header array for custom labels o opts.range = n starts from row n o opts.range = range restricts writer to work within the specified range - Makefile adapted to work with cygwin on windows
101 lines
3.8 KiB
JavaScript
101 lines
3.8 KiB
JavaScript
function readIEEE754(buf, idx, isLE, nl, ml) {
|
|
if(isLE === undefined) isLE = true;
|
|
if(!nl) nl = 8;
|
|
if(!ml && nl === 8) ml = 52;
|
|
var e, m, el = nl * 8 - ml - 1, eMax = (1 << el) - 1, eBias = eMax >> 1;
|
|
var bits = -7, d = isLE ? -1 : 1, i = isLE ? (nl - 1) : 0, s = buf[idx + i];
|
|
|
|
i += d;
|
|
e = s & ((1 << (-bits)) - 1); s >>>= (-bits); bits += el;
|
|
for (; bits > 0; e = e * 256 + buf[idx + i], i += d, bits -= 8);
|
|
m = e & ((1 << (-bits)) - 1); e >>>= (-bits); bits += ml;
|
|
for (; bits > 0; m = m * 256 + buf[idx + i], i += d, bits -= 8);
|
|
if (e === eMax) return m ? NaN : ((s ? -1 : 1) * Infinity);
|
|
else if (e === 0) e = 1 - eBias;
|
|
else { m = m + Math.pow(2, ml); e = e - eBias; }
|
|
return (s ? -1 : 1) * m * Math.pow(2, e - ml);
|
|
}
|
|
|
|
var __toBuffer, ___toBuffer;
|
|
__toBuffer = ___toBuffer = function(bufs) {
|
|
var x = [];
|
|
for(var i = 0; i != bufs[0].length; ++i) { x = x.concat(bufs[0][i]); }
|
|
return x;
|
|
};
|
|
if(typeof Buffer !== "undefined") {
|
|
Buffer.prototype.hexlify= function() { return this.toString('hex'); };
|
|
__toBuffer = function(bufs) { try { return Buffer.concat(bufs[0]); } catch(e) { return ___toBuffer(bufs);} };
|
|
}
|
|
|
|
var __readUInt8 = function(b, idx) { return b.readUInt8 ? b.readUInt8(idx) : b[idx]; };
|
|
var __readUInt16LE = function(b, idx) { return b.readUInt16LE ? b.readUInt16LE(idx) : b[idx+1]*(1<<8)+b[idx]; };
|
|
var __readInt16LE = function(b, idx) { var u = __readUInt16LE(b,idx); if(!(u & 0x8000)) return u; return (0xffff - u + 1) * -1; };
|
|
var __readUInt32LE = function(b, idx) { return b.readUInt32LE ? b.readUInt32LE(idx) : b[idx+3]*(1<<24)+b[idx+2]*(1<<16)+b[idx+1]*(1<<8)+b[idx]; };
|
|
var __readInt32LE = function(b, idx) { if(b.readInt32LE) return b.readInt32LE(idx); var u = __readUInt32LE(b,idx); if(!(u & 0x80000000)) return u; return (0xffffffff - u + 1) * -1; };
|
|
var __readDoubleLE = function(b, idx) { return b.readDoubleLE ? b.readDoubleLE(idx) : readIEEE754(b, idx||0);};
|
|
|
|
var __hexlify = function(b,l) { if(b.hexlify) return b.hexlify((b.l||0), (b.l||0)+l); return b.slice(b.l||0,(b.l||0)+16).map(function(x){return (x<16?"0":"") + x.toString(16);}).join(""); };
|
|
|
|
function ReadShift(size, t) {
|
|
var o="", oo=[], w, vv, i, loc; t = t || 'u';
|
|
if(size === 'ieee754') { size = 8; t = 'f'; }
|
|
switch(size) {
|
|
case 1: o = __readUInt8(this, this.l); break;
|
|
case 2: o=(t==='u' ? __readUInt16LE : __readInt16LE)(this, this.l); break;
|
|
case 4: o = __readUInt32LE(this, this.l); break;
|
|
case 8: if(t === 'f') { o = __readDoubleLE(this, this.l); break; }
|
|
/* falls through */
|
|
case 16: o = __hexlify(this, 16); break;
|
|
|
|
case 'dbcs': size = 2*t; loc = this.l;
|
|
for(i = 0; i != t; ++i) {
|
|
oo.push(_getchar(__readUInt16LE(this, loc)));
|
|
loc+=2;
|
|
} o = oo.join(""); break;
|
|
}
|
|
this.l+=size; return o;
|
|
}
|
|
|
|
function WriteShift(t, val, f) {
|
|
var size, i;
|
|
if(t === 'ieee754') { f = 'f'; t = 8; }
|
|
switch(t) {
|
|
case 1: size = 1; this.writeUInt8(val, this.l); break;
|
|
case 4: size = 4; this.writeUInt32LE(val, this.l); break;
|
|
case 8: size = 8; if(f === 'f') { this.writeDoubleLE(val, this.l); break; }
|
|
/* falls through */
|
|
case 16: break;
|
|
case -4: size = 4; this.writeInt32LE(val, this.l); break;
|
|
case 'dbcs':
|
|
for(i = 0; i != val.length; ++i) this.writeUInt16LE(val.charCodeAt(i), this.l + 2 * i);
|
|
size = 2 * val.length;
|
|
break;
|
|
}
|
|
this.l += size; return this;
|
|
}
|
|
|
|
function prep_blob(blob, pos, w) {
|
|
blob.l = pos || 0;
|
|
if(w) {
|
|
var write = WriteShift.bind(blob);
|
|
blob.write_shift = write;
|
|
return [write];
|
|
} else {
|
|
var read = ReadShift.bind(blob);
|
|
blob.read_shift = read;
|
|
return [read];
|
|
}
|
|
}
|
|
|
|
function parsenoop(blob, length) { blob.l += length; }
|
|
|
|
function writenoop(blob, length) { blob.l += length; }
|
|
|
|
var new_buf = function(sz) {
|
|
var o = typeof Buffer !== 'undefined' ? new Buffer(sz) : new Array(sz);
|
|
prep_blob(o, 0, true);
|
|
return o;
|
|
};
|
|
|
|
var is_buf = function(a) { return (typeof Buffer !== 'undefined' && a instanceof Buffer) || Array.isArray(a); };
|