forked from sheetjs/sheetjs
version bump 0.14.5: XLS grind
- XLS force stub for commented cells (fixes #1567 h/t @Krelborn) - XLS PtgNameX use ixti (fixes #1581 h/t @staperney)
This commit is contained in:
parent
90354392dd
commit
442c4342df
@ -1,4 +1,5 @@
|
|||||||
test_files/
|
test_files/
|
||||||
|
.github/
|
||||||
tests/files/
|
tests/files/
|
||||||
demos/
|
demos/
|
||||||
index.html
|
index.html
|
||||||
|
@ -1 +1 @@
|
|||||||
XLSX.version = '0.14.4';
|
XLSX.version = '0.14.5';
|
||||||
|
@ -75,5 +75,5 @@ if(typeof cptable !== 'undefined') {
|
|||||||
};
|
};
|
||||||
_getansi = function _ga2(x/*:number*/)/*:string*/ {
|
_getansi = function _ga2(x/*:number*/)/*:string*/ {
|
||||||
return cptable.utils.decode(current_ansi, [x])[0];
|
return cptable.utils.decode(current_ansi, [x])[0];
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
@ -335,6 +335,8 @@ var SYLK = (function() {
|
|||||||
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
||||||
};
|
};
|
||||||
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
||||||
|
var sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == "number" ? _getansi(o) : o; };
|
||||||
|
var decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };
|
||||||
sylk_escapes["|"] = 254;
|
sylk_escapes["|"] = 254;
|
||||||
/* TODO: find an actual specification */
|
/* TODO: find an actual specification */
|
||||||
function sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {
|
function sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {
|
||||||
@ -355,13 +357,7 @@ var SYLK = (function() {
|
|||||||
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
||||||
for (; ri !== records.length; ++ri) {
|
for (; ri !== records.length; ++ri) {
|
||||||
Mval = 0;
|
Mval = 0;
|
||||||
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, function($$, $1, $2) {
|
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);
|
||||||
var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30);
|
|
||||||
return newcc == 59 ? $$ : _getansi(newcc);
|
|
||||||
}).replace(sylk_char_regex, function(_, $1){
|
|
||||||
var o = sylk_escapes[$1];
|
|
||||||
return typeof o == "number" ? _getansi(o) : o;
|
|
||||||
});
|
|
||||||
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
||||||
var RT=record[0], val;
|
var RT=record[0], val;
|
||||||
if(rstr.length > 0) switch(RT) {
|
if(rstr.length > 0) switch(RT) {
|
||||||
|
@ -720,7 +720,7 @@ function get_ixti_raw(supbooks, ixti/*:number*/, opts)/*:string*/ {
|
|||||||
case 0x0401:
|
case 0x0401:
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
||||||
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
||||||
case 0x3A01: return "SH33TJSERR8";
|
case 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(";;"); //return "SH33TJSERR8";
|
||||||
default:
|
default:
|
||||||
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
||||||
@ -836,7 +836,7 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
stack.push(String(f[1])); break;
|
stack.push(String(f[1])); break;
|
||||||
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
||||||
// $FlowIgnore
|
// $FlowIgnore
|
||||||
stack.push('"' + f[1] + '"'); break;
|
stack.push('"' + f[1].replace(/"/g, '""') + '"'); break;
|
||||||
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
||||||
stack.push(/*::String(*/f[1]/*::)*/); break;
|
stack.push(/*::String(*/f[1]/*::)*/); break;
|
||||||
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
||||||
@ -872,7 +872,7 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
||||||
/* f[1] = type, ixti, nameindex */
|
/* f[1] = type, ixti, nameindex */
|
||||||
var bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;
|
var bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;
|
||||||
/* TODO: Properly handle missing values */
|
/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */
|
||||||
if(opts.biff <= 5) {
|
if(opts.biff <= 5) {
|
||||||
if(bookidx < 0) bookidx = -bookidx;
|
if(bookidx < 0) bookidx = -bookidx;
|
||||||
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
||||||
@ -887,7 +887,11 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
||||||
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
||||||
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
||||||
else o += "SH33TJSERRX";
|
else {
|
||||||
|
var ixtidata = get_ixti_raw(supbooks, bookidx, opts).split(";;");
|
||||||
|
if(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct
|
||||||
|
else o += "SH33TJSERRX";
|
||||||
|
}
|
||||||
stack.push(o);
|
stack.push(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -534,7 +534,18 @@ function parse_workbook(blob, options/*:ParseOpts*/)/*:Workbook*/ {
|
|||||||
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
||||||
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
||||||
var noteobj = objects[val[2]];
|
var noteobj = objects[val[2]];
|
||||||
if(!cc) break;
|
if(!cc) {
|
||||||
|
if(options.dense) {
|
||||||
|
if(!out[val[0].r]) out[val[0].r] = [];
|
||||||
|
cc = out[val[0].r][val[0].c] = {t:"z"};
|
||||||
|
} else {
|
||||||
|
cc = out[encode_cell(val[0])] = {t:"z"};
|
||||||
|
}
|
||||||
|
range.e.r = Math.max(range.e.r, val[0].r);
|
||||||
|
range.s.r = Math.min(range.s.r, val[0].r);
|
||||||
|
range.e.c = Math.max(range.e.c, val[0].c);
|
||||||
|
range.s.c = Math.min(range.s.c, val[0].c);
|
||||||
|
}
|
||||||
if(!cc.c) cc.c = [];
|
if(!cc.c) cc.c = [];
|
||||||
cmnt = {a:val[1],t:noteobj.TxO.t};
|
cmnt = {a:val[1],t:noteobj.TxO.t};
|
||||||
cc.c.push(cmnt);
|
cc.c.push(cmnt);
|
||||||
|
22
dist/xlsx.core.min.js
generated
vendored
22
dist/xlsx.core.min.js
generated
vendored
File diff suppressed because one or more lines are too long
2
dist/xlsx.core.min.map
generated
vendored
2
dist/xlsx.core.min.map
generated
vendored
File diff suppressed because one or more lines are too long
39
dist/xlsx.extendscript.js
generated
vendored
39
dist/xlsx.extendscript.js
generated
vendored
@ -9160,7 +9160,7 @@ module.exports = ZStream;
|
|||||||
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
||||||
var XLSX = {};
|
var XLSX = {};
|
||||||
function make_xlsx_lib(XLSX){
|
function make_xlsx_lib(XLSX){
|
||||||
XLSX.version = '0.14.4';
|
XLSX.version = '0.14.5';
|
||||||
var current_codepage = 1200, current_ansi = 1252;
|
var current_codepage = 1200, current_ansi = 1252;
|
||||||
/*global cptable:true, window */
|
/*global cptable:true, window */
|
||||||
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
||||||
@ -9237,7 +9237,7 @@ if(typeof cptable !== 'undefined') {
|
|||||||
};
|
};
|
||||||
_getansi = function _ga2(x) {
|
_getansi = function _ga2(x) {
|
||||||
return cptable.utils.decode(current_ansi, [x])[0];
|
return cptable.utils.decode(current_ansi, [x])[0];
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
var DENSE = null;
|
var DENSE = null;
|
||||||
var DIF_XL = true;
|
var DIF_XL = true;
|
||||||
@ -16120,6 +16120,8 @@ var SYLK = (function() {
|
|||||||
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
||||||
};
|
};
|
||||||
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
||||||
|
var sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == "number" ? _getansi(o) : o; };
|
||||||
|
var decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };
|
||||||
sylk_escapes["|"] = 254;
|
sylk_escapes["|"] = 254;
|
||||||
/* TODO: find an actual specification */
|
/* TODO: find an actual specification */
|
||||||
function sylk_to_aoa(d, opts) {
|
function sylk_to_aoa(d, opts) {
|
||||||
@ -16140,13 +16142,7 @@ var SYLK = (function() {
|
|||||||
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
||||||
for (; ri !== records.length; ++ri) {
|
for (; ri !== records.length; ++ri) {
|
||||||
Mval = 0;
|
Mval = 0;
|
||||||
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, function($$, $1, $2) {
|
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);
|
||||||
var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30);
|
|
||||||
return newcc == 59 ? $$ : _getansi(newcc);
|
|
||||||
}).replace(sylk_char_regex, function(_, $1){
|
|
||||||
var o = sylk_escapes[$1];
|
|
||||||
return typeof o == "number" ? _getansi(o) : o;
|
|
||||||
});
|
|
||||||
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
||||||
var RT=record[0], val;
|
var RT=record[0], val;
|
||||||
if(rstr.length > 0) switch(RT) {
|
if(rstr.length > 0) switch(RT) {
|
||||||
@ -20148,7 +20144,7 @@ function get_ixti_raw(supbooks, ixti, opts) {
|
|||||||
case 0x0401:
|
case 0x0401:
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
||||||
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
||||||
case 0x3A01: return "SH33TJSERR8";
|
case 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(";;"); //return "SH33TJSERR8";
|
||||||
default:
|
default:
|
||||||
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
||||||
@ -20264,7 +20260,7 @@ ixti = f[1][1]; c = shift_cell_xls((f[1][2]), _range, opts);
|
|||||||
stack.push(String(f[1])); break;
|
stack.push(String(f[1])); break;
|
||||||
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
||||||
// $FlowIgnore
|
// $FlowIgnore
|
||||||
stack.push('"' + f[1] + '"'); break;
|
stack.push('"' + f[1].replace(/"/g, '""') + '"'); break;
|
||||||
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
||||||
stack.push(f[1]); break;
|
stack.push(f[1]); break;
|
||||||
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
||||||
@ -20300,7 +20296,7 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
||||||
/* f[1] = type, ixti, nameindex */
|
/* f[1] = type, ixti, nameindex */
|
||||||
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
||||||
/* TODO: Properly handle missing values */
|
/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */
|
||||||
if(opts.biff <= 5) {
|
if(opts.biff <= 5) {
|
||||||
if(bookidx < 0) bookidx = -bookidx;
|
if(bookidx < 0) bookidx = -bookidx;
|
||||||
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
||||||
@ -20315,7 +20311,11 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
||||||
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
||||||
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
||||||
else o += "SH33TJSERRX";
|
else {
|
||||||
|
var ixtidata = get_ixti_raw(supbooks, bookidx, opts).split(";;");
|
||||||
|
if(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct
|
||||||
|
else o += "SH33TJSERRX";
|
||||||
|
}
|
||||||
stack.push(o);
|
stack.push(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -26030,7 +26030,18 @@ wb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;
|
|||||||
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
||||||
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
||||||
var noteobj = objects[val[2]];
|
var noteobj = objects[val[2]];
|
||||||
if(!cc) break;
|
if(!cc) {
|
||||||
|
if(options.dense) {
|
||||||
|
if(!out[val[0].r]) out[val[0].r] = [];
|
||||||
|
cc = out[val[0].r][val[0].c] = {t:"z"};
|
||||||
|
} else {
|
||||||
|
cc = out[encode_cell(val[0])] = {t:"z"};
|
||||||
|
}
|
||||||
|
range.e.r = Math.max(range.e.r, val[0].r);
|
||||||
|
range.s.r = Math.min(range.s.r, val[0].r);
|
||||||
|
range.e.c = Math.max(range.e.c, val[0].c);
|
||||||
|
range.s.c = Math.min(range.s.c, val[0].c);
|
||||||
|
}
|
||||||
if(!cc.c) cc.c = [];
|
if(!cc.c) cc.c = [];
|
||||||
cmnt = {a:val[1],t:noteobj.TxO.t};
|
cmnt = {a:val[1],t:noteobj.TxO.t};
|
||||||
cc.c.push(cmnt);
|
cc.c.push(cmnt);
|
||||||
|
18
dist/xlsx.full.min.js
generated
vendored
18
dist/xlsx.full.min.js
generated
vendored
File diff suppressed because one or more lines are too long
2
dist/xlsx.full.min.map
generated
vendored
2
dist/xlsx.full.min.map
generated
vendored
File diff suppressed because one or more lines are too long
39
dist/xlsx.js
generated
vendored
39
dist/xlsx.js
generated
vendored
@ -4,7 +4,7 @@
|
|||||||
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
||||||
var XLSX = {};
|
var XLSX = {};
|
||||||
function make_xlsx_lib(XLSX){
|
function make_xlsx_lib(XLSX){
|
||||||
XLSX.version = '0.14.4';
|
XLSX.version = '0.14.5';
|
||||||
var current_codepage = 1200, current_ansi = 1252;
|
var current_codepage = 1200, current_ansi = 1252;
|
||||||
/*global cptable:true, window */
|
/*global cptable:true, window */
|
||||||
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
||||||
@ -81,7 +81,7 @@ if(typeof cptable !== 'undefined') {
|
|||||||
};
|
};
|
||||||
_getansi = function _ga2(x) {
|
_getansi = function _ga2(x) {
|
||||||
return cptable.utils.decode(current_ansi, [x])[0];
|
return cptable.utils.decode(current_ansi, [x])[0];
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
var DENSE = null;
|
var DENSE = null;
|
||||||
var DIF_XL = true;
|
var DIF_XL = true;
|
||||||
@ -6964,6 +6964,8 @@ var SYLK = (function() {
|
|||||||
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
||||||
};
|
};
|
||||||
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
||||||
|
var sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == "number" ? _getansi(o) : o; };
|
||||||
|
var decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };
|
||||||
sylk_escapes["|"] = 254;
|
sylk_escapes["|"] = 254;
|
||||||
/* TODO: find an actual specification */
|
/* TODO: find an actual specification */
|
||||||
function sylk_to_aoa(d, opts) {
|
function sylk_to_aoa(d, opts) {
|
||||||
@ -6984,13 +6986,7 @@ var SYLK = (function() {
|
|||||||
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
||||||
for (; ri !== records.length; ++ri) {
|
for (; ri !== records.length; ++ri) {
|
||||||
Mval = 0;
|
Mval = 0;
|
||||||
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, function($$, $1, $2) {
|
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);
|
||||||
var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30);
|
|
||||||
return newcc == 59 ? $$ : _getansi(newcc);
|
|
||||||
}).replace(sylk_char_regex, function(_, $1){
|
|
||||||
var o = sylk_escapes[$1];
|
|
||||||
return typeof o == "number" ? _getansi(o) : o;
|
|
||||||
});
|
|
||||||
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
||||||
var RT=record[0], val;
|
var RT=record[0], val;
|
||||||
if(rstr.length > 0) switch(RT) {
|
if(rstr.length > 0) switch(RT) {
|
||||||
@ -10992,7 +10988,7 @@ function get_ixti_raw(supbooks, ixti, opts) {
|
|||||||
case 0x0401:
|
case 0x0401:
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
||||||
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
||||||
case 0x3A01: return "SH33TJSERR8";
|
case 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(";;"); //return "SH33TJSERR8";
|
||||||
default:
|
default:
|
||||||
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
||||||
@ -11108,7 +11104,7 @@ ixti = f[1][1]; c = shift_cell_xls((f[1][2]), _range, opts);
|
|||||||
stack.push(String(f[1])); break;
|
stack.push(String(f[1])); break;
|
||||||
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
||||||
// $FlowIgnore
|
// $FlowIgnore
|
||||||
stack.push('"' + f[1] + '"'); break;
|
stack.push('"' + f[1].replace(/"/g, '""') + '"'); break;
|
||||||
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
||||||
stack.push(f[1]); break;
|
stack.push(f[1]); break;
|
||||||
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
||||||
@ -11144,7 +11140,7 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
||||||
/* f[1] = type, ixti, nameindex */
|
/* f[1] = type, ixti, nameindex */
|
||||||
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
||||||
/* TODO: Properly handle missing values */
|
/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */
|
||||||
if(opts.biff <= 5) {
|
if(opts.biff <= 5) {
|
||||||
if(bookidx < 0) bookidx = -bookidx;
|
if(bookidx < 0) bookidx = -bookidx;
|
||||||
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
||||||
@ -11159,7 +11155,11 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
||||||
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
||||||
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
||||||
else o += "SH33TJSERRX";
|
else {
|
||||||
|
var ixtidata = get_ixti_raw(supbooks, bookidx, opts).split(";;");
|
||||||
|
if(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct
|
||||||
|
else o += "SH33TJSERRX";
|
||||||
|
}
|
||||||
stack.push(o);
|
stack.push(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -16874,7 +16874,18 @@ wb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;
|
|||||||
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
||||||
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
||||||
var noteobj = objects[val[2]];
|
var noteobj = objects[val[2]];
|
||||||
if(!cc) break;
|
if(!cc) {
|
||||||
|
if(options.dense) {
|
||||||
|
if(!out[val[0].r]) out[val[0].r] = [];
|
||||||
|
cc = out[val[0].r][val[0].c] = {t:"z"};
|
||||||
|
} else {
|
||||||
|
cc = out[encode_cell(val[0])] = {t:"z"};
|
||||||
|
}
|
||||||
|
range.e.r = Math.max(range.e.r, val[0].r);
|
||||||
|
range.s.r = Math.min(range.s.r, val[0].r);
|
||||||
|
range.e.c = Math.max(range.e.c, val[0].c);
|
||||||
|
range.s.c = Math.min(range.s.c, val[0].c);
|
||||||
|
}
|
||||||
if(!cc.c) cc.c = [];
|
if(!cc.c) cc.c = [];
|
||||||
cmnt = {a:val[1],t:noteobj.TxO.t};
|
cmnt = {a:val[1],t:noteobj.TxO.t};
|
||||||
cc.c.push(cmnt);
|
cc.c.push(cmnt);
|
||||||
|
18
dist/xlsx.min.js
generated
vendored
18
dist/xlsx.min.js
generated
vendored
File diff suppressed because one or more lines are too long
2
dist/xlsx.min.map
generated
vendored
2
dist/xlsx.min.map
generated
vendored
File diff suppressed because one or more lines are too long
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "xlsx",
|
"name": "xlsx",
|
||||||
"version": "0.14.4",
|
"version": "0.14.5",
|
||||||
"author": "sheetjs",
|
"author": "sheetjs",
|
||||||
"description": "SheetJS Spreadsheet data parser and writer",
|
"description": "SheetJS Spreadsheet data parser and writer",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
|
39
xlsx.flow.js
39
xlsx.flow.js
@ -4,7 +4,7 @@
|
|||||||
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
||||||
var XLSX = {};
|
var XLSX = {};
|
||||||
function make_xlsx_lib(XLSX){
|
function make_xlsx_lib(XLSX){
|
||||||
XLSX.version = '0.14.4';
|
XLSX.version = '0.14.5';
|
||||||
var current_codepage = 1200, current_ansi = 1252;
|
var current_codepage = 1200, current_ansi = 1252;
|
||||||
/*:: declare var cptable:any; */
|
/*:: declare var cptable:any; */
|
||||||
/*global cptable:true, window */
|
/*global cptable:true, window */
|
||||||
@ -82,7 +82,7 @@ if(typeof cptable !== 'undefined') {
|
|||||||
};
|
};
|
||||||
_getansi = function _ga2(x/*:number*/)/*:string*/ {
|
_getansi = function _ga2(x/*:number*/)/*:string*/ {
|
||||||
return cptable.utils.decode(current_ansi, [x])[0];
|
return cptable.utils.decode(current_ansi, [x])[0];
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
var DENSE = null;
|
var DENSE = null;
|
||||||
var DIF_XL = true;
|
var DIF_XL = true;
|
||||||
@ -7061,6 +7061,8 @@ var SYLK = (function() {
|
|||||||
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
||||||
};
|
};
|
||||||
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
||||||
|
var sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == "number" ? _getansi(o) : o; };
|
||||||
|
var decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };
|
||||||
sylk_escapes["|"] = 254;
|
sylk_escapes["|"] = 254;
|
||||||
/* TODO: find an actual specification */
|
/* TODO: find an actual specification */
|
||||||
function sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {
|
function sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {
|
||||||
@ -7081,13 +7083,7 @@ var SYLK = (function() {
|
|||||||
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
||||||
for (; ri !== records.length; ++ri) {
|
for (; ri !== records.length; ++ri) {
|
||||||
Mval = 0;
|
Mval = 0;
|
||||||
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, function($$, $1, $2) {
|
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);
|
||||||
var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30);
|
|
||||||
return newcc == 59 ? $$ : _getansi(newcc);
|
|
||||||
}).replace(sylk_char_regex, function(_, $1){
|
|
||||||
var o = sylk_escapes[$1];
|
|
||||||
return typeof o == "number" ? _getansi(o) : o;
|
|
||||||
});
|
|
||||||
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
||||||
var RT=record[0], val;
|
var RT=record[0], val;
|
||||||
if(rstr.length > 0) switch(RT) {
|
if(rstr.length > 0) switch(RT) {
|
||||||
@ -11093,7 +11089,7 @@ function get_ixti_raw(supbooks, ixti/*:number*/, opts)/*:string*/ {
|
|||||||
case 0x0401:
|
case 0x0401:
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
||||||
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
||||||
case 0x3A01: return "SH33TJSERR8";
|
case 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(";;"); //return "SH33TJSERR8";
|
||||||
default:
|
default:
|
||||||
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
||||||
@ -11209,7 +11205,7 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
stack.push(String(f[1])); break;
|
stack.push(String(f[1])); break;
|
||||||
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
||||||
// $FlowIgnore
|
// $FlowIgnore
|
||||||
stack.push('"' + f[1] + '"'); break;
|
stack.push('"' + f[1].replace(/"/g, '""') + '"'); break;
|
||||||
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
||||||
stack.push(/*::String(*/f[1]/*::)*/); break;
|
stack.push(/*::String(*/f[1]/*::)*/); break;
|
||||||
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
||||||
@ -11245,7 +11241,7 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
||||||
/* f[1] = type, ixti, nameindex */
|
/* f[1] = type, ixti, nameindex */
|
||||||
var bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;
|
var bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;
|
||||||
/* TODO: Properly handle missing values */
|
/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */
|
||||||
if(opts.biff <= 5) {
|
if(opts.biff <= 5) {
|
||||||
if(bookidx < 0) bookidx = -bookidx;
|
if(bookidx < 0) bookidx = -bookidx;
|
||||||
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
||||||
@ -11260,7 +11256,11 @@ function stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks,
|
|||||||
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
||||||
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
||||||
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
||||||
else o += "SH33TJSERRX";
|
else {
|
||||||
|
var ixtidata = get_ixti_raw(supbooks, bookidx, opts).split(";;");
|
||||||
|
if(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct
|
||||||
|
else o += "SH33TJSERRX";
|
||||||
|
}
|
||||||
stack.push(o);
|
stack.push(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -16988,7 +16988,18 @@ function parse_workbook(blob, options/*:ParseOpts*/)/*:Workbook*/ {
|
|||||||
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
||||||
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
||||||
var noteobj = objects[val[2]];
|
var noteobj = objects[val[2]];
|
||||||
if(!cc) break;
|
if(!cc) {
|
||||||
|
if(options.dense) {
|
||||||
|
if(!out[val[0].r]) out[val[0].r] = [];
|
||||||
|
cc = out[val[0].r][val[0].c] = {t:"z"};
|
||||||
|
} else {
|
||||||
|
cc = out[encode_cell(val[0])] = {t:"z"};
|
||||||
|
}
|
||||||
|
range.e.r = Math.max(range.e.r, val[0].r);
|
||||||
|
range.s.r = Math.min(range.s.r, val[0].r);
|
||||||
|
range.e.c = Math.max(range.e.c, val[0].c);
|
||||||
|
range.s.c = Math.min(range.s.c, val[0].c);
|
||||||
|
}
|
||||||
if(!cc.c) cc.c = [];
|
if(!cc.c) cc.c = [];
|
||||||
cmnt = {a:val[1],t:noteobj.TxO.t};
|
cmnt = {a:val[1],t:noteobj.TxO.t};
|
||||||
cc.c.push(cmnt);
|
cc.c.push(cmnt);
|
||||||
|
39
xlsx.js
generated
39
xlsx.js
generated
@ -4,7 +4,7 @@
|
|||||||
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
/*global global, exports, module, require:false, process:false, Buffer:false, ArrayBuffer:false */
|
||||||
var XLSX = {};
|
var XLSX = {};
|
||||||
function make_xlsx_lib(XLSX){
|
function make_xlsx_lib(XLSX){
|
||||||
XLSX.version = '0.14.4';
|
XLSX.version = '0.14.5';
|
||||||
var current_codepage = 1200, current_ansi = 1252;
|
var current_codepage = 1200, current_ansi = 1252;
|
||||||
/*global cptable:true, window */
|
/*global cptable:true, window */
|
||||||
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
||||||
@ -81,7 +81,7 @@ if(typeof cptable !== 'undefined') {
|
|||||||
};
|
};
|
||||||
_getansi = function _ga2(x) {
|
_getansi = function _ga2(x) {
|
||||||
return cptable.utils.decode(current_ansi, [x])[0];
|
return cptable.utils.decode(current_ansi, [x])[0];
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
var DENSE = null;
|
var DENSE = null;
|
||||||
var DIF_XL = true;
|
var DIF_XL = true;
|
||||||
@ -6964,6 +6964,8 @@ var SYLK = (function() {
|
|||||||
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
"+":171, ";":187, "<":188, "=":189, ">":190, "?":191, "{":223
|
||||||
};
|
};
|
||||||
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
var sylk_char_regex = new RegExp("\u001BN(" + keys(sylk_escapes).join("|").replace(/\|\|\|/, "|\\||").replace(/([?()+])/g,"\\$1") + "|\\|)", "gm");
|
||||||
|
var sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == "number" ? _getansi(o) : o; };
|
||||||
|
var decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };
|
||||||
sylk_escapes["|"] = 254;
|
sylk_escapes["|"] = 254;
|
||||||
/* TODO: find an actual specification */
|
/* TODO: find an actual specification */
|
||||||
function sylk_to_aoa(d, opts) {
|
function sylk_to_aoa(d, opts) {
|
||||||
@ -6984,13 +6986,7 @@ var SYLK = (function() {
|
|||||||
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
if(+opts.codepage >= 0) set_cp(+opts.codepage);
|
||||||
for (; ri !== records.length; ++ri) {
|
for (; ri !== records.length; ++ri) {
|
||||||
Mval = 0;
|
Mval = 0;
|
||||||
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, function($$, $1, $2) {
|
var rstr=records[ri].trim().replace(/\x1B([\x20-\x2F])([\x30-\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);
|
||||||
var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30);
|
|
||||||
return newcc == 59 ? $$ : _getansi(newcc);
|
|
||||||
}).replace(sylk_char_regex, function(_, $1){
|
|
||||||
var o = sylk_escapes[$1];
|
|
||||||
return typeof o == "number" ? _getansi(o) : o;
|
|
||||||
});
|
|
||||||
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
var record=rstr.replace(/;;/g, "\u0000").split(";").map(function(x) { return x.replace(/\u0000/g, ";"); });
|
||||||
var RT=record[0], val;
|
var RT=record[0], val;
|
||||||
if(rstr.length > 0) switch(RT) {
|
if(rstr.length > 0) switch(RT) {
|
||||||
@ -10992,7 +10988,7 @@ function get_ixti_raw(supbooks, ixti, opts) {
|
|||||||
case 0x0401:
|
case 0x0401:
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
o = XTI[1] == -1 ? "#REF" : (supbooks.SheetNames[XTI[1]] || "SH33TJSERR3");
|
||||||
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
return XTI[1] == XTI[2] ? o : o + ":" + supbooks.SheetNames[XTI[2]];
|
||||||
case 0x3A01: return "SH33TJSERR8";
|
case 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(";;"); //return "SH33TJSERR8";
|
||||||
default:
|
default:
|
||||||
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
if(!supbooks[XTI[0]][0][3]) return "SH33TJSERR2";
|
||||||
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
o = XTI[1] == -1 ? "#REF" : (supbooks[XTI[0]][0][3][XTI[1]] || "SH33TJSERR4");
|
||||||
@ -11108,7 +11104,7 @@ ixti = f[1][1]; c = shift_cell_xls((f[1][2]), _range, opts);
|
|||||||
stack.push(String(f[1])); break;
|
stack.push(String(f[1])); break;
|
||||||
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
case 'PtgStr': /* [MS-XLS] 2.5.198.89 */
|
||||||
// $FlowIgnore
|
// $FlowIgnore
|
||||||
stack.push('"' + f[1] + '"'); break;
|
stack.push('"' + f[1].replace(/"/g, '""') + '"'); break;
|
||||||
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
case 'PtgErr': /* [MS-XLS] 2.5.198.57 */
|
||||||
stack.push(f[1]); break;
|
stack.push(f[1]); break;
|
||||||
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
case 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */
|
||||||
@ -11144,7 +11140,7 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
case 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */
|
||||||
/* f[1] = type, ixti, nameindex */
|
/* f[1] = type, ixti, nameindex */
|
||||||
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
var bookidx = (f[1][1]); nameidx = (f[1][2]); var externbook;
|
||||||
/* TODO: Properly handle missing values */
|
/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */
|
||||||
if(opts.biff <= 5) {
|
if(opts.biff <= 5) {
|
||||||
if(bookidx < 0) bookidx = -bookidx;
|
if(bookidx < 0) bookidx = -bookidx;
|
||||||
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
if(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];
|
||||||
@ -11159,7 +11155,11 @@ ixti = f[1][1]; r = f[1][2];
|
|||||||
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
else o = supbooks.SheetNames[nameidx-1]+ "!";
|
||||||
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
if(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;
|
||||||
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
else if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;
|
||||||
else o += "SH33TJSERRX";
|
else {
|
||||||
|
var ixtidata = get_ixti_raw(supbooks, bookidx, opts).split(";;");
|
||||||
|
if(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct
|
||||||
|
else o += "SH33TJSERRX";
|
||||||
|
}
|
||||||
stack.push(o);
|
stack.push(o);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -16874,7 +16874,18 @@ wb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;
|
|||||||
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
if(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */
|
||||||
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
cc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];
|
||||||
var noteobj = objects[val[2]];
|
var noteobj = objects[val[2]];
|
||||||
if(!cc) break;
|
if(!cc) {
|
||||||
|
if(options.dense) {
|
||||||
|
if(!out[val[0].r]) out[val[0].r] = [];
|
||||||
|
cc = out[val[0].r][val[0].c] = {t:"z"};
|
||||||
|
} else {
|
||||||
|
cc = out[encode_cell(val[0])] = {t:"z"};
|
||||||
|
}
|
||||||
|
range.e.r = Math.max(range.e.r, val[0].r);
|
||||||
|
range.s.r = Math.min(range.s.r, val[0].r);
|
||||||
|
range.e.c = Math.max(range.e.c, val[0].c);
|
||||||
|
range.s.c = Math.min(range.s.c, val[0].c);
|
||||||
|
}
|
||||||
if(!cc.c) cc.c = [];
|
if(!cc.c) cc.c = [];
|
||||||
cmnt = {a:val[1],t:noteobj.TxO.t};
|
cmnt = {a:val[1],t:noteobj.TxO.t};
|
||||||
cc.c.push(cmnt);
|
cc.c.push(cmnt);
|
||||||
|
Loading…
Reference in New Issue
Block a user