/* 18.2 Workbook */
var wbnsregex = /<\w+:workbook/;
function parse_wb_xml(data, opts)/*:WorkbookFile*/ {
	if(!data) throw new Error("Could not find file");
	var wb = /*::(*/{ AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, Names:[], xmlns: "" }/*::)*/;
	var pass = false, xmlns = "xmlns";
	var dname = {}, dnstart = 0;
	data.replace(tagregex, function xml_wb(x, idx) {
		var y/*:any*/ = parsexmltag(x);
		switch(strip_ns(y[0])) {
			case '': break;
			/* 18.2.13 fileVersion CT_FileVersion ? */
			case '': case '': break;
			/* 18.2.12 fileSharing CT_FileSharing ? */
			case '': break;
			/* 18.2.28 workbookPr CT_WorkbookPr ? */
			case '':
				WBPropsDef.forEach(function(w) {
					if(y[w[0]] == null) return;
					switch(w[2]) {
						case "bool": wb.WBProps[w[0]] = parsexmlbool(y[w[0]]); break;
						case "int": wb.WBProps[w[0]] = parseInt(y[w[0]], 10); break;
						default: wb.WBProps[w[0]] = y[w[0]];
					}
				});
				if(y.codeName) wb.WBProps.CodeName = utf8read(y.codeName);
				break;
			case '': break;
			/* 18.2.29 workbookProtection CT_WorkbookProtection ? */
			case '': break;
			/* 18.2.1  bookViews CT_BookViews ? */
			case '': case '': break;
			/* 18.2.30   workbookView CT_BookView + */
			case '': delete y[0]; wb.WBView.push(y); break;
			case '': break;
			/* 18.2.20 sheets CT_Sheets 1 */
			case '': case '': break; // aggregate sheet
			/* 18.2.19   sheet CT_Sheet + */
			case '': break;
			/* 18.2.15 functionGroups CT_FunctionGroups ? */
			case '': break;
			/* 18.2.14   functionGroup CT_FunctionGroup + */
			case '': case '': break;
			/* 18.2.8    externalReference CT_ExternalReference + */
			case '': break;
			case '': case '': pass=false; break;
			/* 18.2.5    definedName CT_DefinedName + */
			case '': {
				dname.Ref = unescapexml(utf8read(data.slice(dnstart, idx)));
				wb.Names.push(dname);
			} break;
			case '': break;
			/* 18.2.2  calcPr CT_CalcPr ? */
			case '': delete y[0]; wb.CalcPr = y; break;
			case '': break;
			/* 18.2.16 oleSize CT_OleSize ? (ref required) */
			case '': case '': case '': break;
			/* 18.2.18 pivotCaches CT_PivotCaches ? */
			case '': case '': case '': break;
			/* 18.2.23 smartTagTypes CT_SmartTagTypes ? */
			case '': case '': break;
			/* 18.2.22 smartTagType CT_SmartTagType ? */
			case '': break;
			/* 18.2.11 fileRecoveryPr CT_FileRecoveryPr ? */
			case '': break;
			/* 18.2.26 webPublishObjects CT_WebPublishObjects ? */
			case '': case '': break;
			/* 18.2.25 webPublishObject CT_WebPublishObject ? */
			case '': case '': case '': break;
			/* 18.2.7  ext CT_Extension + */
			case '': pass=false; break;
			/* Others */
			case '': pass=true; break;
			case '': pass=false; break;
			/* TODO */
			case ' 0);
	/* fileVersion */
	/* fileSharing */
	var workbookPr/*:any*/ = ({codeName:"ThisWorkbook"}/*:any*/);
	if(wb.Workbook && wb.Workbook.WBProps) {
		WBPropsDef.forEach(function(x) {
			/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw "unreachable"; */
			if((wb.Workbook.WBProps[x[0]]/*:any*/) == null) return;
			if((wb.Workbook.WBProps[x[0]]/*:any*/) == x[1]) return;
			workbookPr[x[0]] = (wb.Workbook.WBProps[x[0]]/*:any*/);
		});
		/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw "unreachable"; */
		if(wb.Workbook.WBProps.CodeName) { workbookPr.codeName = wb.Workbook.WBProps.CodeName; delete workbookPr.CodeName; }
	}
	o[o.length] = (writextag('workbookPr', null, workbookPr));
	/* workbookProtection */
	var sheets = wb.Workbook && wb.Workbook.Sheets || [];
	var i = 0;
	/* bookViews only written if first worksheet is hidden */
	if(sheets && sheets[0] && !!sheets[0].Hidden) {
		o[o.length] = "";
		for(i = 0; i != wb.SheetNames.length; ++i) {
			if(!sheets[i]) break;
			if(!sheets[i].Hidden) break;
		}
		if(i == wb.SheetNames.length) i = 0;
		o[o.length] = '';
		o[o.length] = "";
	}
	o[o.length] = "";
	for(i = 0; i != wb.SheetNames.length; ++i) {
		var sht = ({name:escapexml(wb.SheetNames[i].slice(0,31))}/*:any*/);
		sht.sheetId = ""+(i+1);
		sht["r:id"] = "rId"+(i+1);
		if(sheets[i]) switch(sheets[i].Hidden) {
			case 1: sht.state = "hidden"; break;
			case 2: sht.state = "veryHidden"; break;
		}
		o[o.length] = (writextag('sheet',null,sht));
	}
	o[o.length] = "";
	/* functionGroups */
	/* externalReferences */
	if(write_names) {
		o[o.length] = "";
		if(wb.Workbook && wb.Workbook.Names) wb.Workbook.Names.forEach(function(n) {
			var d/*:any*/ = {name:n.Name};
			if(n.Comment) d.comment = n.Comment;
			if(n.Sheet != null) d.localSheetId = ""+n.Sheet;
			if(n.Hidden) d.hidden = "1";
			if(!n.Ref) return;
			o[o.length] = writextag('definedName', escapexml(n.Ref), d);
		});
		o[o.length] = "";
	}
	/* calcPr */
	/* oleSize */
	/* customWorkbookViews */
	/* pivotCaches */
	/* smartTagPr */
	/* smartTagTypes */
	/* webPublishing */
	/* fileRecoveryPr */
	/* webPublishObjects */
	/* extLst */
	if(o.length>2){ o[o.length] = ''; o[1]=o[1].replace("/>",">"); }
	return o.join("");
}