forked from sheetjs/sheetjs
		
	
		
			
				
	
	
		
			54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			54 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /* 18.6 Calculation Chain */
 | |
| function parse_cc_xml(data/*::, name, opts*/)/*:Array<any>*/ {
 | |
| 	var d = [];
 | |
| 	if(!data) return d;
 | |
| 	var i = 1;
 | |
| 	(data.match(tagregex)||[]).forEach(function(x) {
 | |
| 		var y = parsexmltag(x);
 | |
| 		switch(y[0]) {
 | |
| 			case '<?xml': break;
 | |
| 			/* 18.6.2  calcChain CT_CalcChain 1 */
 | |
| 			case '<calcChain': case '<calcChain>': case '</calcChain>': break;
 | |
| 			/* 18.6.1  c CT_CalcCell 1 */
 | |
| 			case '<c': delete y[0]; if(y.i) i = y.i; else y.i = i; d.push(y); break;
 | |
| 		}
 | |
| 	});
 | |
| 	return d;
 | |
| }
 | |
| 
 | |
| //function write_cc_xml(data, opts) { }
 | |
| 
 | |
| /* [MS-XLSB] 2.6.4.1 */
 | |
| function parse_BrtCalcChainItem$(data) {
 | |
| 	var out = {};
 | |
| 	out.i = data.read_shift(4);
 | |
| 	var cell = {};
 | |
| 	cell.r = data.read_shift(4);
 | |
| 	cell.c = data.read_shift(4);
 | |
| 	out.r = encode_cell(cell);
 | |
| 	var flags = data.read_shift(1);
 | |
| 	if(flags & 0x2) out.l = '1';
 | |
| 	if(flags & 0x8) out.a = '1';
 | |
| 	return out;
 | |
| }
 | |
| 
 | |
| /* 18.6 Calculation Chain */
 | |
| function parse_cc_bin(data, name, opts) {
 | |
| 	var out = [];
 | |
| 	var pass = false;
 | |
| 	recordhopper(data, function hopper_cc(val, R_n, RT) {
 | |
| 		switch(RT) {
 | |
| 			case 0x003F: /* 'BrtCalcChainItem$' */
 | |
| 				out.push(val); break;
 | |
| 
 | |
| 			default:
 | |
| 				if((R_n||"").indexOf("Begin") > 0){/* empty */}
 | |
| 				else if((R_n||"").indexOf("End") > 0){/* empty */}
 | |
| 				else if(!pass || opts.WTF) throw new Error("Unexpected record " + RT + " " + R_n);
 | |
| 		}
 | |
| 	});
 | |
| 	return out;
 | |
| }
 | |
| 
 | |
| //function write_cc_bin(data, opts) { }
 |