{"\"Web pages tagged appropriating and Add-on\"":"steve-tiddlywiki-exploration","$:/.tb/macros/calc":"steve-tiddlywiki-exploration","$:/.tb/modules/startup/hide-sidebar.js":"steve-tiddlywiki-exploration","$:/ControlPanel":"steve-tiddlywiki-exploration","$:/DefaultTiddlers":"steve-tiddlywiki-exploration","$:/Display":"steve-tiddlywiki-exploration","$:/Import":"steve-tiddlywiki-exploration","$:/SiteSubtitle":"steve-tiddlywiki-exploration","$:/SiteTitle":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 1":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 10":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 11":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 12":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 13":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 14":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 15":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 16":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 17":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 18":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 19":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 2":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 20":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 21":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 22":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 23":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 24":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 25":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 26":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 27":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 28":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 29":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 3":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 30":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 31":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 32":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 33":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 34":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 35":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 36":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 37":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 38":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 39":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 4":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 40":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 5":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 6":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 7":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 8":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Field 9":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Row":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Sheet":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Workbook":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/producer-approach":"steve-tiddlywiki-exploration","$:/_ExcelImporter/ImportSpecifiers/producer-type":"steve-tiddlywiki-exploration","$:/_Menu/Home/Configuration/Options":"steve-tiddlywiki-exploration","$:/_TWaddle/Stretch/CSS":"steve-tiddlywiki-exploration","$:/_TWaddle/Stretch/Macro":"steve-tiddlywiki-exploration","$:/_telmiger/ref":"steve-tiddlywiki-exploration","$:/_telmiger/strex":"steve-tiddlywiki-exploration","$:/_telmiger/strex.css":"steve-tiddlywiki-exploration","$:/_telmiger/utils/HashStr.js":"steve-tiddlywiki-exploration","$:/_toggle-editor-toolbar_preview":"steve-tiddlywiki-exploration","$:/_toggle-toolbar-plugin-button":"steve-tiddlywiki-exploration","$:/coltag":"steve-tiddlywiki-exploration","$:/config/AnimationDuration":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/bold":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/clear":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/editor-height":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/excise":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-1":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-2":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-3":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/italic":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/line-width":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/link":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/list-bullet":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/list-number":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/mono-block":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/mono-line":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/more":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/opacity":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/paint":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/picture":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/preview":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/preview-type":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/quote":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/size":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/stamp":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/strikethrough":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/subscript":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/superscript":"steve-tiddlywiki-exploration","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/underline":"steve-tiddlywiki-exploration","$:/config/HideSidebarOnStartup":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/Display":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/close-all":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/control-panel":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/home":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/import":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-tiddler":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/save-wiki":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/theme":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/plugins/tongerner/tiddlersbar/button":"steve-tiddlywiki-exploration","$:/config/PageControlButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"steve-tiddlywiki-exploration","$:/config/Plugins/Disabled/$:/plugins/inmysocks/MathyThing":"steve-tiddlywiki-exploration","$:/config/Plugins/Disabled/$:/plugins/tobibeer/appear":"steve-tiddlywiki-exploration","$:/config/Plugins/Disabled/$:/plugins/tongerner/toolbar":"steve-tiddlywiki-exploration","$:/config/RelinkOnRename":"steve-tiddlywiki-exploration","$:/config/TextEditor/EnableToolbar":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/close-all-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/corrupt-tiddler-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/export-page-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/fold-all-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/full-screen-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/import-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-all-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-open-tiddlers-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-recent-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-untagged-tiddlers-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/more-toolbar-actions":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-journal-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-template-tiddler-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-tiddler-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/palette-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/permaview-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/refresh-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/rename-tags-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/search-delete-tiddlers-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/sidebar-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/storyview-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/tag-handling-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/theme-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/tiddler-manager-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-editortoolbar-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-preview-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-sticky-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/unfold-all-button":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/topmenu/topmenu":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/Draft of '$:/plugins/tongerner/toolbar/sidebar-button'":"steve-tiddlywiki-exploration","$:/config/TopLeftBarButtons/Visibility/end":"steve-tiddlywiki-exploration","$:/config/ViewToolbarButtons/Visibility/$:/plugins/tongerner/tiddlersbar/button":"steve-tiddlywiki-exploration","$:/config/ViewToolbarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"steve-tiddlywiki-exploration","$:/config/WikiParserRules/Inline/wikilink":"steve-tiddlywiki-exploration","$:/config/plugins/tiddlywiki/xlsx-utils/default-import-spec":"steve-tiddlywiki-exploration","$:/core/ui/Buttons/advanced-search":"steve-tiddlywiki-exploration","$:/core/ui/Buttons/home":"steve-tiddlywiki-exploration","$:/core/ui/PageTemplate/topleftbar":"steve-tiddlywiki-exploration","$:/core/ui/TopBar/menu":"steve-tiddlywiki-exploration","$:/core/ui/ViewTemplate/next":"steve-tiddlywiki-exploration","$:/core/ui/ViewTemplate/prev":"steve-tiddlywiki-exploration","$:/core/ui/ViewTemplate/subtitle":"steve-tiddlywiki-exploration","$:/grid-cols":"steve-tiddlywiki-exploration","$:/grid-rows":"steve-tiddlywiki-exploration","$:/inmysocks/Macros/TagGridMacro":"steve-tiddlywiki-exploration","$:/inmysocks/Macros/TagGridMacro/BasicCount":"steve-tiddlywiki-exploration","$:/inmysocks/Macros/TagGridMacro/BasicList":"steve-tiddlywiki-exploration","$:/keytag":"steve-tiddlywiki-exploration","$:/keytag-demo2":"steve-tiddlywiki-exploration","$:/keytag-entered":"steve-tiddlywiki-exploration","$:/keytag-entered-demo2":"steve-tiddlywiki-exploration","$:/keytag-enterred":"steve-tiddlywiki-exploration","$:/keytag-set":"steve-tiddlywiki-exploration","$:/palette":"steve-tiddlywiki-exploration","$:/palettes/Bluish":"steve-tiddlywiki-exploration","$:/plugins/eucaly/popuptagger":"steve-tiddlywiki-exploration","$:/plugins/eucaly/popuptagger/ControlPage":"steve-tiddlywiki-exploration","$:/plugins/eucaly/popuptagger/TagBar":"steve-tiddlywiki-exploration","$:/plugins/eucaly/popuptagger/TagBar 1":"steve-tiddlywiki-exploration","$:/plugins/eucaly/popuptagger/config":"steve-tiddlywiki-exploration","$:/plugins/inmysocks/MathyThing":"steve-tiddlywiki-exploration","$:/plugins/inmysocks/MathyThing/action-increment.js":"steve-tiddlywiki-exploration","$:/plugins/tiddlywiki/xlsx-utils":"steve-tiddlywiki-exploration","$:/plugins/tobibeer/appear":"steve-tiddlywiki-exploration","$:/plugins/tobibeer/appear/styles":"steve-tiddlywiki-exploration","$:/plugins/tobibeer/toc/filter.js":"steve-tiddlywiki-exploration","$:/plugins/tongerner/layout-adjustment":"steve-tiddlywiki-exploration","$:/plugins/tongerner/layout_adjustment":"steve-tiddlywiki-exploration","$:/plugins/tongerner/layout_adjustment/sidebar-top":"steve-tiddlywiki-exploration","$:/plugins/tongerner/layout_adjustment/styles":"steve-tiddlywiki-exploration","$:/plugins/tongerner/tiddlersbar":"steve-tiddlywiki-exploration","$:/plugins/tongerner/tiddlersbar/button":"steve-tiddlywiki-exploration","$:/plugins/tongerner/tiddlersbar/styles":"steve-tiddlywiki-exploration","$:/plugins/tongerner/toolbar":"steve-tiddlywiki-exploration","$:/plugins/tongerner/toolbar/styles":"steve-tiddlywiki-exploration","$:/plugins/tongerner/toolbar/tagging":"steve-tiddlywiki-exploration","$:/plugins/tongerner/topmenu":"steve-tiddlywiki-exploration","$:/plugins/tongerner/topmenu/menu-template":"steve-tiddlywiki-exploration","$:/plugins/tongerner/topmenu/topmenu":"steve-tiddlywiki-exploration","$:/plugins/tongerner/tristate":"steve-tiddlywiki-exploration","$:/plugins/tongerner/uptoolbar":"steve-tiddlywiki-exploration","$:/rowtag":"steve-tiddlywiki-exploration","$:/site-listing-by-attribute/level1":"steve-tiddlywiki-exploration","$:/site-listing-by-attribute/level2":"steve-tiddlywiki-exploration","$:/site-listing-by-attribute/level3":"steve-tiddlywiki-exploration","$:/state/Abstract--1103163209":"steve-tiddlywiki-exploration","$:/state/Abstract--1641178525":"steve-tiddlywiki-exploration","$:/state/Abstract--216232707":"steve-tiddlywiki-exploration","$:/state/Abstract--284034540":"steve-tiddlywiki-exploration","$:/state/Abstract--487894249":"steve-tiddlywiki-exploration","$:/state/Abstract--540094515":"steve-tiddlywiki-exploration","$:/state/Abstract--68536169":"steve-tiddlywiki-exploration","$:/state/Abstract-1301673929":"steve-tiddlywiki-exploration","$:/state/Abstract-1679879544":"steve-tiddlywiki-exploration","$:/state/Abstract-1767006772":"steve-tiddlywiki-exploration","$:/state/Abstract-178419035":"steve-tiddlywiki-exploration","$:/state/Citation--1103163209":"steve-tiddlywiki-exploration","$:/state/Citation--1133582955":"steve-tiddlywiki-exploration","$:/state/Citation--1518436769":"steve-tiddlywiki-exploration","$:/state/Citation--1641178525":"steve-tiddlywiki-exploration","$:/state/Citation--2053240569":"steve-tiddlywiki-exploration","$:/state/Citation--216232707":"steve-tiddlywiki-exploration","$:/state/Citation--284034540":"steve-tiddlywiki-exploration","$:/state/Citation--487894249":"steve-tiddlywiki-exploration","$:/state/Citation--540094515":"steve-tiddlywiki-exploration","$:/state/Citation--68536169":"steve-tiddlywiki-exploration","$:/state/Citation-1278947067":"steve-tiddlywiki-exploration","$:/state/Citation-1301673929":"steve-tiddlywiki-exploration","$:/state/Citation-1679879544":"steve-tiddlywiki-exploration","$:/state/Citation-1767006772":"steve-tiddlywiki-exploration","$:/state/Citation-178419035":"steve-tiddlywiki-exploration","$:/state/Citation-1796769249":"steve-tiddlywiki-exploration","$:/state/Citation-1952226459":"steve-tiddlywiki-exploration","$:/state/Citation-394287553":"steve-tiddlywiki-exploration","$:/state/Citation-784273340":"steve-tiddlywiki-exploration","$:/state/Citation-815572859":"steve-tiddlywiki-exploration","$:/state/Essay 15 Abstract-1278947067":"steve-tiddlywiki-exploration","$:/state/Essay 8 Abstract-1278947067":"steve-tiddlywiki-exploration","$:/state/Latour et al (2012)-379458915":"steve-tiddlywiki-exploration","$:/state/Latour et al (2012)-404455225":"steve-tiddlywiki-exploration","$:/state/More info--1596067385":"steve-tiddlywiki-exploration","$:/state/More info-1272971173":"steve-tiddlywiki-exploration","$:/state/SampleReveal1":"steve-tiddlywiki-exploration","$:/state/SampleReveal2":"steve-tiddlywiki-exploration","$:/state/data analysis--959368941":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/911sites":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row 1":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row 2":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Sheet":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Workbook":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/producer-approach":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/producer-type":"steve-tiddlywiki-exploration","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/web-action":"steve-tiddlywiki-exploration","$:/state/edit/medium":"steve-tiddlywiki-exploration","$:/state/edit/web-action":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/911sites":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row 1":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row 2":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Sheet":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Workbook":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/producer-approach":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/producer-type":"steve-tiddlywiki-exploration","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/web-action":"steve-tiddlywiki-exploration","$:/state/expand/911sites":"steve-tiddlywiki-exploration","$:/state/expand/content-action":"steve-tiddlywiki-exploration","$:/state/expand/medium":"steve-tiddlywiki-exploration","$:/state/expand/web-action":"steve-tiddlywiki-exploration","$:/state/link--1477499117":"steve-tiddlywiki-exploration","$:/state/link-1043321551":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/eucaly/popuptagger":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/inmysocks/MathyThing":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/tobibeer/appear":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/tobibeer/appear--524859434":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/tongerner/layout_adjustment":"steve-tiddlywiki-exploration","$:/state/plugin-info--896887961-$:/plugins/tongerner/topmenu":"steve-tiddlywiki-exploration","$:/state/plugin-info--983554678-$:/plugins/tongerner/tiddlersbar--1574180656":"steve-tiddlywiki-exploration","$:/state/plugin-info-1087676034-$:/themes/tongerner/emphasized--897073260":"steve-tiddlywiki-exploration","$:/state/plugin-info-334910430-$:/core---1812962263":"steve-tiddlywiki-exploration","$:/state/plugin-info-359128298-$:/plugins/tongerner/topmenu---541309856":"steve-tiddlywiki-exploration","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"steve-tiddlywiki-exploration","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/producer-approach":"steve-tiddlywiki-exploration","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/producer-type":"steve-tiddlywiki-exploration","$:/state/popuptagger/EditTags":"steve-tiddlywiki-exploration","$:/state/quine--1434962192":"steve-tiddlywiki-exploration","$:/state/quine--1502880341":"steve-tiddlywiki-exploration","$:/state/quine--672006115":"steve-tiddlywiki-exploration","$:/state/showeditpreview":"steve-tiddlywiki-exploration","$:/state/sidebar":"steve-tiddlywiki-exploration","$:/state/social order--1110802714":"steve-tiddlywiki-exploration","$:/state/social order--971479827":"steve-tiddlywiki-exploration","$:/state/strex_-546171805_-404455225":"steve-tiddlywiki-exploration","$:/state/strex_1415370218_-404455225":"steve-tiddlywiki-exploration","$:/state/strex_654239083_-404455225":"steve-tiddlywiki-exploration","$:/state/strex_70209100_-947816403":"steve-tiddlywiki-exploration","$:/state/strex_777415616_-404455225":"steve-tiddlywiki-exploration","$:/state/strex_error: xuid hashing_--2022463313":"steve-tiddlywiki-exploration","$:/state/strex_error: xuid hashing_-2064420303":"steve-tiddlywiki-exploration","$:/state/strex_error: xuid hashing_-2124116981":"steve-tiddlywiki-exploration","$:/state/tab--1466862881":"steve-tiddlywiki-exploration","$:/state/tab--1498284803":"steve-tiddlywiki-exploration","$:/state/tab--1789422239":"steve-tiddlywiki-exploration","$:/state/tab--1903061147":"steve-tiddlywiki-exploration","$:/state/tab--1963855381":"steve-tiddlywiki-exploration","$:/state/tab--2016259090":"steve-tiddlywiki-exploration","$:/state/tab--2112689675":"steve-tiddlywiki-exploration","$:/state/tab--442292640":"steve-tiddlywiki-exploration","$:/state/tab--86143343":"steve-tiddlywiki-exploration","$:/state/tab-1234747213":"steve-tiddlywiki-exploration","$:/state/tab-1517343957":"steve-tiddlywiki-exploration","$:/state/tab-1749438307":"steve-tiddlywiki-exploration","$:/state/tab-244992490":"steve-tiddlywiki-exploration","$:/state/tab-492244070":"steve-tiddlywiki-exploration","$:/state/tab/moresidebar-401116514":"steve-tiddlywiki-exploration","$:/state/tab/sidebar--1835078512":"steve-tiddlywiki-exploration","$:/state/tab/sidebar--2063883831":"steve-tiddlywiki-exploration","$:/state/tab/sidebar-999205604":"steve-tiddlywiki-exploration","$:/state/tabs/controlpanel/toolbars-1345989671":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents-Demonstrations--1307089991":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents-Demonstrations--2108771229":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents-Resources--1307089991":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents-Resources--2108771229":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents-TiddlyWiki for Scholars Using Web Archives--1307089991":"steve-tiddlywiki-exploration","$:/state/toc/TableOfContents/Demonstrations-Demo 1: Assessing and Presenting Data--2108771229":"steve-tiddlywiki-exploration","$:/status/RequireReloadDueToPluginChange":"steve-tiddlywiki-exploration","$:/status/UserName":"steve-tiddlywiki-exploration","$:/tags/TopLeftBar":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ca-ES":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/cs-CZ":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/da-DK":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-AT":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-CH":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-DE":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/el-GR":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/es-ES":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/fr-FR":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/he-IL":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/hi-IN":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ia-IA":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/it-IT":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ja-JP":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ko-KR":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/nl-NL":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/pa-IN":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/pt-PT":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ru-RU":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/sk-SK":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/sv-SE":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/zh-Hans":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/zh-Hant":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/async":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/bibtex":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/blog":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/browser-sniff":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/cecily":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/classictools":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/codemirror":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/d3":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/evernote":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/filesystem":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/github-fork-ribbon":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/googleanalytics":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/help":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/highlight":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/internals":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/jszip":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/katex":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/markdown":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/mobiledragdrop":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/nodewebkitsaver":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/powered-by-tiddlywiki":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/qrcode":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/railroad":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/savetrail":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/stacked-view":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tahoelafs":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/text-slicer":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tiddlyweb":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tw2parser":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tw5.com-docs":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/twitter":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/xlsx-utils":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/xmldom":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/centralised":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/heavier":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/readonly":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/seamless":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/snowwhite":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/starlight":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/tight":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/tight-heavier":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/vanilla":"steve-tiddlywiki-exploration","$:/temp/RemoteAssetSearch/$:/config/OfficialPluginLibrary":"steve-tiddlywiki-exploration","$:/temp/RenameTags/replace":"steve-tiddlywiki-exploration","$:/temp/RenameTags/search":"steve-tiddlywiki-exploration","$:/temp/ServerConnection/http://tiddlywiki.com/library/v5.1.14/index.html":"steve-tiddlywiki-exploration","$:/temp/advancedsearch":"steve-tiddlywiki-exploration","$:/temp/appear/-126274325/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/911 Blogs To Explore-1477499117/block//process":"steve-tiddlywiki-exploration","$:/temp/appear/911 Blogs To Explore-1477499117/block//task":"steve-tiddlywiki-exploration","$:/temp/appear/A Web page that anyone can write1273324267/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/A Web page that anyone can write1835489822/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.547574563/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.547574563/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/A platform for writing, reading, thinking, teaching, learning-1493198882/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/AZSites LLC.1824238207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Actors and networks are monads404455225/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Actors are defined by networks. Networks are defined by actors.404455225/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on-142613885/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on-357503403/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Add-on72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Advising264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Advocating264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Aerial photo of Ground Zero shows the proximity of St. Paul's Chapel and Trinity Church.547574563/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/After the attacks, the Marine Corps reported an increase in the number of Marines returning to active duty.241852141/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Alternative To? Replacement for?-1493198882/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Appropriating-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Appropriating264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Arab American Journal posted Attorney General's statement regarding Arabs and Muslims-152188601/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Arab American Journal posted Attorney General's statement regarding Arabs and Muslims-152188601/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Articles categorized by source on the Evergreen State College library site.241852141/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/As early as the evening of September 11th, search and rescue dogs were used to search for survivors.-1198580557/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/As early as the evening of September 11th, search and rescue dogs were used to search for survivors.-938289217/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Assisting264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Assisting337508187/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-202087927/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-2041694151/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-2053240569/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.876438085/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Background-426537711/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-1785592531/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-2041694151/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-206484573/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.1272971173/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Branch-142613885/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Branch-357503403/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Branch-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Branch264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Branch337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Branch337508187/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.-1133582955/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.1796769249/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Business-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Business-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Business264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Business337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Business72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//approach":"steve-tiddlywiki-exploration","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//environment":"steve-tiddlywiki-exploration","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//solution":"steve-tiddlywiki-exploration","$:/temp/appear/Charity/Civic337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Dedicated-142613885/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Dedicated-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Dedicated264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Dedicated264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Dedicated72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 1: Assessing and Presenting Data569960871/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 1: Assessing and Presenting Data569960871/block//process":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 1: Producer Actions in the post-September 11 Web Sphere-791301717/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//links":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//process":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//task":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 3: Integrating TiddlyWiki with the ODU Toolkit-69021799/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Demo 3: Using the toolkit with WAIL-1245609497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Descriptions and photos of the missing were posted online.-2053240569/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Descriptions and photos of the missing were posted online.-2053240569/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Digital traces afford navigation through overlapping monads constructed through shared tags404455225/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Dr. Muqtedar Khan published article demanding Muslims step up and not tolerate extemist activity and expand their perspectives.1952226459/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//links":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//process":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//task":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Challenges'413112415/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Challenges'413112415/block//environment":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Challenges'413112415/block//solution":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Demo 1: Assessing and Presenting Data'-1072968491/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Demo 1: Assessing and Presenting Data'-1072968491/block//process":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Demo 1: Producer Actions in the post-September 11 Web Sphere'-2105913825/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Engaging in Web Sphere Analysis using Monadic Thinking'1813779803/block//sphere":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Identify and Define Analysis Tags'388937191/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Identify and Define Analysis Tags'388937191/block//showfields":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Introduction'-914016841/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Reflections on #dmi17'1347795257/block/":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'Situating the Case'-426537711/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'What is TiddlyWiki?'-1502880341/block//free":"steve-tiddlywiki-exploration","$:/temp/appear/Draft of 'What is TiddlyWiki?'-1502880341/block//hypertext":"steve-tiddlywiki-exploration","$:/temp/appear/EduHound creates a ribbon for others to download in support of the USA (patriotism)-202087927/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/EduHound links to sites to help educators with the tragedy-206484573/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/EduHound posts a flag graphic on their website to symbolize patriotism2026642401/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/EduHound provides links to news sites about the events of September 11241852141/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Educational-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Educational72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Embeds the grammar of hypertext in the punctuation of writing1273324267/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Embeds the grammar of hypertext in the punctuation of writing1835489822/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//environment":"steve-tiddlywiki-exploration","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//solution":"steve-tiddlywiki-exploration","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//sphere":"steve-tiddlywiki-exploration","$:/temp/appear/Episcopal St. Paul's Chapel, located yards from Ground Zero, became a haven for rescue workers providing food, supplies, chiropractic services, and more.264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Ethnic-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Filtering-1861790927/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Filtering-31571497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Gallery of patriotic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1122658065/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1122658065/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1518436769/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.815572859/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Government-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Government-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Governor Pataki moved quickly to provide financial assistance to New Yorkers affected by 9/11.-1463103709/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Graphic264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. A quote from Abraham Sofaer from The San Fransico Chronicle article is shown.-1050704581/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Hosting264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Hugh L. Carey of Battery Park City Authority reflects on the events of the past year, thanks supporters, and encourages a return to normalcy.-2041694151/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Hyper211407297/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Hyper947816403/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Identify and Define Analysis Tags-1738796007/block//define":"steve-tiddlywiki-exploration","$:/temp/appear/Identify and Define Analysis Tags-1738796007/block//showfields":"steve-tiddlywiki-exploration","$:/temp/appear/Individual/Volunteer-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Individual/Volunteer264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Individual/Volunteer264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Individual/Volunteer72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Informing264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Interest/Advocacy264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/John Labriola gives a first-hand account of his story.264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.-112022025/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.-112022025/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Jon Anhold hosts a television screen shot of CNN's live coverage of the terrorist attacks.264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Learning Hypertextually-1646321229/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Linking-1861790927/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Linking-31571497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Linking264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Links to resources for those looking to volunteer, donate money, or need assistance.-1198668541/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Links to resources for those looking to volunteer, donate money, or need assistance.-1198668541/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Many New York State security concerns arose after the attack.-206484573/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Memorializing264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Monads are expressed as different ways of navigating through data sets404455225/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Multi-dimensional-1376806676/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Multi-dimensional-2008439413/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Multi-dimensional2037981064/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/NYS Emergency Management Office posted links to relevant third-party sites for further information and assistance.-1403528797/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/NYS Emergency Management office posted recovery assistance resources for public assistance workers.394287553/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/On her official homepage, Senator Hillary Rodham Clinton made useful information available to those who wished to assist others after the tragedy.-1081632013/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/On her official website, Senator Hillary Rodham Clinton posted the text of her statements in Congress commemorating the efforts of New Yorkers who responded to the tragedy.-1081632013/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Online directories and memorials tracked those missing after 9/11.1824238207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Open Source-1493198882/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Photo-142613885/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Photo264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Photos of President Bush and smoke billowing out of the World Trade Centers are part of a collection of images Evergreen State College compiled.264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Practices-1376806676/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Practices2037981064/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Press release from US Commission on Civil Rights-152188601/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Press release from US Commission on Civil Rights-152188601/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Public-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Reading Hypertextually-1646321229/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Reflecting-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Reflecting264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Reflections on #dmi17-2111597877/block/":"steve-tiddlywiki-exploration","$:/temp/appear/Religious-357503403/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Religious-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/Religious337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Reporting-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Reporting264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Research Questions-426537711/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Senator Hillary Rodham Clinton echoed the the sentiment of unity many felt in the days after the tragedy. She voiced her support for the Bush administration's response to September 11, repeating the refrain, \"You are with [us] or you are not.\"-1081632013/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Single Page Application-1493198882/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Site posted links to 3rd party donation sites.264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Sites listed hotline phone numbers in New York City to help find the missing.1824238207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Situating the Case-426537711/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Splash page of the Why Project - a site devoted to art about the attacks.1447210293/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/Splash page of the Why Project - a site devoted to art about the attacks.1447210293/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Tagging-1861790927/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Tagging-31571497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Teaching Hypertextually-1646321229/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Techniques-1376806676/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Techniques2037981064/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Templating-1861790927/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Templating-31571497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Text Hyper Wiki Tiddly211407297/block//fourwords":"steve-tiddlywiki-exploration","$:/temp/appear/Text in this webshot describes the materials and structural system of the Twin Towers. A graphic illustrates a typical floor plan within the building.-724635207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Text in this webshot suggests one possible explantion as to why the supports of the building collapsed after the planes hit the Twin Towers.-724635207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Text211407297/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Text264853545/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Text337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Text947816403/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children shared America's grief after the tragedy.-1520327575/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/The Compassionate Friends chapter in Atlanta, Georgia reaches out to memorialize the victims of 9/11.1986743257/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/The Journal of Arab Students advised Arab students after the September 11 attacks.394287553/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.-202087927/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.-202087927/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/The September 11 Victims' Relief Fund links to stories in the news about itself.241852141/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/The Westboro Baptist Church posted information about its protests in the wake of September 11. The group blamed tolerance of homosexuality for causing the tragedy.-206484573/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/The Women's International League for Peace and Freedom posted contact information to combat discrimination following Septmeber 11.-206484573/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Thinking Hypertextually-1646321229/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/This graphic illustrates what engineers think may have caused the steel structure of the World Trade Center to collapse.-724635207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/This webshot displays a link to an explanation of why the World Trade Center may have collapsed from the perspective of engineers.-724635207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/This webshot displays a portion of the meeting minutes for Battery Park City's Residents Association. Questions are answered about rent for tenants displaced by damage from 9/11, repairs and cleaning of apartments, and when apartments will be ready for occupancy.-2041694151/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.-724635207/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.1447210293/block//citation":"steve-tiddlywiki-exploration","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.1447210293/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Three-D model of Ground Zero with St. Paul's Chapel highlighted.-112022025/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Tiddlers-1493198882/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Tiddly211407297/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Tiddly720385555/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Transcluding-1861790927/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Transcluding-31571497/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Unknown337508187/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/Unknown72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-1434962192/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-1434962192/block//free":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-1434962192/block//hypertext":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-1434962192/block//software":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-672006115/block//challenge":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-672006115/block//free":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-672006115/block//hypertext":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?-672006115/block//software":"steve-tiddlywiki-exploration","$:/temp/appear/What is TiddlyWiki?720385555/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Wiki211407297/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Wiki720385555/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/Witnessing-142613885/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Witnessing264853545/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/Writing Hypertextually-1646321229/block//dataset":"steve-tiddlywiki-exploration","$:/temp/appear/appropriating,-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/appropriating-481949749/block/":"steve-tiddlywiki-exploration","$:/temp/appear/appropriating-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/appropriating337508187/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/appropriating72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/contributing-481949749/block//pink-button":"steve-tiddlywiki-exploration","$:/temp/appear/contributing-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/following-481949749/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/hosting-481949749/block/":"steve-tiddlywiki-exploration","$:/temp/appear/publishing337508187/block//slider-buttons-level2":"steve-tiddlywiki-exploration","$:/temp/appear/publishing72351461/block//slider-buttons":"steve-tiddlywiki-exploration","$:/temp/appear/text337508187/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/xymphora.blogspot.com-468960991/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/appear/xymphora.blogspot.com1718061363/block//slider-buttons-level1":"steve-tiddlywiki-exploration","$:/temp/newtiddler":"steve-tiddlywiki-exploration","$:/temp/search":"steve-tiddlywiki-exploration","$:/theme":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/heavier":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/punch":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/readonly":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/tight-heavier":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/vanilla/metrics/storytop":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/vanilla/options/stickytitles":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/vanilla/settings/backgroundimage":"steve-tiddlywiki-exploration","$:/themes/tiddlywiki/vanilla/sticky":"steve-tiddlywiki-exploration","$:/themes/tongerner/emphasized":"steve-tiddlywiki-exploration","$:/view":"steve-tiddlywiki-exploration",".":"steve-tiddlywiki-exploration","11sep2001wherewereyou.org":"steve-tiddlywiki-exploration","123-MONADS-BJSpdf.pdf":"steve-tiddlywiki-exploration","1mc.blogspot.com":"steve-tiddlywiki-exploration","216.5.68.88":"steve-tiddlywiki-exploration","3-level listing of sites & pages":"steve-tiddlywiki-exploration","4.36.67.70":"steve-tiddlywiki-exploration","45thpeacemakers.de4est.com":"steve-tiddlywiki-exploration","64.156.27.17":"steve-tiddlywiki-exploration","66.40.240.240":"steve-tiddlywiki-exploration","911 Blog Links":"steve-tiddlywiki-exploration","911 Blogs To Explore":"steve-tiddlywiki-exploration","911blog":"steve-tiddlywiki-exploration","911blog templates":"steve-tiddlywiki-exploration","911site template":"steve-tiddlywiki-exploration","911sitenote template":"steve-tiddlywiki-exploration","911sites":"steve-tiddlywiki-exploration","A Web page that anyone can write":"steve-tiddlywiki-exploration","A collection of images gathered on the Terror Hits Home site's splash page.":"steve-tiddlywiki-exploration","A fire truck covered in debris at ground zero.":"steve-tiddlywiki-exploration","A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.":"steve-tiddlywiki-exploration","A list of the released names of the flight attendants who died on American Airlines Flight 11":"steve-tiddlywiki-exploration","A list of the released names of the flight attendants who died on American Airlines Flight 77":"steve-tiddlywiki-exploration","A list of the released names of those passengers who died on American Airlines Flight 11":"steve-tiddlywiki-exploration","A list of the released names of those passengers who died on American Airlines Flight 77":"steve-tiddlywiki-exploration","A new article stating that the attacks weren't just the terrorists' fault, it was our government's too.":"steve-tiddlywiki-exploration","A platform for writing, reading, thinking, teaching, learning":"steve-tiddlywiki-exploration","A priest in California created this banner for the Episcopal Church Center in New York.":"steve-tiddlywiki-exploration","A rector of Parish of Trinity Church writes about how the world has changed and a poignant moment when his colleague rang the bell at St. Paul's Chapel, located at Ground Zero on Friday, September 14, 2001.":"steve-tiddlywiki-exploration","A shot of pedestrians shortly after the attacks among debris from the towers.":"steve-tiddlywiki-exploration","A site hosting photos of the 9/11 attacks.":"steve-tiddlywiki-exploration","A tribute to the rescue workers - a poem over a graphic depicting a firefighter bowing his head with two angels.":"steve-tiddlywiki-exploration","A website showing before and after pictures of World Trade Center displays a photo of the twin towers before the 9/11 attacks.":"steve-tiddlywiki-exploration","AZSites LLC.":"steve-tiddlywiki-exploration","Actors and networks are monads":"steve-tiddlywiki-exploration","Actors are defined by networks. Networks are defined by actors.":"steve-tiddlywiki-exploration","Add metadata fields to be applied to identified objects in entirely new study":"steve-tiddlywiki-exploration","Add-on":"steve-tiddlywiki-exploration","Advising":"steve-tiddlywiki-exploration","Advocating":"steve-tiddlywiki-exploration","Aerial photo of Ground Zero shows the proximity of St. Paul's Chapel and Trinity Church.":"steve-tiddlywiki-exploration","Afghan Women's Mission urges US Goverment to resist military response":"steve-tiddlywiki-exploration","After the U.S. war on terror is declared popularity for Osama Bin Laden increases.":"steve-tiddlywiki-exploration","After the attacks, the Marine Corps reported an increase in the number of Marines returning to active duty.":"steve-tiddlywiki-exploration","Ahlul Bayt Digital Islamic Library Project":"steve-tiddlywiki-exploration","Airwise News":"steve-tiddlywiki-exploration","Airwise News followed developments in airport security, such as the deployment of National Guard troops at the end of September.":"steve-tiddlywiki-exploration","Airwise News published updated flight schedules for major U.S. airlines after the attacks.":"steve-tiddlywiki-exploration","Airwise News reported large layoffs by airlines in the weeks after the attacks.":"steve-tiddlywiki-exploration","Alam, Fareena":"steve-tiddlywiki-exploration","Alternative To? Replacement for?":"steve-tiddlywiki-exploration","American Airlines":"steve-tiddlywiki-exploration","American Airlines dispatches teams to help families of those affected by tragedy":"steve-tiddlywiki-exploration","American Airlines established a separate page with updates related to the terrorist attacks and plane hijackings.":"steve-tiddlywiki-exploration","American Airlines release a partial list of the victims involved in the 9/11 attack":"steve-tiddlywiki-exploration","American: Airlines announced that all airplanes had been accounted for and safe.":"steve-tiddlywiki-exploration","An unknown producer created this page to explain what he suspects about Flight 93. He provides evidence he has found that leads him to believe that the government has not provided the public with the whole story.":"steve-tiddlywiki-exploration","Andrew Horwitz believed that September 11 represented a major shift in American politics.":"steve-tiddlywiki-exploration","Andrew Horwitz recorded in his blog his desire to help others.":"steve-tiddlywiki-exploration","Andrew Horwitz treated the first anniversary of September 11 as a day of reflection on the shock and confusion of the tragedy and what followed.":"steve-tiddlywiki-exploration","Andrew Horwitz witnessed the tragedy firsthand and recorded his disbelief and shock as events unfolded on September 11.":"steve-tiddlywiki-exploration","Andrew Horwitz' blog dedicated a separate page of entries to the disaster at the World Trade Center.":"steve-tiddlywiki-exploration","Andrew Horwitz' blog revealed an interest in learning more about the World Trade Center and how this tragedy could have occurred.":"steve-tiddlywiki-exploration","Anhold, Jon":"steve-tiddlywiki-exploration","Anti-military":"steve-tiddlywiki-exploration","Appropriating":"steve-tiddlywiki-exploration","Arab American Jounal posted article reporting on leaders appealing to people to not lump all Arabs/Muslims with the terrorists and their perspectives.":"steve-tiddlywiki-exploration","Arab American Jounal posted summary of individual rights as provided by the National Lawyer's Guild.":"steve-tiddlywiki-exploration","Arab American Journal posted Attorney General's statement regarding Arabs and Muslims":"steve-tiddlywiki-exploration","Arab American Journal posted prayers for peace from several different religions.":"steve-tiddlywiki-exploration","Arab American Journal posted response to support offered to its community.":"steve-tiddlywiki-exploration","Arab American Journal posts patriotic content":"steve-tiddlywiki-exploration","Arlington National Cemetery":"steve-tiddlywiki-exploration","Articles categorized by source on the Evergreen State College library site.":"steve-tiddlywiki-exploration","Artist posted patriotic images":"steve-tiddlywiki-exploration","As early as the evening of September 11th, search and rescue dogs were used to search for survivors.":"steve-tiddlywiki-exploration","As the war on terror begins overseas, American Muslims face tensions at home.":"steve-tiddlywiki-exploration","Assessment & Presentation of Set of Observed Pages":"steve-tiddlywiki-exploration","Assisting":"steve-tiddlywiki-exploration","At the end of September, the FBI released photos of the 19 hijackers of the four planes that crashed on 9/11.":"steve-tiddlywiki-exploration","BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.":"steve-tiddlywiki-exploration","Background":"steve-tiddlywiki-exploration","Battery Park City":"steve-tiddlywiki-exploration","Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.":"steve-tiddlywiki-exploration","Ben Fritz, one of the three founders of spinsanity, reports on a New York Post editorial board blaming the Clinton administration, and the Monica Lewinsky affair for the 9/11 terrorist attacks.":"steve-tiddlywiki-exploration","Ben Fritz, one of the three founders of spinsanity, reports on a column written by Robert Scheer claiming it to be invalid.":"steve-tiddlywiki-exploration","Ben Fritz, one of the three founders of spinsanity, reports on an article in the Washington Post written by Jim Hoagland that uses victims as a rhetoric shield to make is position more powerful.":"steve-tiddlywiki-exploration","Ben Fritz, one of the three founders of spinsanity, writes an article about the importance of rational thinking after the terrorist attacks.":"steve-tiddlywiki-exploration","Blogger posted various quotes in response to 9/11.":"steve-tiddlywiki-exploration","Bloggers such as Andrew Horwitz reported their feelings of shock and dismay on September 11.":"steve-tiddlywiki-exploration","Both WTC in NYC are hit by planes on 9/11/01":"steve-tiddlywiki-exploration","Branch":"steve-tiddlywiki-exploration","Brendan Nyhan, one of the three founders of spinsanity reports on Andrew Sullivans attack of leftist opponents of the \"war on terrorism\".":"steve-tiddlywiki-exploration","British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.":"steve-tiddlywiki-exploration","Bryan Keefer, one of the three founders of spinsanity, writes about Ann Coulter's positions on profiling, and deportation.":"steve-tiddlywiki-exploration","Bryan Keefer, one of the three founders of spinsanity, writes an article about Michael Kelly's position on American's against the war on terror being pro-terrorist.":"steve-tiddlywiki-exploration","Business":"steve-tiddlywiki-exploration","Catholic University Students held candlelight vigil for victims.":"steve-tiddlywiki-exploration","Catholic University of America":"steve-tiddlywiki-exploration","Charity/Civic":"steve-tiddlywiki-exploration","Christopher Fahey shows photos taken from his roof in time sequence as the smoke became closer and denser.":"steve-tiddlywiki-exploration","Civilian casualities of the war in Afghanistan.":"steve-tiddlywiki-exploration","Columbia Business School":"steve-tiddlywiki-exploration","Commondreams.org reports on prospects for Afghanistan's future":"steve-tiddlywiki-exploration","Compassionate Friends -Atlanta Georgia Area Chapters":"steve-tiddlywiki-exploration","Components":"steve-tiddlywiki-exploration","Condemming":"steve-tiddlywiki-exploration","Connecting with others was an important coping activity after September 11.":"steve-tiddlywiki-exploration","CourtLink Corporation":"steve-tiddlywiki-exploration","Create Cell Tiddlers":"steve-tiddlywiki-exploration","Crediting terrorists by calling a 'crime' a 'war'.":"steve-tiddlywiki-exploration","Crosstab of Objects Sharing Two Characteristics":"steve-tiddlywiki-exploration","Cynthia Malaraan captures images of the planes hitting the World Trade Center from her bedroom window.":"steve-tiddlywiki-exploration","Cynthia Malaraan displays a collection of photos to memorialize the view of the NYC skyline from her bedroom window before the attacks.":"steve-tiddlywiki-exploration","Cynthia Malaraan displays photos of the changed NYC skyline and the 9/11 memorial lights shining into the sky. She also explains how the attacks caused the intent of her website to evolve.":"steve-tiddlywiki-exploration","Cynthia Malaraan explains that her series of paintings are inspired by her memory of the skyline from her bedroom window before the 9/11 attacks.":"steve-tiddlywiki-exploration","Cynthia Malaraan reflects on 9/11 one year later. She displays patriotism and hope with her own painting of the United States flag.":"steve-tiddlywiki-exploration","Cynthia Malaran reflects on 9/11 and how it hurts her to view the many missing persons fliers throughout NYC.":"steve-tiddlywiki-exploration","Data and Analysis Preparation":"steve-tiddlywiki-exploration","David Pawson posted a sarcastic response to an email sent him about the significance of the number eleven.":"steve-tiddlywiki-exploration","David Pawson posted a story mocking the fear of anthrax contamination.":"steve-tiddlywiki-exploration","Debris from the towers after the attack measure over an inch off the ground; papers and even personal belongings are blasted far away from ground zero.":"steve-tiddlywiki-exploration","Dedicated":"steve-tiddlywiki-exploration","Demo 1: Producer Actions in the post-September 11 Web Sphere":"steve-tiddlywiki-exploration","Demo 2: Identifying and analyzing archived Web pages":"steve-tiddlywiki-exploration","Demo 3: Integrating TiddlyWiki with the ODU Toolkit":"steve-tiddlywiki-exploration","Demo 4: Images after September 11":"steve-tiddlywiki-exploration","Demonstrations":"steve-tiddlywiki-exploration","Department of Civil Engineering at The University of Sydney":"steve-tiddlywiki-exploration","Descriptions and photos of the missing were posted online.":"steve-tiddlywiki-exploration","Digital Methods and Monadic Exploration":"steve-tiddlywiki-exploration","Digital Methods and Monadic Thinking":"steve-tiddlywiki-exploration","Digital Text Cycles":"steve-tiddlywiki-exploration","Digital traces afford navigation through overlapping monads constructed through shared tags":"steve-tiddlywiki-exploration","DoughertyWebImages":"steve-tiddlywiki-exploration","DoughertyWebImages template":"steve-tiddlywiki-exploration","Dr. Muqtedar Khan called upon American Muslims to address extremist Islamic philosophies.":"steve-tiddlywiki-exploration","Dr. Muqtedar Khan published a column advocating for unconditional condemnation and political and social unity.":"steve-tiddlywiki-exploration","Dr. Muqtedar Khan published an article explaining relevant details of Muslim theology and issues with the US.":"steve-tiddlywiki-exploration","Dr. Muqtedar Khan published article demanding Muslims step up and not tolerate extemist activity and expand their perspectives.":"steve-tiddlywiki-exploration","Draft of '$:/core/ui/Buttons/home'":"steve-tiddlywiki-exploration","Draft of '$:/core/ui/PageTemplate/pagecontrols'":"steve-tiddlywiki-exploration","Draft of '$:/plugins/eucaly/popuptagger/macros'":"steve-tiddlywiki-exploration","Draft of '$:/plugins/tongerner/toolbar/sidebar-button'":"steve-tiddlywiki-exploration","Draft of '911 Blog Links'":"steve-tiddlywiki-exploration","Draft of 'Digital Methods and Monadic Thinking' by steve":"steve-tiddlywiki-exploration","Draft of 'Emphasized theme'":"steve-tiddlywiki-exploration","Draft of 'Navigation to Pages Sharing Two Characteristics'":"steve-tiddlywiki-exploration","Draft of 'New Tiddler 1'":"steve-tiddlywiki-exploration","Draft of 'New Tiddler 2'":"steve-tiddlywiki-exploration","Draft of 'Web images after September 11, 2001'":"steve-tiddlywiki-exploration","Draft of 'Web pages tagged Branch and Charity/Civic'":"steve-tiddlywiki-exploration","EduHound":"steve-tiddlywiki-exploration","EduHound creates a ribbon for others to download in support of the USA (patriotism)":"steve-tiddlywiki-exploration","EduHound expresses sympathy for those touched by the events of September 11":"steve-tiddlywiki-exploration","EduHound links to sites to help educators with the tragedy":"steve-tiddlywiki-exploration","EduHound posts a flag graphic on their website to symbolize patriotism":"steve-tiddlywiki-exploration","EduHound provides links to news sites about the events of September 11":"steve-tiddlywiki-exploration","EduHound provides links to sites where someone can lend aid to those affected by the tragedy.":"steve-tiddlywiki-exploration","Education Week":"steve-tiddlywiki-exploration","Educational":"steve-tiddlywiki-exploration","Electronic Privacy Information Center":"steve-tiddlywiki-exploration","Embeds the grammar of hypertext in the punctuation of writing":"steve-tiddlywiki-exploration","Emphasized theme":"steve-tiddlywiki-exploration","Engaging in Web Sphere Analysis using Monadic Thinking":"steve-tiddlywiki-exploration","Epiphany Lutheran Church":"steve-tiddlywiki-exploration","Episcopal St. Paul's Chapel, located yards from Ground Zero, became a haven for rescue workers providing food, supplies, chiropractic services, and more.":"steve-tiddlywiki-exploration","Events of September 11 presented new challenges to teachers nationwide and required creative ways to help students to cope with the tragedy.":"steve-tiddlywiki-exploration","Evergreen State College":"steve-tiddlywiki-exploration","Evergreen State College linked to a photo gallery of the Pentagon attack.":"steve-tiddlywiki-exploration","Evergreen State College linked to the Department of Defense's Casualty Update reports.":"steve-tiddlywiki-exploration","Explaining":"steve-tiddlywiki-exploration","Fahey, Christopher":"steve-tiddlywiki-exploration","Fareena Alam, a British Muslim journalist, expressed her reaction to the attacks in an interview with Newsweek.":"steve-tiddlywiki-exploration","Fareena Alam, a British Muslim journalist, suggested that the world not jump to the conclusion that Muslims were responsible for 9/11.":"steve-tiddlywiki-exploration","Filtering":"steve-tiddlywiki-exploration","Fire fighters walk through all the dust, building materials, and debris which cover everything surrounding the twin towers after the attack.":"steve-tiddlywiki-exploration","Foot_Schneider.pdf":"steve-tiddlywiki-exploration","For the Westboro Baptist Church, the tragedy of September 11 was further evidence supporting their belief that God hates America.":"steve-tiddlywiki-exploration","Four Words":"steve-tiddlywiki-exploration","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the explosions following the impact of the airplanes.":"steve-tiddlywiki-exploration","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the impact of the first plane.":"steve-tiddlywiki-exploration","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the smoldering remains of the World Trade Center at 7 AM the following morning.":"steve-tiddlywiki-exploration","FrontSlide":"steve-tiddlywiki-exploration","Galleries of quilts that were donated to raise money for the Families of Freedom Scholarship Fund. The quilts are categorized as Symbolic, Patriotic, or Spiritual.":"steve-tiddlywiki-exploration","Gallery of patriotic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"steve-tiddlywiki-exploration","Gallery of spiritual quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"steve-tiddlywiki-exploration","Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"steve-tiddlywiki-exploration","Gary Hunt's \"Outpost of Freedom\" believed that the events of September 11 should be understood in relation to instances of government intrusion such as the siege of the Branch Davidians in Waco in 1993.":"steve-tiddlywiki-exploration","Get Started with TiddlyWiki":"steve-tiddlywiki-exploration","Get started with TiddlyWiki":"steve-tiddlywiki-exploration","Government":"steve-tiddlywiki-exploration","Governor Pataki moved quickly to provide financial assistance to New Yorkers affected by 9/11.":"steve-tiddlywiki-exploration","Graphic":"steve-tiddlywiki-exploration","GroundZero was a memorial site built but Native New Yorker, Tony Tonns.":"steve-tiddlywiki-exploration","HERE IS NEW YORK asks for volunteers to help with their image archive.":"steve-tiddlywiki-exploration","HERE IS NEW YORK explains their purpose of selling photographs to benefit children affected by the tragedy.":"steve-tiddlywiki-exploration","HERE IS NEW YORK gives directions for uploading photos.":"steve-tiddlywiki-exploration","HERE IS NEW YORK is established as an exhibition to display photos from the tragedy.":"steve-tiddlywiki-exploration","Haller, John":"steve-tiddlywiki-exploration","HashTag Macro":"steve-tiddlywiki-exploration","HelloThere":"steve-tiddlywiki-exploration","Here is New York":"steve-tiddlywiki-exploration","HillesundTextCycle.pdf":"steve-tiddlywiki-exploration","Hindu Unity":"steve-tiddlywiki-exploration","Hindu Unity warned that the religion of Islam itself, not only fundamentalism, posed a threat.":"steve-tiddlywiki-exploration","Home page of the United Way America is demonstrating ways of helping and a list of major donors to the September 11th Fund.":"steve-tiddlywiki-exploration","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. A quote from Abraham Sofaer from The San Fransico Chronicle article is shown.":"steve-tiddlywiki-exploration","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Shelby Steele (The Wall Street Journal), and Thomas Sowell (The Washington Times) are shown.":"steve-tiddlywiki-exploration","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Steve Johnson (The San Jose Mercury News), and The Baltimore Sun are shown.":"steve-tiddlywiki-exploration","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Thomas Sowell (The Washington Times), and Marc Sandalow (The San Francisco Chronicle) are shown.":"steve-tiddlywiki-exploration","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Susan Sward, Elizabeth Fernandez, and Bill Wallace (The San Francisco Chronicle), as well as Ronald Brownstein (The Los Angeles Times) are shown.":"steve-tiddlywiki-exploration","Hoover Institution on War, Revolution and Peace":"steve-tiddlywiki-exploration","Horwitz, Andrew":"steve-tiddlywiki-exploration","Hosting":"steve-tiddlywiki-exploration","Hugh L. Carey of Battery Park City Authority reflects on the events of the past year, thanks supporters, and encourages a return to normalcy.":"steve-tiddlywiki-exploration","Hunt, Gary":"steve-tiddlywiki-exploration","Hyper":"steve-tiddlywiki-exploration","Iconic image of fallen towers posted at entrance to website.":"steve-tiddlywiki-exploration","Identify and Define Analysis Tags":"steve-tiddlywiki-exploration","Images of September 11 on the Web":"steve-tiddlywiki-exploration","ImportedRows":"steve-tiddlywiki-exploration","In response to superstition about the significance of the number eleven, David Pawson posted a widely circulated sarcastic piece.":"steve-tiddlywiki-exploration","In the days after September 11 the NY.com site hosted a list of possible missing persons from the World Trade Center. It relied on visitor participation to update information.":"steve-tiddlywiki-exploration","In the days following September 11 the NY.com site created a list of the missing at the World Trade Center to help people find each other.":"steve-tiddlywiki-exploration","In the days following the attack, the Westboro Baptist Church was among those who interpreted events in line with their beliefs.":"steve-tiddlywiki-exploration","In this new article a columnist writes the attacks of 9/11 are crimes, not grounds for war.":"steve-tiddlywiki-exploration","In this webshot the producer discusses the evidence that leads him to believe that the military was involved in bringing down Flight 93.":"steve-tiddlywiki-exploration","In this webshot, the producer discusses the probability that a bomb exploded on Flight 93.":"steve-tiddlywiki-exploration","In this webshot, the producer discusses the probability that the passengers of Flight 93 worked together to overpower the terrorists.":"steve-tiddlywiki-exploration","Individual/Volunteer":"steve-tiddlywiki-exploration","Informing":"steve-tiddlywiki-exploration","Jessamyn West was among those whose flight was grounded after September 11.":"steve-tiddlywiki-exploration","Jewish Family & Life Media Inc.":"steve-tiddlywiki-exploration","JewzNewz.com suggests in their \"Take Action\" section, that every Jewish home have a Yahreit candle burning memorializing the loss of life during the 9/11 attacks.":"steve-tiddlywiki-exploration","Joe Sobran is blaming the United State's foreign policy for the attacks and hopes for peace. Sobran is thankful Al Gore wasn't our president.":"steve-tiddlywiki-exploration","Joe Sobran responded to angry emails he received about his columns.":"steve-tiddlywiki-exploration","John Haller created WorldTradeCenterAftermath.com as a central resource for emergency , victim assistance, and donations contact information.":"steve-tiddlywiki-exploration","John Labriola gives a first-hand account of his story.":"steve-tiddlywiki-exploration","John Labriola links to the red cross for help":"steve-tiddlywiki-exploration","John Labriola provides a quote from The Art of Happiness written by the Dalai Lama.":"steve-tiddlywiki-exploration","Jon Anhold creates a website to collect eyewitness photos, provide a guestbook to upload sentiments, and links to organizations that need monetary support.":"steve-tiddlywiki-exploration","Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.":"steve-tiddlywiki-exploration","Jon Anhold hosts a photographic of the second plane about to collide with the World Trade Center.":"steve-tiddlywiki-exploration","Jon Anhold hosts a picture of the Anchorage Daily News front page for 9/11/2001.":"steve-tiddlywiki-exploration","Jon Anhold hosts a television screen shot of CNN's live coverage of the terrorist attacks.":"steve-tiddlywiki-exploration","Journal of Arab Students":"steve-tiddlywiki-exploration","Kendall Clark report on how Bush will use US Code Title 10 to move swiftly on the war against terrorism":"steve-tiddlywiki-exploration","Key challenges for scholars working with archived web pages":"steve-tiddlywiki-exploration","Khan, Muqtedar":"steve-tiddlywiki-exploration","King, Cory R":"steve-tiddlywiki-exploration","Kolb2009OtherSpaces":"steve-tiddlywiki-exploration","Labriola, John":"steve-tiddlywiki-exploration","Layout adjustment plugin":"steve-tiddlywiki-exploration","Learning Hypertextually":"steve-tiddlywiki-exploration","Librarian Jessamyn West's blog dealt with September 11 by linking to resources, especially those library and information-gathering themed.":"steve-tiddlywiki-exploration","Librarian Jessamyn West's blog linked to resources and other sites' perspectives on the tragedy.":"steve-tiddlywiki-exploration","Linking":"steve-tiddlywiki-exploration","Links to resources for those looking to volunteer, donate money, or need assistance.":"steve-tiddlywiki-exploration","Live":"steve-tiddlywiki-exploration","Lonely Planet":"steve-tiddlywiki-exploration","MIT Community reacts to 9/11 events by publishing links to resources to help fundraise, volunteer, or participate in discusion board.":"steve-tiddlywiki-exploration","MIT builds replica of World Trade Center wall for community to honor and memorialize victims with flowers or to take time to reflect on 9/11 tragedy.":"steve-tiddlywiki-exploration","MIT community reacts to 9/11 events by creating a linked page of resources and scheduled activities.":"steve-tiddlywiki-exploration","Malaraan, Cynthia":"steve-tiddlywiki-exploration","Many New York State security concerns arose after the attack.":"steve-tiddlywiki-exploration","Many organization offered help and support to students, parents and teachers.":"steve-tiddlywiki-exploration","Many photos of the attack, taken from various sources, were published online.":"steve-tiddlywiki-exploration","Massachusetts Institute of Technology":"steve-tiddlywiki-exploration","Masterclass":"steve-tiddlywiki-exploration","Memorial page from the Arab American Journal":"steve-tiddlywiki-exploration","Memorial site posted collection of links to similar sites.":"steve-tiddlywiki-exploration","Memorializing":"steve-tiddlywiki-exploration","Message of sympathy and response by American Airlines.":"steve-tiddlywiki-exploration","Monachos":"steve-tiddlywiki-exploration","Monachos is providing links to prayers and hymns to help people cope with the tragedy.":"steve-tiddlywiki-exploration","Monachos.net offers Orthodox responses to the attacks, including prayers and hymns.":"steve-tiddlywiki-exploration","Monadic Exploration":"steve-tiddlywiki-exploration","Monads are expressed as different ways of navigating through data sets":"steve-tiddlywiki-exploration","Mosque invited non-Muslims to attend lecture.":"steve-tiddlywiki-exploration","Multi-dimensional":"steve-tiddlywiki-exploration","NY.com":"steve-tiddlywiki-exploration","NYCstories.com":"steve-tiddlywiki-exploration","NYS Emergency Management Office":"steve-tiddlywiki-exploration","NYS Emergency Management Office posted links to relevant third-party sites for further information and assistance.":"steve-tiddlywiki-exploration","NYS Emergency Management office posted recovery assistance resources for public assistance workers.":"steve-tiddlywiki-exploration","NYS Emergency Management site posted initial statement from Govenor Pataki regarding the World Trade Center attack.":"steve-tiddlywiki-exploration","NYS Emergency Management site posted relevant phone numbers.":"steve-tiddlywiki-exploration","National Underwriter Company":"steve-tiddlywiki-exploration","Nausea Manifesto":"steve-tiddlywiki-exploration","New Tiddler":"steve-tiddlywiki-exploration","New York State Division of Military and Naval Affairs":"steve-tiddlywiki-exploration","New York State continued to issue security alerts weeks after the attacks.":"steve-tiddlywiki-exploration","New York World Trade Center Memorial":"steve-tiddlywiki-exploration","New York World Trade Center Memorial displaying patriotic imagery and links to news and the Salvation Army's Crisis website.":"steve-tiddlywiki-exploration","New York World Trade Center Memorial is providing links to other memorial websites.":"steve-tiddlywiki-exploration","News article reacting to President George W. Bush's national address after 9/11.":"steve-tiddlywiki-exploration","O'Brien, Heather Anne Davis":"steve-tiddlywiki-exploration","OCRT encourages assistance in the form of donations to the September 11th Fund by United Way.":"steve-tiddlywiki-exploration","OCRT encourages religious tolerance and condemns the actions of those responsible for the attack.":"steve-tiddlywiki-exploration","Object-oriented Historiography":"steve-tiddlywiki-exploration","On September 11th, Airwise News reported that the Federal Aviation Administration had halted operations at U.S. airports.":"steve-tiddlywiki-exploration","On September 21, Airwise News reported a $15 billion government compensation plan to bolster the airlines and offer some liability protection.":"steve-tiddlywiki-exploration","On her official homepage, Senator Hillary Rodham Clinton made useful information available to those who wished to assist others after the tragedy.":"steve-tiddlywiki-exploration","On her official website, Senator Hillary Rodham Clinton posted the text of her statements in Congress commemorating the efforts of New Yorkers who responded to the tragedy.":"steve-tiddlywiki-exploration","On the first anniversary of September 11 Andrew Horwitz reflected on his sense of gratitude for being alive, for sharing stories with others.":"steve-tiddlywiki-exploration","Online directories and memorials tracked those missing after 9/11.":"steve-tiddlywiki-exploration","Ontario Consultants on Religious Tolerance":"steve-tiddlywiki-exploration","Open Source":"steve-tiddlywiki-exploration","Outline":"steve-tiddlywiki-exploration","Pataki posted messages of support from iloveny.com on site.":"steve-tiddlywiki-exploration","Patriotic and memorial graphics were published for visitors to upload to their own sites.":"steve-tiddlywiki-exploration","Pawson, David":"steve-tiddlywiki-exploration","People's Poetry Gathering":"steve-tiddlywiki-exploration","People's Poetry Gathering hosts a collection of poetry about the 9/11 tragedy and supplies upload links for contributors.":"steve-tiddlywiki-exploration","Personal blog reflecting on events":"steve-tiddlywiki-exploration","Pet owners were sometimes able to return to their homes in closed areas downtown to rescue their animals.":"steve-tiddlywiki-exploration","Photo":"steve-tiddlywiki-exploration","Photo of St. Paul's Chapel with firefighters gathering in the debris. Note: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"steve-tiddlywiki-exploration","Photo of demonstration":"steve-tiddlywiki-exploration","Photo showing Trinity Church in the foreground and the World Trade Center in the background.\nNote: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"steve-tiddlywiki-exploration","Photo showing the collapse of the South Tower from a nearby building. Note: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"steve-tiddlywiki-exploration","Photographer Sara Schwittek captures images of fliers requesting blood, information, and supplies.":"steve-tiddlywiki-exploration","Photographer Sara Schwittek captures images of patriotism and remembrance.":"steve-tiddlywiki-exploration","Photographer's pictures witnessing the first plane crashing into the towers.":"steve-tiddlywiki-exploration","Photos of President Bush and smoke billowing out of the World Trade Centers are part of a collection of images Evergreen State College compiled.":"steve-tiddlywiki-exploration","Pipes, Daniel":"steve-tiddlywiki-exploration","Poll illustrates opinion of around the world in/out of favor with a trial or a counter attack.":"steve-tiddlywiki-exploration","Popup Tagger Tiddler":"steve-tiddlywiki-exploration","Practices":"steve-tiddlywiki-exploration","Present":"steve-tiddlywiki-exploration","President George W. Bush's speech makes good points about the 'enemy' shortly before declaring a war.":"steve-tiddlywiki-exploration","Press release from US Commission on Civil Rights":"steve-tiddlywiki-exploration","Principles of monadic thinking":"steve-tiddlywiki-exploration","Producer":"steve-tiddlywiki-exploration","Project Pitch":"steve-tiddlywiki-exploration","Prosthetic Monkey":"steve-tiddlywiki-exploration","Public Interest/Advocacy":"steve-tiddlywiki-exploration","Published photos honoring those who served as first responders.":"steve-tiddlywiki-exploration","Publishing":"steve-tiddlywiki-exploration","Quilt4America":"steve-tiddlywiki-exploration","Quilt4America publishes an idea to help memorialize victims by creating quilts designed by the American public. Quilts are then given to families in honor of their loved ones.":"steve-tiddlywiki-exploration","Quilts.com raises funds for victims of the tragedy.":"steve-tiddlywiki-exploration","Rayhawk.com":"steve-tiddlywiki-exploration","Reading Hypertextually":"steve-tiddlywiki-exploration","Readings":"steve-tiddlywiki-exploration","Readings template":"steve-tiddlywiki-exploration","Reflecting":"steve-tiddlywiki-exploration","Reflections on #dmi17":"steve-tiddlywiki-exploration","Religious":"steve-tiddlywiki-exploration","RenameTags":"steve-tiddlywiki-exploration","Reporting":"steve-tiddlywiki-exploration","Research Question 1":"steve-tiddlywiki-exploration","Research Question 2":"steve-tiddlywiki-exploration","Research Question 3":"steve-tiddlywiki-exploration","Research Question 4":"steve-tiddlywiki-exploration","Research Question 5":"steve-tiddlywiki-exploration","Research Question 6":"steve-tiddlywiki-exploration","Research Questions":"steve-tiddlywiki-exploration","Resources":"steve-tiddlywiki-exploration","SEE/Afghan Women's Mission":"steve-tiddlywiki-exploration","Schwittek, Sara":"steve-tiddlywiki-exploration","Senator Hillary Rodham Clinton":"steve-tiddlywiki-exploration","Senator Hillary Rodham Clinton echoed the the sentiment of unity many felt in the days after the tragedy. She voiced her support for the Bush administration's response to September 11, repeating the refrain, \"You are with [us] or you are not.\"":"steve-tiddlywiki-exploration","Senator Hillary Rodham Clinton's official webpage displayed numerous links, phone numbers, and other useful information for finding loved ones or assisting recovery after the tragedy.":"steve-tiddlywiki-exploration","September 11th Victims' Relief Fund":"steve-tiddlywiki-exploration","September11":"steve-tiddlywiki-exploration","Simultaneous declarations of war by President George W. Bush and Osama bin Laden.":"steve-tiddlywiki-exploration","Single Page Application":"steve-tiddlywiki-exploration","Sit posted feed from webcam aimed at Ground Zero.":"steve-tiddlywiki-exploration","Site Listings by Attribute":"steve-tiddlywiki-exploration","Site Listings by Attribute 1":"steve-tiddlywiki-exploration","Site chronologically listing the events that transpired on September 11, 2001.":"steve-tiddlywiki-exploration","Site featured images of missing persons with associated contact information.":"steve-tiddlywiki-exploration","Site posted links to 3rd party donation sites.":"steve-tiddlywiki-exploration","Site posted various links to 911 missing person resources.":"steve-tiddlywiki-exploration","Sites linked to patriotic music and information about the American flag.":"steve-tiddlywiki-exploration","Sites listed hotline phone numbers in New York City to help find the missing.":"steve-tiddlywiki-exploration","Sites posted photos of victims.":"steve-tiddlywiki-exploration","Sites such as Gary Hunt's \"Outpost of Freedom\" argued that September 11 was the consequence of the United States' actions throughout the world.":"steve-tiddlywiki-exploration","Situating the Case":"steve-tiddlywiki-exploration","Slide1":"steve-tiddlywiki-exploration","SlideShowMacros":"steve-tiddlywiki-exploration","Slideshows":"steve-tiddlywiki-exploration","Snark":"steve-tiddlywiki-exploration","Sobran, Joe":"steve-tiddlywiki-exploration","Soon after the attack, Senator Hillary Clinton's webpage posted messages of condolence that likened the tragedy to the surprise attack at Pearl Harbor.":"steve-tiddlywiki-exploration","Splash page of the New York World Trade Center Memorial. Visitors are encouraged to leave messages for the victims family and friends.":"steve-tiddlywiki-exploration","Splash page of the Why Project - a site devoted to art about the attacks.":"steve-tiddlywiki-exploration","St. Paul's Chapel spawns a new congregation as rescue workers seek nourishment - both physical and spiritual.":"steve-tiddlywiki-exploration","Stott, Reid":"steve-tiddlywiki-exploration","Strategic Forecasting LLC":"steve-tiddlywiki-exploration","Stray animals around the World Trade Center site were rescued by the AnimalAid program, established by United Animal Nations.":"steve-tiddlywiki-exploration","Symbols often speaks more than words. United In Memory: 11 September 2001 symbol represents many efforts directed to remember and reflect on the events that happened on 9/11/01.":"steve-tiddlywiki-exploration","Syndicated columnist, Joe Sobran, writes about how the terrorist attacks were a reaction to US foreign policy.":"steve-tiddlywiki-exploration","Table Attributes":"steve-tiddlywiki-exploration","TableTiddlers Template":"steve-tiddlywiki-exploration","Tagging":"steve-tiddlywiki-exploration","Teachers respond to tragic events trying to provide their care to children and ensure safety":"steve-tiddlywiki-exploration","Teaching Hypertextually":"steve-tiddlywiki-exploration","Techniques":"steve-tiddlywiki-exploration","Templating":"steve-tiddlywiki-exploration","Terror Hits Home":"steve-tiddlywiki-exploration","Text":"steve-tiddlywiki-exploration","Text Hyper Wiki Tiddly":"steve-tiddlywiki-exploration","Text in this webshot describes the materials and structural system of the Twin Towers. A graphic illustrates a typical floor plan within the building.":"steve-tiddlywiki-exploration","Text in this webshot suggests one possible explantion as to why the supports of the building collapsed after the planes hit the Twin Towers.":"steve-tiddlywiki-exploration","TextStretch":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project answered questions about Islam and terror, and demonstrated that the attacks of September 11 were un-Islamic.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project condemned the terrorist attacks as un-Islamic, citing the Quran to support its contention.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project displayed the sentiment of former President George H.W. Bush condemning anti-Muslim and anti-Arab prejudice.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project provided links to text and images demonstrating that terrorism is un-Islamic and showing the sympathy that Muslims throughout the world felt for America's loss.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children grieved for America after September 11.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children shared America's grief after the tragedy.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed how Palestinians grieved for America after September 11.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed images of Palestinians grieving for America after September 11.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed images of unity between Muslims and Americans.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project showed the ways Muslims around the world grieved for America after September 11.":"steve-tiddlywiki-exploration","The Ahlul Bayt Digital Islamic Library Project, a site devoted to teaching visitors about Islam, published its response to the tragedy on a separate set of pages.":"steve-tiddlywiki-exploration","The British Muslim Fareena Alam posted a Department of State chart showing that in 1997, Latin America, not the Middle East, was responsible for most global terrorism against the U.S.":"steve-tiddlywiki-exploration","The British Muslim Fareena Alam re-published many articles on her website questioning who was really responsible for the attacks.":"steve-tiddlywiki-exploration","The Catholic University of America hosted a lecture about Islam.":"steve-tiddlywiki-exploration","The Catholic University of America published the speeches made at their vigil.":"steve-tiddlywiki-exploration","The Catholic University of American sent a letter to parents detailing their response to the Anthrax threat.":"steve-tiddlywiki-exploration","The Chief Executive of American Airlines recorded messages for employees, and the airline posted the text of the messages with a phone number for those who wished to hear the message.":"steve-tiddlywiki-exploration","The Columbia Business School reports that their entire student body, staff, and faculty are safe, and lists a variety of useful information regarding the return to normalcy after the 9/11 attacks.":"steve-tiddlywiki-exploration","The Compassionate Friends chapter in Atlanta, Georgia reaches out to memorialize the victims of 9/11.":"steve-tiddlywiki-exploration","The Compassionate Friends of Atlanta, Georgia appropriate photos showing the workers at Ground Zero":"steve-tiddlywiki-exploration","The Compassionate Friends of Atlanta, Georgia share the front page of a newsletter from another organization.":"steve-tiddlywiki-exploration","The Compassionate Friends of Atlanta, Georgia, displays a flag in solidarity of the tragedy.":"steve-tiddlywiki-exploration","The Compassionate Friends of Atlanta, Georgia, displays a photo combining a crying eagle with the Twin Towers.":"steve-tiddlywiki-exploration","The Department of Justice warned that they would prosecute those who perpetrated false anthrax threats.":"steve-tiddlywiki-exploration","The Department of Justice was responsible for enforcement of the new anti-terrorism legislation passed in the end of October.":"steve-tiddlywiki-exploration","The Episcopal Church":"steve-tiddlywiki-exploration","The Episcopal Church organizes a relief effort for the rescue workers.":"steve-tiddlywiki-exploration","The Episcopal Church posted this video of the Seamen's Church Institute which provided meals, socks, aspirin, shirts, for the rescue workers at Ground Zero hours after the attacks.":"steve-tiddlywiki-exploration","The Episcopal Church responds to the attacks.":"steve-tiddlywiki-exploration","The Families of Freedom Scholarship Fund is raising funds for the children and spouses of the victims.":"steve-tiddlywiki-exploration","The Federal Bureau of Investigation released names of the 19 hijackers of the planes that crashed on 9/11, and requested information through a hotline.":"steve-tiddlywiki-exploration","The Interfaith Alliance posted observations of reactions.":"steve-tiddlywiki-exploration","The Interfaith Alliance urged people to embrace nonviolence, privately and publicly, and organize interfaith vigils.":"steve-tiddlywiki-exploration","The Journal of Arab Students advised Arab students after the September 11 attacks.":"steve-tiddlywiki-exploration","The Journal of Arab Students condemned the attacks on its front page.":"steve-tiddlywiki-exploration","The Journal of Arab Students invited students to attend a memorial for the victims of the September 11 tragedy.":"steve-tiddlywiki-exploration","The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.":"steve-tiddlywiki-exploration","The NY.com site links to survivor lists at the nyc.gov site as well as other useful information for helping survivors and relief.":"steve-tiddlywiki-exploration","The New York State National Guard was mobilized in response to the attack.":"steve-tiddlywiki-exploration","The New York World Trade Center Memorial site providing a memorial message and link to message board.":"steve-tiddlywiki-exploration","The Outpost of Freedom argued that the World Trade Center was the symbol of American world governance and the Pentagon a symbol of the misuse of power.":"steve-tiddlywiki-exploration","The Outpost of Freedom argued that the first responders, firefighters and police, impeded the ability of victims to escape the collapsing World Trade Center.":"steve-tiddlywiki-exploration","The Outpost of Freedom did not believe the United States had the legal authority to retaliate against Osama bin Laden.":"steve-tiddlywiki-exploration","The September 11 Victims' Relief Fund gave an address where aid could be mailed.":"steve-tiddlywiki-exploration","The September 11 Victims' Relief Fund links to stories in the news about itself.":"steve-tiddlywiki-exploration","The September 11th Victims' Relief Fund was established \"to serve the long term needs of the victims.\"":"steve-tiddlywiki-exploration","The Topps Company known for sports cards, creates a line of Enduring Freedom Picture Cards.":"steve-tiddlywiki-exploration","The Trinity Parish, which includes the Trinity Church and St. Paul's chapel, is adjacent to Ground Zero. The church buildings and people were important in assisting the emergency workers.":"steve-tiddlywiki-exploration","The USO is asking for donations so they can support the US Armed Forces.":"steve-tiddlywiki-exploration","The USO is describing the difficulties our troops face with the war on terrorism and how the USO is responding.":"steve-tiddlywiki-exploration","The USO is providing options for people to donate to benefit the troops.":"steve-tiddlywiki-exploration","The USO is providing services to the troops, their families and communities.":"steve-tiddlywiki-exploration","The United Methodist News Service published many online stories about the ways September 11 affected the lives of Methodists, and how Methodists should respond to the tragedy.":"steve-tiddlywiki-exploration","The United States Marine Corps posted a contact number for people to call for information after the tragedy.":"steve-tiddlywiki-exploration","The United Way is offering ways to help, shown here Give to the September 11th Fund.":"steve-tiddlywiki-exploration","The United Way is offering ways to help, shown here Talk to Children and Teens.":"steve-tiddlywiki-exploration","The United Way is offering ways to help, shown here promoting tolerance.":"steve-tiddlywiki-exploration","The United Way is offering ways to help, shown here supporting your local United Way.":"steve-tiddlywiki-exploration","The United Way is offering ways to help, shown here volunteering.":"steve-tiddlywiki-exploration","The United Way's list of major donors to the September 11th Fund and the amount that company has committed to give.":"steve-tiddlywiki-exploration","The Web as an Object of Study":"steve-tiddlywiki-exploration","The Westboro Baptist Church codified its belief that God hated America because of its tolerance for homosexuality in parodies of well-known songs.":"steve-tiddlywiki-exploration","The Westboro Baptist Church posted information about its protests in the wake of September 11. The group blamed tolerance of homosexuality for causing the tragedy.":"steve-tiddlywiki-exploration","The Westboro Baptist Church provided a simple interpretation of events: September 11 happened because God hates America because of its sins.":"steve-tiddlywiki-exploration","The Westboro Baptist Church sought to interpret the tragedy using Biblical verses to support the notion that September 11 was punishment from God.":"steve-tiddlywiki-exploration","The Women's International League for Peace and Freedom asked its members to contact Congresspersons on October 10 to urge peaceful responses to the tragedy.":"steve-tiddlywiki-exploration","The Women's International League for Peace and Freedom posted contact information to combat discrimination following Septmeber 11.":"steve-tiddlywiki-exploration","The Women's International League for Peace and Freedom provided resources to urge leaders to respond peacefully to the tragedy of September 11.":"steve-tiddlywiki-exploration","The Women's International League for Peace and Freedom wrote to President Bush and Congress advocating a nonmilitary response to September 11.":"steve-tiddlywiki-exploration","The Women's International League for Peace and Justice opposed war and racism and promoted the values of freedom for all and peaceful responses to terror.":"steve-tiddlywiki-exploration","The World Trade Center Memorial site published memorial text and images from all over the world.":"steve-tiddlywiki-exploration","The group Hindu Unity accused Pakistan of supporting the attacks.":"steve-tiddlywiki-exploration","The group Hindu Unity compared the actions of Indian Hindus with Pakistani Muslims, suggesting that Hindus supported the United States, while Muslims opposed them.":"steve-tiddlywiki-exploration","The group Hindu Unity condemned Oprah Winfrey for supporting donations to Afghan children, claiming that the children were future terrorists.":"steve-tiddlywiki-exploration","The group Hindu Unity condemned the attacks and warned against the danger of Islam.":"steve-tiddlywiki-exploration","The home page of quilter Carolyn Lee Vehslage highlighting the recent benefit auction for the Families of Freedom Scholarship Fund.":"steve-tiddlywiki-exploration","The site NY.com briefly maintained a list of survivors and missing persons on its pages, but by September 15 had had to remove the list.":"steve-tiddlywiki-exploration","The whole is always smaller than its parts":"steve-tiddlywiki-exploration","There are many forms of grieving and reflecting on difficult, uncomprehending events. Thinking and using thoughts expressed by others may be helpful way of dealing with the tragedy of terrorist attacks.":"steve-tiddlywiki-exploration","There were multiple sites with images of memorial ribbons.":"steve-tiddlywiki-exploration","These photos are part of a collection of images Evergreen State College compiled.":"steve-tiddlywiki-exploration","Thinking Hypertextually":"steve-tiddlywiki-exploration","This graphic illustrates what engineers think may have caused the steel structure of the World Trade Center to collapse.":"steve-tiddlywiki-exploration","This page shares links to a variety of folklore surrounding the 9/11 terrorist attacks.":"steve-tiddlywiki-exploration","This site allows people to submit stories about their own 9/11 experiences.":"steve-tiddlywiki-exploration","This webshot displays United Airlines' first official statement after the occurrence of the attacks on 9/11.":"steve-tiddlywiki-exploration","This webshot displays United Airlines' second official statement only hours after the occurrence of the attacks on 9/11.":"steve-tiddlywiki-exploration","This webshot displays a link to an explanation of why the World Trade Center may have collapsed from the perspective of engineers.":"steve-tiddlywiki-exploration","This webshot displays a portion of the meeting minutes for Battery Park City's Residents Association. Questions are answered about rent for tenants displaced by damage from 9/11, repairs and cleaning of apartments, and when apartments will be ready for occupancy.":"steve-tiddlywiki-exploration","This webshot displays a ten point statement created by the Electronic Privacy of Information Center that urges lawmakers to protect the civil liberties that define the American way of life.":"steve-tiddlywiki-exploration","This webshot displays information regarding the 9/11 crashes and assistance that would be provided to families of victims.":"steve-tiddlywiki-exploration","This webshot displays part of the list of law professors that support the Electronic Privacy Information Center in the protection of freedom.":"steve-tiddlywiki-exploration","This webshot displays part of the list of organizations that support the Electronic Privacy Information Center in the protection of freedom.":"steve-tiddlywiki-exploration","This webshot displays the form that people can fill out to endorse the defense of freedoms in the United States.":"steve-tiddlywiki-exploration","This webshot illustrates that the Electronic Privacy Information Center or EPIC feels that despite recent attacks, Americans should be aware and work to maintain their freedom of privacy.":"steve-tiddlywiki-exploration","This webshot includes stories from eyewitnesses of the Flight 93 crash.":"steve-tiddlywiki-exploration","This webshot introduces Cynthia Malaraan's website which uses imagery and a diary to pay tribute to the changes in NYC caused by the 9/11 attacks.":"steve-tiddlywiki-exploration","This webshot provides general information about the engineering and construction of the Twin Towers.":"steve-tiddlywiki-exploration","Three-D model of Ground Zero with St. Paul's Chapel highlighted.":"steve-tiddlywiki-exploration","Throughout the Fall of 2001, Senator Hillary Rodham Clinton's office actively made information available and assisted relief efforts throughout the various tragedies of September 11, the anthrax scare, and the crash of Flight 587 in Queens, NY.":"steve-tiddlywiki-exploration","Tiddlers":"steve-tiddlywiki-exploration","Tiddly":"steve-tiddlywiki-exploration","TiddlyWiki: A Tool for Monadic Exploration":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 10:10AM-10:48AM":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 10:53AM-12:04PM":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 12:13PM-1:50PM":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 2:00PM-8:45PM":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 8:45AM-9:22AM":"steve-tiddlywiki-exploration","Timeline of events on September 11th, 2001 from 9:22AM-10:08AM":"steve-tiddlywiki-exploration","Tonns, Tony":"steve-tiddlywiki-exploration","Tony Tonns set up Ground Zero to memorialize those who lost their lives.":"steve-tiddlywiki-exploration","Toolbar plugin":"steve-tiddlywiki-exploration","TopTopMenu":"steve-tiddlywiki-exploration","Topps Company, Inc":"steve-tiddlywiki-exploration","Toward the Tabular Text":"steve-tiddlywiki-exploration","Transcluding":"steve-tiddlywiki-exploration","U. S. Department of Justice":"steve-tiddlywiki-exploration","Union United Methodist Church":"steve-tiddlywiki-exploration","United Air Lines, Inc":"steve-tiddlywiki-exploration","United Airlines expresses very limited information regarding the 9/11 attacks. They give their condolences to those affected by the attacks and provide hotlines for those who want more information.":"steve-tiddlywiki-exploration","United Airlines provides links to information about two flights that were involved in 9/11.":"steve-tiddlywiki-exploration","United Animal Nations":"steve-tiddlywiki-exploration","United Animal Nations provided assistance for animals and pet owners affected by the World Trade Center collapse, as well as for search and rescue dogs.":"steve-tiddlywiki-exploration","United Methodist News Service":"steve-tiddlywiki-exploration","United Service Organizations (USO)":"steve-tiddlywiki-exploration","United States Marine Corps":"steve-tiddlywiki-exploration","United Way of America":"steve-tiddlywiki-exploration","United Way's role in the recovery effort and ways to give.":"steve-tiddlywiki-exploration","Unknown,":"steve-tiddlywiki-exploration","Untitled":"steve-tiddlywiki-exploration","Untitled 1":"steve-tiddlywiki-exploration","Uptoolbar plugin":"steve-tiddlywiki-exploration","Varieties of Hypertext":"steve-tiddlywiki-exploration","Viewing Archived Pages in Context":"steve-tiddlywiki-exploration","Visible evidence speaks even more profoundly to reality if the terrorist attacks":"steve-tiddlywiki-exploration","War actions create more damage, instead should we try to capture and prosecute Bin Laden.":"steve-tiddlywiki-exploration","War will come at a cost of our freedom, but isn't the war about preserving our freedom? Paradox.":"steve-tiddlywiki-exploration","Web Campaigning: Web Sphere Analysis":"steve-tiddlywiki-exploration","Web images after September 11, 2001":"steve-tiddlywiki-exploration","Web pages tagged Add-on and Educational":"steve-tiddlywiki-exploration","Web pages tagged Add-on and Government":"steve-tiddlywiki-exploration","Web pages tagged Add-on and Public Interest/Advocacy":"steve-tiddlywiki-exploration","Web pages tagged Add-on and Publishing":"steve-tiddlywiki-exploration","Web pages tagged Appropriating and Photo":"steve-tiddlywiki-exploration","Web pages tagged Branch and Charity/Civic":"steve-tiddlywiki-exploration","Web pages tagged Branch and Educational":"steve-tiddlywiki-exploration","Web pages tagged Branch and Government":"steve-tiddlywiki-exploration","Web pages tagged Branch and Public Interest/Advocacy":"steve-tiddlywiki-exploration","Web pages tagged Business and Add-on":"steve-tiddlywiki-exploration","Web pages tagged Business and Appropriating":"steve-tiddlywiki-exploration","Web pages tagged Business and Assisting":"steve-tiddlywiki-exploration","Web pages tagged Business and Hosting":"steve-tiddlywiki-exploration","Web pages tagged Charity/Civic and Appropriating":"steve-tiddlywiki-exploration","Web pages tagged Dedicated and Business":"steve-tiddlywiki-exploration","Web pages tagged Dedicated and Educational":"steve-tiddlywiki-exploration","Web pages tagged Educational and Branch":"steve-tiddlywiki-exploration","Web pages tagged Educational and Hosting":"steve-tiddlywiki-exploration","Web pages tagged Educational and Publishing":"steve-tiddlywiki-exploration","Web pages tagged Government and Add-on":"steve-tiddlywiki-exploration","Web pages tagged Individual/Volunteer and Appropriating":"steve-tiddlywiki-exploration","Web pages tagged Individual/Volunteer and Hosting":"steve-tiddlywiki-exploration","Web pages tagged Individual/Volunteer and Informing":"steve-tiddlywiki-exploration","Web pages tagged Publishing and Graphic":"steve-tiddlywiki-exploration","Web pages tagged September11 and Anti-military":"steve-tiddlywiki-exploration","Web pages tagged September11 and Snark":"steve-tiddlywiki-exploration","Web-action":"steve-tiddlywiki-exploration","Web-as-Object-of-Study.pdf":"steve-tiddlywiki-exploration","WebArchiveInterface Macros":"steve-tiddlywiki-exploration","Webshot illustrates a producer publishing text condeming terrorism using a religious viewpoint.":"steve-tiddlywiki-exploration","Webshot illustrates a producer publishing text informing how people may join volunteer efforts or contribute to disaster relief fund":"steve-tiddlywiki-exploration","Webshot illustrates a producer publishing text reflecting on the 9/11 tragedy in behalf of the Council of Bishops for The United Methodist Church.":"steve-tiddlywiki-exploration","Webshot shows quotes from various officials reporting on 'hate' crimes around the U.S. after the attacks":"steve-tiddlywiki-exploration","Website display a picture from ground view of the attack on the World Trade Center.":"steve-tiddlywiki-exploration","Website displaying photos of the aftermath of the 9/11 attacks.":"steve-tiddlywiki-exploration","Website displays photos of the second plane approaching and hitting the second tower.":"steve-tiddlywiki-exploration","West, Bob":"steve-tiddlywiki-exploration","West, Jessamyn":"steve-tiddlywiki-exploration","Westboro Baptist Church":"steve-tiddlywiki-exploration","What is TiddlyWiki?":"steve-tiddlywiki-exploration","While there was a high death toll from the attack, does it mean a war is necessary?":"steve-tiddlywiki-exploration","Why Project":"steve-tiddlywiki-exploration","Wiki":"steve-tiddlywiki-exploration","Wiki Notes":"steve-tiddlywiki-exploration","Witnessing":"steve-tiddlywiki-exploration","Women's International League for Peace and Freedom":"steve-tiddlywiki-exploration","World Trade Aftermath site listed missing persons hotlines/phone numbers.":"steve-tiddlywiki-exploration","World Trade Center Memorial":"steve-tiddlywiki-exploration","WorldTradeAftermath.com posted ways to donate and/or volunteer and support.":"steve-tiddlywiki-exploration","Writing Hypertextually":"steve-tiddlywiki-exploration","abc.net.au":"steve-tiddlywiki-exploration","abunimah.org":"steve-tiddlywiki-exploration","acidlogic.com":"steve-tiddlywiki-exploration","afireinside.8m.com":"steve-tiddlywiki-exploration","afterchaos.com":"steve-tiddlywiki-exploration","al-islam.org":"steve-tiddlywiki-exploration","alltheweb.com":"steve-tiddlywiki-exploration","analysis-field template":"steve-tiddlywiki-exploration","angel-art.net":"steve-tiddlywiki-exploration","annie.newdream.net":"steve-tiddlywiki-exploration","appropriating Add-on":"steve-tiddlywiki-exploration","appropriating Branch":"steve-tiddlywiki-exploration","appropriating Dedicated":"steve-tiddlywiki-exploration","appropriating Unknown":"steve-tiddlywiki-exploration","appropriatingAdd-on":"steve-tiddlywiki-exploration","arcurl":"steve-tiddlywiki-exploration","arstechnica.com":"steve-tiddlywiki-exploration","assisting Add-on":"steve-tiddlywiki-exploration","assisting Branch":"steve-tiddlywiki-exploration","assisting Dedicated":"steve-tiddlywiki-exploration","assisting Unknown":"steve-tiddlywiki-exploration","assyria.nineveh.com":"steve-tiddlywiki-exploration","badvogato.org":"steve-tiddlywiki-exploration","bbs.cbsnews.com":"steve-tiddlywiki-exploration","billdrew.net":"steve-tiddlywiki-exploration","blahblahblog":"steve-tiddlywiki-exploration","blog-cells":"steve-tiddlywiki-exploration","blogstalker.blogspot.com":"steve-tiddlywiki-exploration","boards.educationworld.com":"steve-tiddlywiki-exploration","boards.heartlight.org":"steve-tiddlywiki-exploration","bovineamerica.com":"steve-tiddlywiki-exploration","cagle.slate.msn.com":"steve-tiddlywiki-exploration","catholicdirectory.org":"steve-tiddlywiki-exploration","cdr.flavorj.com":"steve-tiddlywiki-exploration","cells":"steve-tiddlywiki-exploration","chat3.suresite.com":"steve-tiddlywiki-exploration","cinchouse.com":"steve-tiddlywiki-exploration","clkoberg.com":"steve-tiddlywiki-exploration","commondreams.org":"steve-tiddlywiki-exploration","community.cnn.com":"steve-tiddlywiki-exploration","content-action":"steve-tiddlywiki-exploration","contributing Add-on":"steve-tiddlywiki-exploration","contributing Branch":"steve-tiddlywiki-exploration","contributing Dedicated":"steve-tiddlywiki-exploration","contributing Unknown":"steve-tiddlywiki-exploration","csoakley.com":"steve-tiddlywiki-exploration","date":"steve-tiddlywiki-exploration","davidgrenier.weblogger.com":"steve-tiddlywiki-exploration","demotag":"steve-tiddlywiki-exploration","discussion.canada.com":"steve-tiddlywiki-exploration","dork2014monadic.pdf":"steve-tiddlywiki-exploration","drifters.net":"steve-tiddlywiki-exploration","drop-d.com":"steve-tiddlywiki-exploration","dump":"steve-tiddlywiki-exploration","eastwest.nu":"steve-tiddlywiki-exploration","emc.elte.hu":"steve-tiddlywiki-exploration","emperors-clothes.com":"steve-tiddlywiki-exploration","end":"steve-tiddlywiki-exploration","english.planetarabia.com":"steve-tiddlywiki-exploration","evilfluffer.blogspot.com":"steve-tiddlywiki-exploration","federalreserve.gov":"steve-tiddlywiki-exploration","following Add-on":"steve-tiddlywiki-exploration","following Branch":"steve-tiddlywiki-exploration","following Dedicated":"steve-tiddlywiki-exploration","following Unknown":"steve-tiddlywiki-exploration","fray.com":"steve-tiddlywiki-exploration","gemm.com":"steve-tiddlywiki-exploration","genehack.org":"steve-tiddlywiki-exploration","geocities.com":"steve-tiddlywiki-exploration","goodnewsaboutgod.com":"steve-tiddlywiki-exploration","home.earthlink.net":"steve-tiddlywiki-exploration","hosting Add-on":"steve-tiddlywiki-exploration","hosting Branch":"steve-tiddlywiki-exploration","hosting Dedicated":"steve-tiddlywiki-exploration","hosting Unknown":"steve-tiddlywiki-exploration","islamic-city.com":"steve-tiddlywiki-exploration","jfg.girlscouts.org":"steve-tiddlywiki-exploration","jish.nu":"steve-tiddlywiki-exploration","justicemail.com":"steve-tiddlywiki-exploration","kottke.org":"steve-tiddlywiki-exploration","lawandeverythingelse.com":"steve-tiddlywiki-exploration","lightacandle.sol.dk":"steve-tiddlywiki-exploration","linking Add-on":"steve-tiddlywiki-exploration","linking Branch":"steve-tiddlywiki-exploration","linking Dedicated":"steve-tiddlywiki-exploration","linking Unknown":"steve-tiddlywiki-exploration","local host wayback page":"steve-tiddlywiki-exploration","manson.exodus.net":"steve-tiddlywiki-exploration","medium":"steve-tiddlywiki-exploration","menic.utexas.edu":"steve-tiddlywiki-exploration","my.webmd.com/roundtable_topic":"steve-tiddlywiki-exploration","mystory.inter.net":"steve-tiddlywiki-exploration","navbar":"steve-tiddlywiki-exploration","ncccusa.org":"steve-tiddlywiki-exploration","nebraskasynod.org":"steve-tiddlywiki-exploration","news.bbc.co.uk":"steve-tiddlywiki-exploration","origurl":"steve-tiddlywiki-exploration","pages.prodigy.net":"steve-tiddlywiki-exploration","papertoys.com":"steve-tiddlywiki-exploration","pew-internet-report.pdf":"steve-tiddlywiki-exploration","producer":"steve-tiddlywiki-exploration","producer-approach":"steve-tiddlywiki-exploration","producer-name":"steve-tiddlywiki-exploration","producer-type":"steve-tiddlywiki-exploration","pub84.ezboard.com":"steve-tiddlywiki-exploration","publishing Add-on":"steve-tiddlywiki-exploration","publishing Branch":"steve-tiddlywiki-exploration","publishing Dedicated":"steve-tiddlywiki-exploration","publishing Unknown":"steve-tiddlywiki-exploration","publishingUnknown":"steve-tiddlywiki-exploration","remember.worldatwar.org":"steve-tiddlywiki-exploration","safe.millennium.berkeley.edu":"steve-tiddlywiki-exploration","scripting.com":"steve-tiddlywiki-exploration","show":"steve-tiddlywiki-exploration","showdox":"steve-tiddlywiki-exploration","specials.msn.com":"steve-tiddlywiki-exploration","spinsanity":"steve-tiddlywiki-exploration","stylesheet":"steve-tiddlywiki-exploration","sunews.syr.edu":"steve-tiddlywiki-exploration","tabletalk.salon.com":"steve-tiddlywiki-exploration","tags":"steve-tiddlywiki-exploration","temp blog post for testing":"steve-tiddlywiki-exploration","terror.joshstorz.com":"steve-tiddlywiki-exploration","thankyou.fast-networks.net":"steve-tiddlywiki-exploration","thegospelzone.com":"steve-tiddlywiki-exploration","thetruereligion.org":"steve-tiddlywiki-exploration","title":"steve-tiddlywiki-exploration","us.geocities.yahoo.com":"steve-tiddlywiki-exploration","vandendorpe15.pdf":"steve-tiddlywiki-exploration","vandendorpe8.pdf":"steve-tiddlywiki-exploration","web-action":"steve-tiddlywiki-exploration","web-campaigning-pp27-35.pdf":"steve-tiddlywiki-exploration","web.mit.edu":"steve-tiddlywiki-exploration","wherewereyou.org":"steve-tiddlywiki-exploration","worldtradeaftermath.com":"steve-tiddlywiki-exploration","wtc.blogspot.com":"steve-tiddlywiki-exploration","wtc.chats.co.il":"steve-tiddlywiki-exploration","ww.blahblahblog.com":"steve-tiddlywiki-exploration","www.99dogs.com":"steve-tiddlywiki-exploration","www.abc.net.au":"steve-tiddlywiki-exploration","www.afghan-network.net":"steve-tiddlywiki-exploration","www.alhewar.com":"steve-tiddlywiki-exploration","www.ambushsite.com":"steve-tiddlywiki-exploration","www.appleseeds.org":"steve-tiddlywiki-exploration","www.arabamerican.com":"steve-tiddlywiki-exploration","www.attackonusa.f2s.com":"steve-tiddlywiki-exploration","www.bettingonamerica.com":"steve-tiddlywiki-exploration","www.broward.org":"steve-tiddlywiki-exploration","www.browardschools.com":"steve-tiddlywiki-exploration","www.cjf.org":"steve-tiddlywiki-exploration","www.deafdate.com":"steve-tiddlywiki-exploration","www.disastercenter.com":"steve-tiddlywiki-exploration","www.edc.org":"steve-tiddlywiki-exploration","www.educateamerica.org":"steve-tiddlywiki-exploration","www.episcopalchurch.org":"steve-tiddlywiki-exploration","www.fourthturning.com":"steve-tiddlywiki-exploration","www.geocities.com/american_freedom_91101/":"steve-tiddlywiki-exploration","www.geocities.com/athnsios":"steve-tiddlywiki-exploration","www.griefnet.org":"steve-tiddlywiki-exploration","www.harbus.org":"steve-tiddlywiki-exploration","www.heartlight.org":"steve-tiddlywiki-exploration","www.hezb-e-islami.org":"steve-tiddlywiki-exploration","www.hinduonnet.com":"steve-tiddlywiki-exploration","www.howard.edu":"steve-tiddlywiki-exploration","www.iuinfo.indiana.edu":"steve-tiddlywiki-exploration","www.javaranch.com":"steve-tiddlywiki-exploration","www.jish.nu":"steve-tiddlywiki-exploration","www.likeanorb.com":"steve-tiddlywiki-exploration","www.middleeastwire.com":"steve-tiddlywiki-exploration","www.nacc.org":"steve-tiddlywiki-exploration","www.newsday.com":"steve-tiddlywiki-exploration","www.newyorkworldtradecentermemorial.com":"steve-tiddlywiki-exploration","www.paul.dube.net":"steve-tiddlywiki-exploration","www.pentagondisaster.com":"steve-tiddlywiki-exploration","www.powerlineblog.com/archives/2017/06/update-and-thoughts-on-the-scalise-shooting.php":"steve-tiddlywiki-exploration","www.poynter.org":"steve-tiddlywiki-exploration","www.ravelly.com":"steve-tiddlywiki-exploration","www.september11news.com":"steve-tiddlywiki-exploration","www.sfsu.edu":"steve-tiddlywiki-exploration","www.siworld.com":"steve-tiddlywiki-exploration","www.specwarnet.com":"steve-tiddlywiki-exploration","www.sun.com":"steve-tiddlywiki-exploration","www.theguestbook.com":"steve-tiddlywiki-exploration","www.thewallsonline.com":"steve-tiddlywiki-exploration","www.virtualmiracles.com":"steve-tiddlywiki-exploration","www.witchvox.com":"steve-tiddlywiki-exploration","www.witchvox.net":"steve-tiddlywiki-exploration","www.worldtradecentermemorial.com":"steve-tiddlywiki-exploration","www.wtcbombings.com":"steve-tiddlywiki-exploration","www.wtchope.org":"steve-tiddlywiki-exploration","www.wtcmemorialquilt.com":"steve-tiddlywiki-exploration","www.zahov1.f2s.com":"steve-tiddlywiki-exploration","www2.arch.ttu.edu":"steve-tiddlywiki-exploration","www2b.abc.net.au":"steve-tiddlywiki-exploration","xymphora.blogspot.com":"steve-tiddlywiki-exploration"}
{"\"Web pages tagged appropriating and Add-on\"":"\"70ff4e4d6ae0750b1736517076c69864\"","$:/.tb/macros/calc":"\"f2f3fa0347685b436fe469493dcdcc2a\"","$:/.tb/modules/startup/hide-sidebar.js":"\"c291ebd71c0a2b8cd9d727e26ab4658f\"","$:/ControlPanel":"\"c9c8e66c4e0ca602b799fa4016ba9439\"","$:/DefaultTiddlers":"\"6b0ecef3b8348462e13e292d6fc05ad8\"","$:/Display":"\"7587ee1abbfb1153bb3a55953d2064dd\"","$:/Import":"\"65615979649a640e518dafff0fe3a671\"","$:/SiteSubtitle":"\"7c484adc7922f7f224f42093d4c2273f\"","$:/SiteTitle":"\"dd37802df8e8f3a7afaacd490205ae86\"","$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"\"54c86f3247732b32b36000b04ac53f7a\"","$:/_ExcelImporter/ImportSpecifiers/Field":"\"2503b7b0c18aaa11e876ef9e2ec7d026\"","$:/_ExcelImporter/ImportSpecifiers/Field 1":"\"77489fd3001578305591d3e0c5e5514d\"","$:/_ExcelImporter/ImportSpecifiers/Field 10":"\"ddba2a4b709c3971a0fb5e4851ebe1e2\"","$:/_ExcelImporter/ImportSpecifiers/Field 11":"\"2ab1a1215853f088957cf42c9dde6a70\"","$:/_ExcelImporter/ImportSpecifiers/Field 12":"\"2200812149f4e3d290f905a39d2dbd75\"","$:/_ExcelImporter/ImportSpecifiers/Field 13":"\"9bf20fa1bfa83423fa3d5a639fda99f3\"","$:/_ExcelImporter/ImportSpecifiers/Field 14":"\"c15dcfa0ff9f914d6ebe00031965f5d8\"","$:/_ExcelImporter/ImportSpecifiers/Field 15":"\"4d982aa54b6a8e6371d32156f722ae74\"","$:/_ExcelImporter/ImportSpecifiers/Field 16":"\"0b83a6c7012aab248f503e0c79f7a25a\"","$:/_ExcelImporter/ImportSpecifiers/Field 17":"\"2d4667388ba34814c5b8f49d68c5621a\"","$:/_ExcelImporter/ImportSpecifiers/Field 18":"\"13ef08c991b545b3b69d7fcb0c7c51c6\"","$:/_ExcelImporter/ImportSpecifiers/Field 19":"\"70aed8031c318e7574af222c5a820f32\"","$:/_ExcelImporter/ImportSpecifiers/Field 2":"\"025596b65f2cd99f8e40c8251f53cd30\"","$:/_ExcelImporter/ImportSpecifiers/Field 20":"\"58f7c2adc38bc15f102a285cf34fe057\"","$:/_ExcelImporter/ImportSpecifiers/Field 21":"\"6bdb3886b584f611d7c2c16b4c730a4a\"","$:/_ExcelImporter/ImportSpecifiers/Field 22":"\"3c904c829e3ed7d25c1089b67e23e3c9\"","$:/_ExcelImporter/ImportSpecifiers/Field 23":"\"820fc621492a0c3a70d86c446cf9bea7\"","$:/_ExcelImporter/ImportSpecifiers/Field 24":"\"a60326bbe7b2203ce7adac6759bbf95d\"","$:/_ExcelImporter/ImportSpecifiers/Field 25":"\"4a68a8fb43c0f88952cae0fde9657381\"","$:/_ExcelImporter/ImportSpecifiers/Field 26":"\"7dca356d758d39534d498311d2b0c4a6\"","$:/_ExcelImporter/ImportSpecifiers/Field 27":"\"1e16bb7b14d07af4bb8c9caa30caf760\"","$:/_ExcelImporter/ImportSpecifiers/Field 28":"\"7fa6d7938cca26a1c77a279e51a7d865\"","$:/_ExcelImporter/ImportSpecifiers/Field 29":"\"768a0df72230ac9682b0229cf010d186\"","$:/_ExcelImporter/ImportSpecifiers/Field 3":"\"8c73687e34824c89daa7fc8852a58e71\"","$:/_ExcelImporter/ImportSpecifiers/Field 30":"\"7435605ed5a9e59935943a7a47a18362\"","$:/_ExcelImporter/ImportSpecifiers/Field 31":"\"df9ca145cd16019f62a7b4f452b4a3aa\"","$:/_ExcelImporter/ImportSpecifiers/Field 32":"\"dbde0625fb662a0c27aba2d744bb275a\"","$:/_ExcelImporter/ImportSpecifiers/Field 33":"\"3b27bba21c6cb3659f06b65a89b83e36\"","$:/_ExcelImporter/ImportSpecifiers/Field 34":"\"d5e63191c8e28edc2915f3f502156983\"","$:/_ExcelImporter/ImportSpecifiers/Field 35":"\"4e018a1d8602e423a2df87e95cefcd93\"","$:/_ExcelImporter/ImportSpecifiers/Field 36":"\"1afef28f164d8baaa27bbedd9d4e6c2d\"","$:/_ExcelImporter/ImportSpecifiers/Field 37":"\"b60ec4d4173c7145b16c097a3fc1e5eb\"","$:/_ExcelImporter/ImportSpecifiers/Field 38":"\"2e35f7f9370591a33e7a739a77e10250\"","$:/_ExcelImporter/ImportSpecifiers/Field 39":"\"f4661937549565cbabe83e426b7cd5d2\"","$:/_ExcelImporter/ImportSpecifiers/Field 4":"\"f1d0e673fcadb51ed362f239c6e91426\"","$:/_ExcelImporter/ImportSpecifiers/Field 40":"\"9af09c0597e856283484b092ddf4bd27\"","$:/_ExcelImporter/ImportSpecifiers/Field 5":"\"a0c426b1a76ef89ef3a17f093ca0f3e0\"","$:/_ExcelImporter/ImportSpecifiers/Field 6":"\"93ef4fe705f62089d08d8f70c3001e61\"","$:/_ExcelImporter/ImportSpecifiers/Field 7":"\"c855dc12dda47ef2d110123da6d9fc2c\"","$:/_ExcelImporter/ImportSpecifiers/Field 8":"\"342bff49511141f3df655f08b49c2907\"","$:/_ExcelImporter/ImportSpecifiers/Field 9":"\"e584583841672fec7f0ccc4b1a81309e\"","$:/_ExcelImporter/ImportSpecifiers/Row":"\"d037a3e032d45386fc646d865a4c45a3\"","$:/_ExcelImporter/ImportSpecifiers/Sheet":"\"520bb9da67336591a45cab6bfdfb6a77\"","$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"\"99f02cfb2faf684ff0b3abb624020e00\"","$:/_ExcelImporter/ImportSpecifiers/Workbook":"\"76f02bdd92bb2230c1ee0953ddd3754d\"","$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"\"931b33617645a76780c2efcf629f4128\"","$:/_ExcelImporter/ImportSpecifiers/producer-approach":"\"280d7c2ef23d690652a38385a8e80d70\"","$:/_ExcelImporter/ImportSpecifiers/producer-type":"\"f4fbc032c9cc0e890941cd648bf1e035\"","$:/_Menu/Home/Configuration/Options":"\"9dd4261cb253bbe945b432ec08f19c72\"","$:/_TWaddle/Stretch/CSS":"\"93083a3ed51afc27e63aec3a81d1e677\"","$:/_TWaddle/Stretch/Macro":"\"b07c42775a930aba4a738b0c014e94e7\"","$:/_telmiger/ref":"\"856d8226f214f6f8c41573230e745dea\"","$:/_telmiger/strex":"\"734b4c501b4815489696f6b389aaa431\"","$:/_telmiger/strex.css":"\"e21da051c87ce1ae6554a18ba823acc8\"","$:/_telmiger/utils/HashStr.js":"\"ce24e1aa12ab6c6641c21cdaad53060a\"","$:/_toggle-editor-toolbar_preview":"\"fc21dd2d209108f95e8ff5cf314cd297\"","$:/_toggle-toolbar-plugin-button":"\"9ccf4a78a0f9b67671fdd903dfb737f3\"","$:/coltag":"\"3c4976f1cebbd0835599dbc1f2e4e6d3\"","$:/config/AnimationDuration":"\"97fcf9b0c7cd0f61246e509d023db4c6\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/bold":"\"65eadc67b10f79a4ae045aa23c42eeef\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/clear":"\"cd83ab03839e736d224697075e68ce3f\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/editor-height":"\"0fc9f17c570267ed1791054bd2ad6e5d\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/excise":"\"4af4422376fa5cd878426225b3146604\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-1":"\"34ed15c6cbf7b33de9a0d57cd3735156\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-2":"\"ba86edfb2b73959cba1bbe59c0e2caa3\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/heading-3":"\"b825ab36c339f33e335891527a6013bf\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/italic":"\"f2dc59da0302fec1f6474cd3887df01c\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/line-width":"\"a73e862ddf1389a3fe125e1d5e84123a\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/link":"\"2d00808b07f6e006f35dce26a4e073bc\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/list-bullet":"\"b72dfb341a59cdc787d3e45436da38e5\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/list-number":"\"95030938d093fd770c9e13e2897db45c\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/mono-block":"\"130921659f9b7cdd06510ff598bf0f82\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/mono-line":"\"4a4518f9dae7b38d6be2f78baf142e18\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/more":"\"52c689d8f03837abe53ccc67ba50a1c7\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/opacity":"\"f70140fd11c8d10fc811bc6aa52bd73c\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/paint":"\"09ef7fc16734ab6f04d0a800985a4ed8\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/picture":"\"0427f8fd247c8dbed93d8b4a90316a9d\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/preview":"\"9ac055bdf24caedbc9840ca29a5122e9\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/preview-type":"\"a5640caeb29b443face065b992c2706b\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/quote":"\"6aba00ecc9e2cad44e2b5b6a48ae4d25\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/size":"\"f530006c39a5368a5f88ad3ec6699a70\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/stamp":"\"173c9caf3b3f293b97f890afd2a70927\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/strikethrough":"\"9fc0b3220a79df8ecd5dc22ba39687c9\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/subscript":"\"9e97d5686e83265b79c4f7eca55456fc\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/superscript":"\"a462b6cfd2d67fba9899bc26d82f0c20\"","$:/config/EditorToolbarButtons/Visibility/$:/core/ui/EditorToolbar/underline":"\"2d25f647e9bf202d13b2c42361307c23\"","$:/config/HideSidebarOnStartup":"\"c5319b0cf42584575e3a85fb4e7d9c10\"","$:/config/PageControlButtons/Visibility/$:/Display":"\"59aabe0a209f41f075bd25ce09bf8897\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/close-all":"\"887084d0262dfd8f8fb592db212edb11\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/control-panel":"\"a8ee604a9ee6a006c89580f5c91820d8\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/home":"\"653631d120629bdd0931b4d7eb1a2ce4\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/import":"\"042e7149a2fbf44286b28d49a7b8caa3\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/new-tiddler":"\"5d03a0893160d11e687e5cbe27098ff7\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/save-wiki":"\"a8d5f95d86c362c74f1d9dcb1605049b\"","$:/config/PageControlButtons/Visibility/$:/core/ui/Buttons/theme":"\"83f93e01289088ea1df540afe29eb92f\"","$:/config/PageControlButtons/Visibility/$:/plugins/tongerner/tiddlersbar/button":"\"356da3497b6daad3fc17aed213328d3e\"","$:/config/PageControlButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"\"86a8cf895d8ec37447ee895af9cdc7d4\"","$:/config/Plugins/Disabled/$:/plugins/inmysocks/MathyThing":"\"fd370a8adb984dfadf0c61237cb313d8\"","$:/config/Plugins/Disabled/$:/plugins/tobibeer/appear":"\"f65aedc497d323eba0a883d0c0953f64\"","$:/config/Plugins/Disabled/$:/plugins/tongerner/toolbar":"\"3c3ab9410c970454b0e35ef41d8d3209\"","$:/config/RelinkOnRename":"\"17722f159efcdb8629731f4bb1f8ca25\"","$:/config/TextEditor/EnableToolbar":"\"c4862b6aa37d92bf3f07d5ad20c1b2d8\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/close-all-button":"\"ab54bcbe743317c0d723ea87b314b46e\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/corrupt-tiddler-button":"\"0fc3755e2408507f013e8d38614f259c\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/export-page-button":"\"53239237d99416e7762f2d0fb72a867f\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/fold-all-button":"\"51a9be3bd6d0395e21fec96e5ce5f9ab\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/full-screen-button":"\"a49ee7245bc45949716ac60c5976ed50\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/import-button":"\"586c5d9f4eb147a7f94f67d61ce93050\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-all-button":"\"f20391ba5c028b241843fdd3b5b043f1\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-open-tiddlers-button":"\"40f648bff307cd46b9243e7183497b88\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-recent-button":"\"bf1ad1a7157cf462e490969fdbbb5a45\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/list-untagged-tiddlers-button":"\"71174e8ec2b8b5c706d51b18a302864b\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/more-toolbar-actions":"\"1d4550cdc52c66a1f44beb5be9bd3a80\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-journal-button":"\"f3661cdcc02b9ab9a45333150a8098f9\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-template-tiddler-button":"\"d3a2927700b4386b0b0bd7fda2b33d96\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/new-tiddler-button":"\"1288a0c15d7710cb9dcc554e858026a4\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/palette-button":"\"294b75c8e4fc9521f0cd3ff88269c671\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/permaview-button":"\"18e639d368acea9fd3f2fe4317cf8b3d\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/refresh-button":"\"474846bb3ede8c4e47ad09b3b2d347d7\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/rename-tags-button":"\"a7b338a57bf9f49d394f6160ddda04ba\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/search-delete-tiddlers-button":"\"35226ec06bc8bcef41652ec55bc99df4\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/sidebar-button":"\"ffe304b18b350e3fb9594bfd577d38d4\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/storyview-button":"\"10f1d2492c2329134d4415038947beb0\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/tag-handling-button":"\"44378711068b23fbcaafcef2b0e01d27\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/theme-button":"\"00579b465c4ade596df4ad65690d6262\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/tiddler-manager-button":"\"2c4e50dc12f6197f849878195d097826\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-editortoolbar-button":"\"71528aeb216f07a0b78fecb58f64cec7\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-preview-button":"\"0158bcae6200fe534c3e2cbaa624fb2d\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-sticky-button":"\"88868bd3a8992de93df29d3034c8cf88\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"\"8e537aa8f7ce3bd27fd7d3a5abd9dc84\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/toolbar/unfold-all-button":"\"82e0df6dc0c5f1f496d360fcd106f8f9\"","$:/config/TopLeftBarButtons/Visibility/$:/plugins/tongerner/topmenu/topmenu":"\"6d9356634873dd62b4ddf7f1c0d5f98e\"","$:/config/TopLeftBarButtons/Visibility/Draft of '$:/plugins/tongerner/toolbar/sidebar-button'":"\"8f2a29e36ac00f9df38e18edf003290c\"","$:/config/TopLeftBarButtons/Visibility/end":"\"41787b77162c6117eae12dc82a771590\"","$:/config/ViewToolbarButtons/Visibility/$:/plugins/tongerner/tiddlersbar/button":"\"efd261108a571221666c45909379185e\"","$:/config/ViewToolbarButtons/Visibility/$:/plugins/tongerner/toolbar/toggle-tagging-button":"\"f4466036bc2e79b9b466d8efcd6b563f\"","$:/config/WikiParserRules/Inline/wikilink":"\"1df241e5058c8a1f7d964ea71d64ab5e\"","$:/config/plugins/tiddlywiki/xlsx-utils/default-import-spec":"\"f375d11482fd0bf45af7b9692130090e\"","$:/core/ui/Buttons/advanced-search":"\"3f88b8d2bd2fb29f4d1211724efd2633\"","$:/core/ui/Buttons/home":"\"61142b57d18d1455cb9d3b753d548424\"","$:/core/ui/PageTemplate/topleftbar":"\"9e8c2f5b95eac96aae9734b69e4d59d2\"","$:/core/ui/TopBar/menu":"\"e265c6716ebff081088f54c62ef3178a\"","$:/core/ui/ViewTemplate/next":"\"bdd200d2d213c306c890ab8a8fddd7b3\"","$:/core/ui/ViewTemplate/prev":"\"b03dae8d8b52d593cd377876fd5ab8a2\"","$:/core/ui/ViewTemplate/subtitle":"\"3b202b237068cd69b8d6003720a22624\"","$:/grid-cols":"\"17b16104cd887266abd0e2db15a74270\"","$:/grid-rows":"\"4735d584881cdff9491f19879d51a559\"","$:/inmysocks/Macros/TagGridMacro":"\"fa6d8d21a56912bdb35a9179b35707e1\"","$:/inmysocks/Macros/TagGridMacro/BasicCount":"\"bf741597a95460223d7060b53834107c\"","$:/inmysocks/Macros/TagGridMacro/BasicList":"\"095c5585a5f0ad01b4d9044ded6e8355\"","$:/keytag":"\"f2eb893fe717c0a3701d4672933d8670\"","$:/keytag-demo2":"\"6d1c94fcab521a6512e8e97ca35f7357\"","$:/keytag-entered":"\"1ad968d80f81424d4bab6b885b454b27\"","$:/keytag-entered-demo2":"\"f083f1f74f739f86a120d4c1f9dd8403\"","$:/keytag-enterred":"\"a221c891392187f7395e40d040169758\"","$:/keytag-set":"\"706c034918eca865c77a6f5b909b0ee3\"","$:/palette":"\"a30af135c2069f874010ebab8fa6d74e\"","$:/palettes/Bluish":"\"fa2b10a7f8c67069fffe85179afa0c3b\"","$:/plugins/eucaly/popuptagger":"\"eabe77b78cd76b5491e39ea8a3d4333a\"","$:/plugins/eucaly/popuptagger/ControlPage":"\"a45ce3811a56bfc01e8fa77cc3793aee\"","$:/plugins/eucaly/popuptagger/TagBar":"\"3a4bd7a0fb1f5e13345feb0324b94050\"","$:/plugins/eucaly/popuptagger/TagBar 1":"\"acef0045ff74b28ca6023cfe7474d637\"","$:/plugins/eucaly/popuptagger/config":"\"92c24aae5f886c708725d0ea40dec64c\"","$:/plugins/inmysocks/MathyThing":"\"2e5afbf3e91acb7805c8ccb87e2cec4d\"","$:/plugins/inmysocks/MathyThing/action-increment.js":"\"bbb374561137b5b9bb45e5a20dcdcb9f\"","$:/plugins/tiddlywiki/xlsx-utils":"\"8d5d9a1831616dce6d5a1beeb643b99b\"","$:/plugins/tobibeer/appear":"\"dea4184cfc8445bf2e3af920488f8807\"","$:/plugins/tobibeer/appear/styles":"\"3bd845c8cc69b3d2806859e0bd424806\"","$:/plugins/tobibeer/toc/filter.js":"\"252766ebaef88599324fe22c84b8180c\"","$:/plugins/tongerner/layout-adjustment":"\"fda1f73edcce268fad624d7c4bec2c1c\"","$:/plugins/tongerner/layout_adjustment":"\"d3404f99ee7769f572049d4e8620eddf\"","$:/plugins/tongerner/layout_adjustment/sidebar-top":"\"e6c1d8dcfef0b9789742ceb1bd2ed394\"","$:/plugins/tongerner/layout_adjustment/styles":"\"cc528b72b4bcace4c2c2b2c71e3c9bc3\"","$:/plugins/tongerner/tiddlersbar":"\"c861efd24969d3947af9b1ac7e15d32e\"","$:/plugins/tongerner/tiddlersbar/button":"\"5e98836067dca0672c4fa20b52118381\"","$:/plugins/tongerner/tiddlersbar/styles":"\"b2cbf0dc06311062b728cd4c7e06f83a\"","$:/plugins/tongerner/toolbar":"\"8a0e03afcb903240fbc113f74e2e0537\"","$:/plugins/tongerner/toolbar/styles":"\"d3bc3a1f6d01b2ec35de41872d7a5faf\"","$:/plugins/tongerner/toolbar/tagging":"\"6ba07159231f2b13819368531d525d65\"","$:/plugins/tongerner/topmenu":"\"34b471c5a55429d0898a64172e51a948\"","$:/plugins/tongerner/topmenu/menu-template":"\"a77e6c001af5b89a07f02e752fd880d6\"","$:/plugins/tongerner/topmenu/topmenu":"\"59b1d9bbe67b767b2942e1962f8b0343\"","$:/plugins/tongerner/tristate":"\"ba693356cdf113b48faf196ad6f3b18b\"","$:/plugins/tongerner/uptoolbar":"\"fd2a4669108f643e2c4e198a03797115\"","$:/rowtag":"\"266a13c3bdc05bd89cc30a3ba0703798\"","$:/site-listing-by-attribute/level1":"\"c3afa284a55f427c9cef7a0358283304\"","$:/site-listing-by-attribute/level2":"\"bdf4ab87b31c5541503437b857a4bf28\"","$:/site-listing-by-attribute/level3":"\"39bd7d9a5e9a166f59832ef22986787d\"","$:/state/Abstract--1103163209":"\"095a3c976781804b43173cdecf7ce55c\"","$:/state/Abstract--1641178525":"\"ec7a58117b2ec4c1cf7877f9e46da983\"","$:/state/Abstract--216232707":"\"f2aea59bd1c77929b4726ed8e2184151\"","$:/state/Abstract--284034540":"\"1dee04ec3c2709b68f1626db9913a8bd\"","$:/state/Abstract--487894249":"\"54ebd9906702fdc14c0e22ece1a64d59\"","$:/state/Abstract--540094515":"\"4ed5484b27529ccf913a456c37848251\"","$:/state/Abstract--68536169":"\"43b5d1f8e77adde5db3408613c32966c\"","$:/state/Abstract-1301673929":"\"0a5fc07778fcdddbdd7c89bc594e7cd1\"","$:/state/Abstract-1679879544":"\"c5a03306223feb19bc54a03a956726e2\"","$:/state/Abstract-1767006772":"\"3e6e5bbc06c72619a8769d9c95c22f31\"","$:/state/Abstract-178419035":"\"1592b024db5c16f8f408c2888164b21b\"","$:/state/Citation--1103163209":"\"826de59a7e9829fb86ff0d57171b7ea0\"","$:/state/Citation--1133582955":"\"c5ab8a44e7aeb7e6fa7bbb8ec062e361\"","$:/state/Citation--1518436769":"\"580aee8fb2354acc0a204b5b09c49bcd\"","$:/state/Citation--1641178525":"\"09c4f2a3b69c1f528932451476369c11\"","$:/state/Citation--2053240569":"\"fb3cfa4ba5fb57b07cef26ef931e5164\"","$:/state/Citation--216232707":"\"0fae142ceb705554231d67a812040461\"","$:/state/Citation--284034540":"\"4af57b479a4f92d601a18bee6d04f8bb\"","$:/state/Citation--487894249":"\"0d168231836c53536e0ee12eb6e1a9d8\"","$:/state/Citation--540094515":"\"ba9dca119a228cfa2d11380951e11549\"","$:/state/Citation--68536169":"\"69a53de711420368831374f355544aa0\"","$:/state/Citation-1278947067":"\"452c9bcc79b6aba6e4cdb3c19d3e1e53\"","$:/state/Citation-1301673929":"\"16817be3b07dc6f2532e495f1c8b9ae1\"","$:/state/Citation-1679879544":"\"dd24a5ae2d9e6b770d3d290bbd016ed9\"","$:/state/Citation-1767006772":"\"0b30c60bdb79d1f86f4b51994f7db48e\"","$:/state/Citation-178419035":"\"a8ea3ef5a3aa81a6ff6919ff57d5e8c1\"","$:/state/Citation-1796769249":"\"f4c1d7199595c7d2d5647c309691b52e\"","$:/state/Citation-1952226459":"\"702a2f114565b1025e43a5b63f3391e6\"","$:/state/Citation-394287553":"\"6259650593099527c8bb4c606dcb4c68\"","$:/state/Citation-784273340":"\"84422fbde303bfc941fa8c5e0405658d\"","$:/state/Citation-815572859":"\"80d626964538a29497f3acda7a319761\"","$:/state/Essay 15 Abstract-1278947067":"\"4f58631bd6d1223da268ebb2a5690022\"","$:/state/Essay 8 Abstract-1278947067":"\"357dec82b11c12e9e482cfae275c03e1\"","$:/state/Latour et al (2012)-379458915":"\"855d179b90fcb9d94fc0f1865f4b7b4d\"","$:/state/Latour et al (2012)-404455225":"\"42ecfe954f6444702b860b0f2131592e\"","$:/state/More info--1596067385":"\"31caa8c74e938eb47ee27a1a79ee3b9c\"","$:/state/More info-1272971173":"\"246365e852e116b5f7ab03ad72f34c64\"","$:/state/SampleReveal1":"\"8ec23cc400539000c391cff7d6a91322\"","$:/state/SampleReveal2":"\"b948913eab82718580ffba8a1404f3d4\"","$:/state/data analysis--959368941":"\"cf925b22433c93823ac9abb65b518a71\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"\"1a973ebd09f978c312ec12e837622b49\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/911sites":"\"e3d13fb17aafd7e01d653292d2215a2e\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row":"\"797ea8d1d35d6d1cee18ec30f00f12b8\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row 1":"\"e8bb3970a0e25b680c12f0e82f5fa158\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Row 2":"\"6709ad2875de09aa15978ca50662bdce\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Sheet":"\"fa0af2936b11dd94af93abc8a712aca0\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"\"20fb5f0feb281b2df3738cc347543e98\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Workbook":"\"082d88f9379b92f0c5d057a93532927b\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"\"fa59c4884a2609017c29ba7aa55764f7\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/producer-approach":"\"bdae106be0d1756b6da10f122f9f6073\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/producer-type":"\"a4ce292b7104acbf95f9e08689dd54de\"","$:/state/edit/$:/_ExcelImporter/ImportSpecifiers/web-action":"\"ebcb735272d26441cb7a3a97185c801b\"","$:/state/edit/medium":"\"79b4a47b9f52833edd2276f68961a121\"","$:/state/edit/web-action":"\"78f71abe5d52430ef9a8a9151a5cf3ca\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"\"4aa0ec193fc60c66cfd3468f8160bf80\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/911sites":"\"22edce8fc71d057b2910f1f8726aa9d8\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row":"\"3cbf8689bca8e8ff1ff31c3fbdbf8455\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row 1":"\"36329734914a023c40efda4cb1f7d47d\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Row 2":"\"0ef206408360eaba81400b7c8e918c78\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Sheet":"\"e1a4ede1163f02a0a6f0a7666a2e954d\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Sheet 1":"\"bd0bfd7bf16a09346c2552d283e6f6c9\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Workbook":"\"3bc394dc7e5948187996f16cea55384d\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/Workbook 1":"\"9ed9e668e3987ea6cd059d9ada1f9388\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/producer-approach":"\"af36d214814a812bf19f38777dfdadb5\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/producer-type":"\"f27042dbae7e1dbc887ab4a899a1baf4\"","$:/state/expand/$:/_ExcelImporter/ImportSpecifiers/web-action":"\"d709311964b0ee1bfa9762d811bc5111\"","$:/state/expand/911sites":"\"51d77921dd99197416f991f3381e90a9\"","$:/state/expand/content-action":"\"ea4d97100a35bce437a1fdd71d5b0f14\"","$:/state/expand/medium":"\"fcde48956a6615c018f4c59ad56002e8\"","$:/state/expand/web-action":"\"048fb59eeeccb745f7dba41782c99f8e\"","$:/state/link--1477499117":"\"442565b2ae74c2ca10bbbb6563fcd8d3\"","$:/state/link-1043321551":"\"2185612af5fed3b86f6b45397807868d\"","$:/state/plugin-info--896887961-$:/plugins/eucaly/popuptagger":"\"79d90f3fc26932dbab806f365b0c93b6\"","$:/state/plugin-info--896887961-$:/plugins/inmysocks/MathyThing":"\"9027cd46946e1d1411093042ee9aeeb3\"","$:/state/plugin-info--896887961-$:/plugins/tobibeer/appear":"\"6876d790e38b20bd6bb8142ab46014b9\"","$:/state/plugin-info--896887961-$:/plugins/tobibeer/appear--524859434":"\"eef0f3dc44a46c58a5eb250bce8ae88d\"","$:/state/plugin-info--896887961-$:/plugins/tongerner/layout_adjustment":"\"5959507f3934297123e472aef1be70ab\"","$:/state/plugin-info--896887961-$:/plugins/tongerner/topmenu":"\"0f1d88d012dbf83dd3778ff88534aa4b\"","$:/state/plugin-info--983554678-$:/plugins/tongerner/tiddlersbar--1574180656":"\"14f2c2b0430ebe5d321fe90bd898192a\"","$:/state/plugin-info-1087676034-$:/themes/tongerner/emphasized--897073260":"\"8fa404009fcff17b82cc77b515cc1af3\"","$:/state/plugin-info-334910430-$:/core---1812962263":"\"59b431f708b07cb5f12a454dfb9d5d53\"","$:/state/plugin-info-359128298-$:/plugins/tongerner/topmenu---541309856":"\"94adc61e6a17640a7d170987663f4eb8\"","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/911sitenotes":"\"29f6c3ea594eff089b472d907731844e\"","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/producer-approach":"\"616e473a6a4dd31202eebae529e24a99\"","$:/state/plugins/tiddlywiki/xlsx-utils/rename-$:/_ExcelImporter/ImportSpecifiers/producer-type":"\"3816144b8d73b26b1235c91440772b84\"","$:/state/popuptagger/EditTags":"\"ecbdd8d7531b2abb53cd77f65082e921\"","$:/state/quine--1434962192":"\"d2946f157eb94bd30076a2e1577268eb\"","$:/state/quine--1502880341":"\"b17418cce818a6d42f97658718970ecb\"","$:/state/quine--672006115":"\"79cf59bb645e976a9f9c10e583dd8c8a\"","$:/state/showeditpreview":"\"190b3bd59c2bf37d3107dcbf8c3488b2\"","$:/state/sidebar":"\"c0e7b8ffb9b2cef002eccb4cfd40a029\"","$:/state/social order--1110802714":"\"bcfc82fb1ba03b610093f9ddea02bfe6\"","$:/state/social order--971479827":"\"6a877cfc7816c2a3ecedcc8545275b3d\"","$:/state/strex_-546171805_-404455225":"\"6ba80af6daf1c596a11b6e4ca29eeb86\"","$:/state/strex_1415370218_-404455225":"\"415b2bd67ac76e8dff9208ab2ab061f7\"","$:/state/strex_654239083_-404455225":"\"dc5c1a08d9d5f67bf4b64bdb4dd00fa1\"","$:/state/strex_70209100_-947816403":"\"12f2b1c654023bca9c1208ae7cb9abf4\"","$:/state/strex_777415616_-404455225":"\"265f9f63b422966cd4815f2db37b1a18\"","$:/state/strex_error: xuid hashing_--2022463313":"\"e065a3ffc92af9b81c743ba69dc3a192\"","$:/state/strex_error: xuid hashing_-2064420303":"\"fa02c77f9bdfaa11df3ba5ac5fc54d27\"","$:/state/strex_error: xuid hashing_-2124116981":"\"0f964caa8903fae458eba91148b2e70d\"","$:/state/tab--1466862881":"\"5f38f55c4d3214bb496774802700284c\"","$:/state/tab--1498284803":"\"4c1dcd4feae89b75dcd3b14ef5e1cebe\"","$:/state/tab--1789422239":"\"3131cc33c9bfe34c0139dadb53fe9034\"","$:/state/tab--1903061147":"\"7c9df997d26407acd28ba44209f39a06\"","$:/state/tab--1963855381":"\"3e552f460f35cbde029acdccbd92593c\"","$:/state/tab--2016259090":"\"3aaf19c14ccc47b99d1dd0f3cb1337c3\"","$:/state/tab--2112689675":"\"28823778f67bc3045f0a391531e320b9\"","$:/state/tab--442292640":"\"e3f0d51dc2be294a561dcdb2b1f47f4c\"","$:/state/tab--86143343":"\"f88306953ddf9b8c36ea3e41cd0b3207\"","$:/state/tab-1234747213":"\"88b78efdad34fb33f17685c79e028c07\"","$:/state/tab-1517343957":"\"463a0997b4a9062726ca4faaec7b7e3b\"","$:/state/tab-1749438307":"\"43d56ebbec9ea528eca79145ab5572d6\"","$:/state/tab-244992490":"\"b62c96a18125701f08bdc5fcbd9b03f1\"","$:/state/tab-492244070":"\"0aeafa4e4a7ff0e3ff2cd4602387ceaf\"","$:/state/tab/moresidebar-401116514":"\"1f575779eaaef21a0008a6bdb3c71724\"","$:/state/tab/sidebar--1835078512":"\"2b68d5b86172a099057a6fe8eef9339e\"","$:/state/tab/sidebar--2063883831":"\"3b40e1fda4948df23c15851713faff00\"","$:/state/tab/sidebar-999205604":"\"0bfc063f0db8c3bc97cdaa05b483ff24\"","$:/state/tabs/controlpanel/toolbars-1345989671":"\"b87dc44f46db2ce13b0a71862d11472c\"","$:/state/toc/TableOfContents-Demonstrations--1307089991":"\"f8c3dbaf3b60f199f22fbfa0bdda9327\"","$:/state/toc/TableOfContents-Demonstrations--2108771229":"\"661db3cb8936835a2be89ef1f15d865f\"","$:/state/toc/TableOfContents-Resources--1307089991":"\"ccbb9442d998c5d00ce327cacfc56a8f\"","$:/state/toc/TableOfContents-Resources--2108771229":"\"3752f39e0d23cfe1814b677e3a9572d4\"","$:/state/toc/TableOfContents-TiddlyWiki for Scholars Using Web Archives--1307089991":"\"1bcaaa1f8182341b1a7525ce05c6568a\"","$:/state/toc/TableOfContents/Demonstrations-Demo 1: Assessing and Presenting Data--2108771229":"\"995a2ea4ec0fc52cd73d573df5ea2d86\"","$:/status/RequireReloadDueToPluginChange":"\"d99c9e69c4dc9b205e6f72291ba58984\"","$:/status/UserName":"\"17bd12b55cf9eb44abc39fa04a4f7167\"","$:/tags/TopLeftBar":"\"f22dbdcb641581b55a3d2c130dfec09a\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ca-ES":"\"1ceca3edad74baa52e50120d20893d5b\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/cs-CZ":"\"3d5e14f54ea76967455bc0e5ef1090c0\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/da-DK":"\"2cabc2ac457daa96b8075d9753ef504e\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-AT":"\"48a7e1e5d6d4d1c611636aac84862e47\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-CH":"\"a17278e916fb245497f81a4cb2a2e99a\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/de-DE":"\"24517ebd8d4ddbd6fa9f8f54f2f7906a\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/el-GR":"\"ca1ad67d992c284f6aa3e18f0eff3c11\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/es-ES":"\"a80a65caa3eef8fee54ce85a5b11c536\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/fr-FR":"\"41150ae9a13cfcd6a387f57903c3cae6\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/he-IL":"\"01104a6f998747cfa176dddcc094a973\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/hi-IN":"\"138bc4e10620d983baa2fb2ee1ded398\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ia-IA":"\"c864650a1d1c159cb5f63551c5985e57\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/it-IT":"\"7f307fde134dbd3ff1bac92264e41429\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ja-JP":"\"a402618dc4aa9ca7ee98f566d21e7faf\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ko-KR":"\"5e0f33dd6e9901f0f03d47f13348a942\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/nl-NL":"\"ecf481ac70547a54c59b33be6b227c96\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/pa-IN":"\"b1c83805428e65cbde5c04255329b7fa\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/pt-PT":"\"af30ee55a15fcc10ac8dcba194b4f757\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/ru-RU":"\"8c2dcd652d04fa4944a5b1b03ee1636d\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/sk-SK":"\"a65d7385f675cd64a97ae26952151569\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/sv-SE":"\"d0f2b9a817e512530a1dcc4eff260f5c\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/zh-Hans":"\"deab0c6a5f0ae8f28f019a47ffdf6875\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/languages/zh-Hant":"\"5e3ec9adb98bd595d175cc2b1f7432ed\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/async":"\"5d730c3e2e752814360f6a53e37b8ff3\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/bibtex":"\"b5675014ec46c4bdcdee83be28aee8fe\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/blog":"\"8d201c267cfa9177eec3a62929aa7977\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/browser-sniff":"\"a528aa8018aa4f2760904ddb31e117e9\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/cecily":"\"db3b188436d87b25c0a1de33d4faed9c\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/classictools":"\"fd0056c3499f7b9cb265215b2e73f81b\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/codemirror":"\"1499b600b54f7539934531dc449eaed0\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/d3":"\"450968b653bf45a90721f55f0cb93812\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/evernote":"\"e30a73576faa06b20c3111b15b69a525\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/filesystem":"\"3aa48e023f460291937fac9bef9da75c\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/github-fork-ribbon":"\"44fbfd36a2a3bb968be2cd8f16ef59ac\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/googleanalytics":"\"9c3447a6cdb033ed2b05ab6ecf63522e\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/help":"\"405dc0e4d55096e5dce0528c2a56cf5f\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/highlight":"\"bc0962c82729e68e3e3dea7773a6b0fd\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/internals":"\"c540345ae3a067421984a7855651afe9\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/jszip":"\"da01e05801581f6ae995d2beef1bb3dc\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/katex":"\"6589c1184609dc35ef3c4c64e58cd6c7\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/markdown":"\"e1fec21bd9deb92e0a008117e753164d\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/mobiledragdrop":"\"16af7c7944ee0793d28d14fe13d8b508\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/nodewebkitsaver":"\"51b45fcfe6c205e135db7a27f7fb9dac\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/powered-by-tiddlywiki":"\"02918d9f9a3fe445a149e5c6f7fd5a51\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/qrcode":"\"db96d31b14ee6113d08337df8c82f8de\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/railroad":"\"6af8d9b727cf1f41c56857181b995e05\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/savetrail":"\"6eca535d40efa8e25296b9e70b33434f\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/stacked-view":"\"7efd7a8e07b4dda1aa124a5597a3ae8c\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tahoelafs":"\"75153579f6cfdc9a8ede2e9f6ad30210\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/text-slicer":"\"c44736de616b3170187897b4f1dee2b4\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tiddlyweb":"\"97122286c19e97d27b37aa6dd5457096\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tw2parser":"\"ee9bde726b79e52c31959fde45703646\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/tw5.com-docs":"\"e7106630f9fa6a88fb7086800d0e6230\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/twitter":"\"c3beb2042c30373f408888b044fa3b72\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/xlsx-utils":"\"5d7c413e81c9d16b3046bc6c2312748b\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/plugins/tiddlywiki/xmldom":"\"f1011f5a20156bed2305f978c49140a5\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/centralised":"\"6c74caa1630c763076f2d2c9a3b5e559\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/heavier":"\"f6cdc3f61acada73b1e4aa469d5d9e7a\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/readonly":"\"2e91af65d53ea12d8910c5a21e058b19\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/seamless":"\"f24c1d0764f4cba506a67fb720be414a\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/snowwhite":"\"8103971d26a10033077c95b7a7365e60\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/starlight":"\"8a2db580de66f1f676a2c1bf4ccd34a2\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/tight":"\"aaedaf37f0b343b7c11c5398c4b7149e\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/tight-heavier":"\"601efcc15fce0fa20edf82d86bd02e7e\"","$:/temp/RemoteAssetInfo/http://tiddlywiki.com/library/v5.1.14/index.html/$:/themes/tiddlywiki/vanilla":"\"04d4fad672e07ae67a3836bd33a70e15\"","$:/temp/RemoteAssetSearch/$:/config/OfficialPluginLibrary":"\"2dc72893c9f593e8e7d758be2a356dc2\"","$:/temp/RenameTags/replace":"\"224be0ab446dbc2fbea5fa9567e87270\"","$:/temp/RenameTags/search":"\"b075b39ae5bc3108b4fcfe1988b8bd57\"","$:/temp/ServerConnection/http://tiddlywiki.com/library/v5.1.14/index.html":"\"fceb7c6bfb9d01d93146654c346e160e\"","$:/temp/advancedsearch":"\"2a804e986d32cfa65350540cd7789e4e\"","$:/temp/appear/-126274325/block//citation":"\"2cddab09c13cbfa6906353cdbc45fd87\"","$:/temp/appear/911 Blogs To Explore-1477499117/block//process":"\"943d8566b724fefaa52175b843eae541\"","$:/temp/appear/911 Blogs To Explore-1477499117/block//task":"\"ae817794b3bd584b95dad015bd841481\"","$:/temp/appear/A Web page that anyone can write1273324267/block//dataset":"\"cedce9658198e2ecec9219cc83f23380\"","$:/temp/appear/A Web page that anyone can write1835489822/block//dataset":"\"90236a2005dfea5c8b937d1762641c37\"","$:/temp/appear/A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.547574563/block//citation":"\"9c5db20b395be66dd4484a774297a191\"","$:/temp/appear/A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.547574563/block//slider-buttons-level1":"\"38c83f1ca6ba4e5097c57ba1ab64e928\"","$:/temp/appear/A platform for writing, reading, thinking, teaching, learning-1493198882/block//dataset":"\"8e1a50ba168d9068e181c9ddf5699a22\"","$:/temp/appear/AZSites LLC.1824238207/block//slider-buttons-level1":"\"7d0cb351adcce119a09ddf4f48b2956d\"","$:/temp/appear/Actors and networks are monads404455225/block//dataset":"\"5f1fb87cad6cb87593fd8a5746a58d98\"","$:/temp/appear/Actors are defined by networks. Networks are defined by actors.404455225/block//dataset":"\"00a2d55c6d300d5122066af9e2a41c6a\"","$:/temp/appear/Add-on-142613885/block//slider-buttons-level2":"\"a626c1fcc4faf6cd356778c8e8e180f9\"","$:/temp/appear/Add-on-357503403/block//slider-buttons":"\"adc89b0d9b03123321924aedd7b339aa\"","$:/temp/appear/Add-on-481949749/block//slider-buttons":"\"84543cefc7081b0e2ead7ab9090d9222\"","$:/temp/appear/Add-on264853545/block//slider-buttons-level1":"\"87fb0ed997537eda1cf5fd05d17e16b5\"","$:/temp/appear/Add-on264853545/block//slider-buttons-level2":"\"8a4cb42f79be2dd466d4ae2713cbb4a2\"","$:/temp/appear/Add-on72351461/block//slider-buttons":"\"3c87ebd8a51ff98e46b157897515ddb6\"","$:/temp/appear/Advising264853545/block//slider-buttons-level1":"\"42e0176670a0ebab3729521c6d3db2a6\"","$:/temp/appear/Advocating264853545/block//slider-buttons-level1":"\"149275006f34d2f4d2a2fedf71578517\"","$:/temp/appear/Aerial photo of Ground Zero shows the proximity of St. Paul's Chapel and Trinity Church.547574563/block//slider-buttons-level1":"\"fa6c66d491056de5922797c7aa4ae28b\"","$:/temp/appear/After the attacks, the Marine Corps reported an increase in the number of Marines returning to active duty.241852141/block//slider-buttons-level1":"\"d8b5be24ed54564327388dd357744164\"","$:/temp/appear/Alternative To? Replacement for?-1493198882/block//dataset":"\"70bcb94d5ce04394f7f28ec16df9d6ad\"","$:/temp/appear/Appropriating-142613885/block//slider-buttons-level1":"\"dc54dae90c58786394db467e7d9b9db9\"","$:/temp/appear/Appropriating264853545/block//slider-buttons-level1":"\"86e4e3dd96eef29aed62c5cf17ad360e\"","$:/temp/appear/Arab American Journal posted Attorney General's statement regarding Arabs and Muslims-152188601/block//citation":"\"f5b28521b00c69231d174e15ed840208\"","$:/temp/appear/Arab American Journal posted Attorney General's statement regarding Arabs and Muslims-152188601/block//slider-buttons-level1":"\"c743c26c777fe42ec1da2036be81382e\"","$:/temp/appear/Articles categorized by source on the Evergreen State College library site.241852141/block//slider-buttons-level1":"\"23958de20a1e105d4942d463af2a5ddc\"","$:/temp/appear/As early as the evening of September 11th, search and rescue dogs were used to search for survivors.-1198580557/block//slider-buttons-level1":"\"d4ecc1d1c682bf29390bdbd1f482a1f7\"","$:/temp/appear/As early as the evening of September 11th, search and rescue dogs were used to search for survivors.-938289217/block//citation":"\"710c2343b491dbdc30d2f4ef730e68b5\"","$:/temp/appear/Assisting264853545/block//slider-buttons-level1":"\"f8e609172ef44291730af7feb30be014\"","$:/temp/appear/Assisting337508187/block//slider-buttons-level2":"\"809a1d8dea03dc99aa390ece84c61c1d\"","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-202087927/block//slider-buttons-level1":"\"e4d892d6c5bd29e6a20fa122379012cd\"","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-2041694151/block//slider-buttons-level1":"\"0abb67a76e1ba38d32fca2eeb45f623d\"","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.-2053240569/block//slider-buttons-level1":"\"24f7a0f8f9309c10877572c79ff6ad5b\"","$:/temp/appear/BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.876438085/block//slider-buttons-level1":"\"51c030d9bed009e0aaf4dc3832ba1cf4\"","$:/temp/appear/Background-426537711/block//dataset":"\"ce46a8669d507adf68124116e5796eee\"","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-1785592531/block//slider-buttons-level1":"\"b90276a8c98efdf6c57612e0a0af1ec0\"","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-2041694151/block//slider-buttons-level1":"\"7e05d99c717bfe1938f7c1851a1687da\"","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.-206484573/block//slider-buttons-level1":"\"f5d0d0b9380531273a225a35cc424438\"","$:/temp/appear/Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.1272971173/block//citation":"\"b33cf9b29e45f427b7200a7df64d9636\"","$:/temp/appear/Branch-142613885/block//slider-buttons-level2":"\"efababbeba385b9b976d67c548eb1c43\"","$:/temp/appear/Branch-357503403/block//slider-buttons":"\"3f450ae9f04ebca263d9f9019bacf788\"","$:/temp/appear/Branch-481949749/block//slider-buttons":"\"18e91d4d17bdacb5cf51464645de0d62\"","$:/temp/appear/Branch264853545/block//slider-buttons-level1":"\"6b5bd28e4a1fc198fc5469b8ef6dfec0\"","$:/temp/appear/Branch337508187/block//slider-buttons-level1":"\"1c26204581ba7f16df9a9590c553567b\"","$:/temp/appear/Branch337508187/block//slider-buttons-level2":"\"84bfac9d9425a47be35f9351fda62d63\"","$:/temp/appear/British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.-1133582955/block//slider-buttons-level1":"\"5f6a4c9c61d216c410eb8c63aed1ad48\"","$:/temp/appear/British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.1796769249/block//slider-buttons-level1":"\"d38769ed8c09390a6ff3b299f7791aab\"","$:/temp/appear/Business-142613885/block//slider-buttons-level1":"\"76f317fa2b0b3ef7e91bbcb26167e7d9\"","$:/temp/appear/Business-481949749/block//slider-buttons":"\"cffbc52a31c2d46e5a4352780be7bded\"","$:/temp/appear/Business264853545/block//slider-buttons-level1":"\"07dcb13531bd669ab4cd387528312446\"","$:/temp/appear/Business337508187/block//slider-buttons-level1":"\"405b00dee7a2f0ea06228cd05d5873d8\"","$:/temp/appear/Business72351461/block//slider-buttons":"\"7101fe98f90b4d0dc3b36987923bbc8a\"","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//approach":"\"b342294bec34a6127ee8c83c6198d578\"","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//challenge":"\"4ba296dd65f387d2e7514fe1b85950e6\"","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//environment":"\"4ae5891edc04fd529021479287521fe1\"","$:/temp/appear/Challenges for Scholars Using Web Archives-191786315/block//solution":"\"1cf2d88d68a033eab3015f16ff3397a1\"","$:/temp/appear/Charity/Civic337508187/block//slider-buttons-level1":"\"4a45949de7e60453c2dd052fc6014efa\"","$:/temp/appear/Dedicated-142613885/block//slider-buttons-level2":"\"3143fa54a0b247cd53f5bef56c8a3c49\"","$:/temp/appear/Dedicated-481949749/block//slider-buttons":"\"eab54e21acf57df15a5139cf81cc0f74\"","$:/temp/appear/Dedicated264853545/block//slider-buttons-level1":"\"6489e9002a9e35331d446d3793bcd8be\"","$:/temp/appear/Dedicated264853545/block//slider-buttons-level2":"\"1e34352ea66f7e8ff9971d31ab7bbe9a\"","$:/temp/appear/Dedicated72351461/block//slider-buttons":"\"0fd88e9d03c6aa592cefe93a052da3a7\"","$:/temp/appear/Demo 1: Assessing and Presenting Data569960871/block//dataset":"\"9f6ca1782b0e147fac51d1f127ffe266\"","$:/temp/appear/Demo 1: Assessing and Presenting Data569960871/block//process":"\"36a7262731f746ac862f9b62797c6f20\"","$:/temp/appear/Demo 1: Producer Actions in the post-September 11 Web Sphere-791301717/block//dataset":"\"aebbb942fbbf9f8f33b719abf9565034\"","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//dataset":"\"b5cda590c8f5568c9933ed3990c8765b\"","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//links":"\"ded7a76b0746bc31649cae77a41c3c1e\"","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//process":"\"114f264bd941de64382c26ab833322e6\"","$:/temp/appear/Demo 2: Identifying and analyzing archived Web pages-539721495/block//task":"\"0c75568cf5d6ba050246962decdfe1fd\"","$:/temp/appear/Demo 3: Integrating TiddlyWiki with the ODU Toolkit-69021799/block//dataset":"\"b1f8ef7412e9c239ecbb06c90afaeca2\"","$:/temp/appear/Demo 3: Using the toolkit with WAIL-1245609497/block//dataset":"\"d179aee2c9bde6c9113cab4ca9a3fc75\"","$:/temp/appear/Descriptions and photos of the missing were posted online.-2053240569/block//citation":"\"b18e77eb75a40607751a56f3123db611\"","$:/temp/appear/Descriptions and photos of the missing were posted online.-2053240569/block//slider-buttons-level1":"\"a3d3db22728f7208c6fe80bf4c9ccb02\"","$:/temp/appear/Digital traces afford navigation through overlapping monads constructed through shared tags404455225/block//dataset":"\"8615704fe7c5e99b78744cf70f812def\"","$:/temp/appear/Dr. Muqtedar Khan published article demanding Muslims step up and not tolerate extemist activity and expand their perspectives.1952226459/block//slider-buttons-level1":"\"7f5c2ba60816e805df75075f846604d7\"","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//links":"\"cf840df8cc50d1a466f8beb9a74f83d2\"","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//process":"\"f3a944269399cd76b7891289cdba1e4e\"","$:/temp/appear/Draft of '911 Blogs To Explore'1043321551/block//task":"\"0a0c1c71f35bd1e64240626fec6b5b48\"","$:/temp/appear/Draft of 'Challenges'413112415/block//challenge":"\"e7ef5f2810af9e61d666b34051a80305\"","$:/temp/appear/Draft of 'Challenges'413112415/block//environment":"\"6837b0b75af4ed8da8abd29086463f9a\"","$:/temp/appear/Draft of 'Challenges'413112415/block//solution":"\"bc7a497c86f049d5b55b1a9d43eeb314\"","$:/temp/appear/Draft of 'Demo 1: Assessing and Presenting Data'-1072968491/block//dataset":"\"bd04d7854d982a2bdb96b3061e104ea0\"","$:/temp/appear/Draft of 'Demo 1: Assessing and Presenting Data'-1072968491/block//process":"\"6281b682b70efc9237de8cf7bf5d96eb\"","$:/temp/appear/Draft of 'Demo 1: Producer Actions in the post-September 11 Web Sphere'-2105913825/block//dataset":"\"069105a0e570bf93b3bfac40516b3f78\"","$:/temp/appear/Draft of 'Engaging in Web Sphere Analysis using Monadic Thinking'1813779803/block//sphere":"\"80687c814e387960dbaa75484d4d7546\"","$:/temp/appear/Draft of 'Identify and Define Analysis Tags'388937191/block//citation":"\"350950f6e318a5abf468951e004e1b45\"","$:/temp/appear/Draft of 'Identify and Define Analysis Tags'388937191/block//showfields":"\"ec072cd2477ad398f904c2fdf4dd42ae\"","$:/temp/appear/Draft of 'Introduction'-914016841/block//challenge":"\"53c7b94f92c2081557948d00250b1563\"","$:/temp/appear/Draft of 'Reflections on #dmi17'1347795257/block/":"\"58aacb0cc171d8b875b1252ea931458f\"","$:/temp/appear/Draft of 'Situating the Case'-426537711/block//dataset":"\"3ff117cd3c2cacc12ab92f96fd2f6c25\"","$:/temp/appear/Draft of 'What is TiddlyWiki?'-1502880341/block//free":"\"074695b1184d7d67194a2899b4bfd52f\"","$:/temp/appear/Draft of 'What is TiddlyWiki?'-1502880341/block//hypertext":"\"8d633aa347ab3a8cf59fd81ee000a6fa\"","$:/temp/appear/EduHound creates a ribbon for others to download in support of the USA (patriotism)-202087927/block//slider-buttons-level1":"\"b4d653ee8d9aeef073b3202a02450f53\"","$:/temp/appear/EduHound links to sites to help educators with the tragedy-206484573/block//slider-buttons-level1":"\"4407bd6265d3b45c6e3abe6f0378b131\"","$:/temp/appear/EduHound posts a flag graphic on their website to symbolize patriotism2026642401/block//slider-buttons-level1":"\"1c3cbf1dbfb5114b4ad0ce9280964638\"","$:/temp/appear/EduHound provides links to news sites about the events of September 11241852141/block//slider-buttons-level1":"\"474fd342bb133a3f9436fd70c1f0aea7\"","$:/temp/appear/Educational-481949749/block//slider-buttons":"\"382a3f669f8c1bb75e29600a0b3b2ea9\"","$:/temp/appear/Educational72351461/block//slider-buttons":"\"ecedb7a366a4c85c025a0bb1ab36af1b\"","$:/temp/appear/Embeds the grammar of hypertext in the punctuation of writing1273324267/block//dataset":"\"22ee676d59e5a0323915abfdc1f4dec3\"","$:/temp/appear/Embeds the grammar of hypertext in the punctuation of writing1835489822/block//dataset":"\"86150d7419d9b0c54c293fb38d1837dc\"","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//challenge":"\"60149bdedfe019dd1f50171fa408847b\"","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//environment":"\"d1d73a5850dc7795eb3cb6676f03eced\"","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//solution":"\"875ced2dd88eb0c29068700d20af3793\"","$:/temp/appear/Engaging in Web Sphere Analysis using Monadic Thinking1309029405/block//sphere":"\"acd70d11dc06412350256029b934cde1\"","$:/temp/appear/Episcopal St. Paul's Chapel, located yards from Ground Zero, became a haven for rescue workers providing food, supplies, chiropractic services, and more.264853545/block//slider-buttons-level1":"\"8e25562e756fb3e5c6ae9feb302e1323\"","$:/temp/appear/Ethnic-481949749/block//slider-buttons":"\"816f21343fbfe15731917d0466572ccc\"","$:/temp/appear/Filtering-1861790927/block//dataset":"\"f018fb294615ecb30ff8c64a0b129211\"","$:/temp/appear/Filtering-31571497/block//dataset":"\"4a564b09127db69b5bcb09a2cfa49f2d\"","$:/temp/appear/Gallery of patriotic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1122658065/block//slider-buttons-level1":"\"7a3e9a1d7dc7954e3c48e882424ab616\"","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1122658065/block//slider-buttons-level1":"\"1e28a9011e029f7d35dce4d2716afb50\"","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.-1518436769/block//slider-buttons-level1":"\"e8098b4cf6424b905b79251ea3f5732e\"","$:/temp/appear/Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.815572859/block//slider-buttons-level1":"\"67d99197b415a7a827fd05425d53b419\"","$:/temp/appear/Government-142613885/block//slider-buttons-level1":"\"43424940fe684d710ca7416b43376960\"","$:/temp/appear/Government-481949749/block//slider-buttons":"\"20042d49d68935a5a0a2a60f817ad06b\"","$:/temp/appear/Governor Pataki moved quickly to provide financial assistance to New Yorkers affected by 9/11.-1463103709/block//slider-buttons-level1":"\"9f36cca9fad4c9f33be50a7a8c406a0e\"","$:/temp/appear/Graphic264853545/block//slider-buttons-level2":"\"110d34efb5e6f8a2932ec7756ce0a111\"","$:/temp/appear/Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. A quote from Abraham Sofaer from The San Fransico Chronicle article is shown.-1050704581/block//slider-buttons-level1":"\"8816927bdf3cf934e2d4499adc602331\"","$:/temp/appear/Hosting264853545/block//slider-buttons-level1":"\"0ee8e419c1c66a6e1c1aa48ad0075fdc\"","$:/temp/appear/Hugh L. Carey of Battery Park City Authority reflects on the events of the past year, thanks supporters, and encourages a return to normalcy.-2041694151/block//slider-buttons-level1":"\"e05e744804f849c79d5481734514306e\"","$:/temp/appear/Hyper211407297/block//dataset":"\"8aa786b0dbe64f4baf495f40bf0b03d5\"","$:/temp/appear/Hyper947816403/block//dataset":"\"cb6a834c03aa6034cc0890bdae5eadcf\"","$:/temp/appear/Identify and Define Analysis Tags-1738796007/block//define":"\"274ab82a349d9a6c599df882e7355ba6\"","$:/temp/appear/Identify and Define Analysis Tags-1738796007/block//showfields":"\"355906d31332f9095e633523deccc19c\"","$:/temp/appear/Individual/Volunteer-142613885/block//slider-buttons-level1":"\"6d9b46fa38628ba4d3238987018a7721\"","$:/temp/appear/Individual/Volunteer264853545/block//slider-buttons-level1":"\"0ec98833ab800a28680eae0f35f09fe6\"","$:/temp/appear/Individual/Volunteer264853545/block//slider-buttons-level2":"\"509f16f85acda2ba53143059cc9842f7\"","$:/temp/appear/Individual/Volunteer72351461/block//slider-buttons":"\"a71b73b07ebb5f4ab29f21ba6b8a0be6\"","$:/temp/appear/Informing264853545/block//slider-buttons-level1":"\"0fa19ea57c3867c0f2daa065c9552f58\"","$:/temp/appear/Interest/Advocacy264853545/block//slider-buttons-level1":"\"25da454b63373ff0cca5364b9146fb6a\"","$:/temp/appear/John Labriola gives a first-hand account of his story.264853545/block//slider-buttons-level1":"\"206730b0306d8c090955a3af68dbb6bf\"","$:/temp/appear/Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.-112022025/block//citation":"\"d70b9cce6915180bd22a6ecda2415dcb\"","$:/temp/appear/Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.-112022025/block//slider-buttons-level1":"\"f39fc6efa252b8f612978cd96e0a427e\"","$:/temp/appear/Jon Anhold hosts a television screen shot of CNN's live coverage of the terrorist attacks.264853545/block//slider-buttons-level1":"\"643f307acbc734ca8c0b6a1bd8e261b9\"","$:/temp/appear/Learning Hypertextually-1646321229/block//dataset":"\"6d6a73d36eb3b37400a1be2036aeacba\"","$:/temp/appear/Linking-1861790927/block//dataset":"\"5345f564c0325c34ea5cd8500ed07ac4\"","$:/temp/appear/Linking-31571497/block//dataset":"\"9d737233006ef0312b43400aef451b9a\"","$:/temp/appear/Linking264853545/block//slider-buttons-level1":"\"b737c827bc054cb5d453f92ced1ab284\"","$:/temp/appear/Links to resources for those looking to volunteer, donate money, or need assistance.-1198668541/block//citation":"\"625fd02ec252b9ca2da981f2b6f4412f\"","$:/temp/appear/Links to resources for those looking to volunteer, donate money, or need assistance.-1198668541/block//slider-buttons-level1":"\"3bca4a23223f6466300a7a6f245f3bb9\"","$:/temp/appear/Many New York State security concerns arose after the attack.-206484573/block//slider-buttons-level1":"\"f3f499d004e77c5fd4a4019b751d2c27\"","$:/temp/appear/Memorializing264853545/block//slider-buttons-level1":"\"2a6b7e1736ce665f347b9b36be722b8a\"","$:/temp/appear/Monads are expressed as different ways of navigating through data sets404455225/block//dataset":"\"c5adb2d80d9dd0f710d6e05df79b34b8\"","$:/temp/appear/Multi-dimensional-1376806676/block//dataset":"\"449ac43dcbe5ec11c366cc0f6c93e4f3\"","$:/temp/appear/Multi-dimensional-2008439413/block//dataset":"\"b5e9fae3607eef0c10c67b9d02f374d6\"","$:/temp/appear/Multi-dimensional2037981064/block//dataset":"\"bf32bb3ecaac457f32fbf183e9d565cf\"","$:/temp/appear/NYS Emergency Management Office posted links to relevant third-party sites for further information and assistance.-1403528797/block//slider-buttons-level1":"\"8d49c9d1dd320c0c6ba248b3d16ba432\"","$:/temp/appear/NYS Emergency Management office posted recovery assistance resources for public assistance workers.394287553/block//slider-buttons-level1":"\"fbc0d8a6feaaa8ebc6d059a4bc2702bf\"","$:/temp/appear/On her official homepage, Senator Hillary Rodham Clinton made useful information available to those who wished to assist others after the tragedy.-1081632013/block//slider-buttons-level1":"\"88aae48e149f6e1245e16ec18e1601de\"","$:/temp/appear/On her official website, Senator Hillary Rodham Clinton posted the text of her statements in Congress commemorating the efforts of New Yorkers who responded to the tragedy.-1081632013/block//slider-buttons-level1":"\"ed733905a52cde0673b7e2daec4cf759\"","$:/temp/appear/Online directories and memorials tracked those missing after 9/11.1824238207/block//slider-buttons-level1":"\"90b2f3da98425f3d13a35788c23be2ea\"","$:/temp/appear/Open Source-1493198882/block//dataset":"\"771a9d57bc24670c2de8150d03611a0e\"","$:/temp/appear/Photo-142613885/block//slider-buttons-level2":"\"48fdafee7f58727c6c58644f0aacf62e\"","$:/temp/appear/Photo264853545/block//slider-buttons-level2":"\"cf54c8e4fedf90d7865d1016dfa59294\"","$:/temp/appear/Photos of President Bush and smoke billowing out of the World Trade Centers are part of a collection of images Evergreen State College compiled.264853545/block//slider-buttons-level1":"\"8633766e60d85958d72cd2ed1a8720b2\"","$:/temp/appear/Practices-1376806676/block//dataset":"\"2c4c0a064a2c0b2b8d44ee64562bd451\"","$:/temp/appear/Practices2037981064/block//dataset":"\"4fa524c85c0cdd344da4d81d97a42f19\"","$:/temp/appear/Press release from US Commission on Civil Rights-152188601/block//citation":"\"bd113388dca87e09a5f824ad50ba5d0c\"","$:/temp/appear/Press release from US Commission on Civil Rights-152188601/block//slider-buttons-level1":"\"e9193dd3b16b74b47fe6414b5b805eef\"","$:/temp/appear/Public-142613885/block//slider-buttons-level1":"\"296d646fe922b9a83bcd9b40a9954656\"","$:/temp/appear/Reading Hypertextually-1646321229/block//dataset":"\"3c6b0d0344a18b6b054bd0a1df545102\"","$:/temp/appear/Reflecting-142613885/block//slider-buttons-level1":"\"8bf61d11980aed3924ed39d9c415c5bb\"","$:/temp/appear/Reflecting264853545/block//slider-buttons-level1":"\"01575d41bfbf974642a1e94bea117ab5\"","$:/temp/appear/Reflections on #dmi17-2111597877/block/":"\"c006a7c6242a266edc56f97ed4b54cc3\"","$:/temp/appear/Religious-357503403/block//slider-buttons":"\"8b68efd8a3f586b424d1d993359bfc9c\"","$:/temp/appear/Religious-481949749/block//slider-buttons":"\"3bbd459eca1387e686c9168d3ff3a27c\"","$:/temp/appear/Religious337508187/block//slider-buttons-level1":"\"92000123c9b3ed98c5efdb9ba3b4456e\"","$:/temp/appear/Reporting-142613885/block//slider-buttons-level1":"\"1cd80fbc5d1fcb3c1d4af13313945323\"","$:/temp/appear/Reporting264853545/block//slider-buttons-level1":"\"9811001f93c461eebbf4c05cbc792549\"","$:/temp/appear/Research Questions-426537711/block//dataset":"\"97f524c1dadbb5e1d5dbef035609d309\"","$:/temp/appear/Senator Hillary Rodham Clinton echoed the the sentiment of unity many felt in the days after the tragedy. She voiced her support for the Bush administration's response to September 11, repeating the refrain, \"You are with [us] or you are not.\"-1081632013/block//slider-buttons-level1":"\"3456a62ef317f5033b5a4e7101e01e14\"","$:/temp/appear/Single Page Application-1493198882/block//dataset":"\"71998c36381d10d3663e425e845ae08d\"","$:/temp/appear/Site posted links to 3rd party donation sites.264853545/block//slider-buttons-level1":"\"8d7e8379c7c39ae18184417a4c638b96\"","$:/temp/appear/Sites listed hotline phone numbers in New York City to help find the missing.1824238207/block//slider-buttons-level1":"\"94ddbb02bcc768a82cb055cd3c7304c3\"","$:/temp/appear/Situating the Case-426537711/block//dataset":"\"4bb4b99599fe5f0f166d0023b282afc8\"","$:/temp/appear/Splash page of the Why Project - a site devoted to art about the attacks.1447210293/block//citation":"\"0411f73879ca03444f03b5b0d80d4b1d\"","$:/temp/appear/Splash page of the Why Project - a site devoted to art about the attacks.1447210293/block//slider-buttons-level1":"\"8178b5ceaa1a830f23ce2cc552fd3e65\"","$:/temp/appear/Tagging-1861790927/block//dataset":"\"1f8a41f3688c121d6dcaafeee3917981\"","$:/temp/appear/Tagging-31571497/block//dataset":"\"2e8899dd6a9e600c43670098e7d93180\"","$:/temp/appear/Teaching Hypertextually-1646321229/block//dataset":"\"6ad1f332d860d2b214f1998e1af24c63\"","$:/temp/appear/Techniques-1376806676/block//dataset":"\"30e37ea626bf9b060d783cd15f85d601\"","$:/temp/appear/Techniques2037981064/block//dataset":"\"df20f7b66f3917f927857ad5a78f1ca8\"","$:/temp/appear/Templating-1861790927/block//dataset":"\"249bd2e17702c9a0a604fcf51fe752f1\"","$:/temp/appear/Templating-31571497/block//dataset":"\"2e7bf1d6189b8016214833e6714d6ac6\"","$:/temp/appear/Text Hyper Wiki Tiddly211407297/block//fourwords":"\"fabc28e1fd5621dc7563f10cd25e6018\"","$:/temp/appear/Text in this webshot describes the materials and structural system of the Twin Towers. A graphic illustrates a typical floor plan within the building.-724635207/block//slider-buttons-level1":"\"a7c1a91daf9ccb535aef5aedab6f83a2\"","$:/temp/appear/Text in this webshot suggests one possible explantion as to why the supports of the building collapsed after the planes hit the Twin Towers.-724635207/block//slider-buttons-level1":"\"250d49940e524aadf3e2e545aa8ba5cf\"","$:/temp/appear/Text211407297/block//dataset":"\"fb91a8d0723b3d94b4461447bd80f8c5\"","$:/temp/appear/Text264853545/block//slider-buttons-level2":"\"46e815428547d1dd8479bd941ff55981\"","$:/temp/appear/Text337508187/block//slider-buttons-level1":"\"0e9ddd30e842a6cec68b003c57a4102e\"","$:/temp/appear/Text947816403/block//dataset":"\"13a24ab53dfd239f74f1e981c4d77a50\"","$:/temp/appear/The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children shared America's grief after the tragedy.-1520327575/block//citation":"\"9dec4ba634fe977c14aa98589b080878\"","$:/temp/appear/The Compassionate Friends chapter in Atlanta, Georgia reaches out to memorialize the victims of 9/11.1986743257/block//slider-buttons-level1":"\"93bb55ee7acc27eb748be9f920910fcd\"","$:/temp/appear/The Journal of Arab Students advised Arab students after the September 11 attacks.394287553/block//slider-buttons-level1":"\"a91b1cdbe752de048c47673ab6a3d6cc\"","$:/temp/appear/The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.-202087927/block//citation":"\"d62405309736fa1fb61dc8c0693a2d4d\"","$:/temp/appear/The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.-202087927/block//slider-buttons-level1":"\"60dd9527f402bd16368a8c9aba92fd2e\"","$:/temp/appear/The September 11 Victims' Relief Fund links to stories in the news about itself.241852141/block//slider-buttons-level1":"\"6af959f2c034d508799a9ca4f9fe14c5\"","$:/temp/appear/The Westboro Baptist Church posted information about its protests in the wake of September 11. The group blamed tolerance of homosexuality for causing the tragedy.-206484573/block//slider-buttons-level1":"\"94e6f788bbeb0dccbccdc8db5ac5df82\"","$:/temp/appear/The Women's International League for Peace and Freedom posted contact information to combat discrimination following Septmeber 11.-206484573/block//slider-buttons-level1":"\"2c29092e216e0b244313c107f22b40cc\"","$:/temp/appear/Thinking Hypertextually-1646321229/block//dataset":"\"977520c4b0a88ced35cb8ceca6ff40b7\"","$:/temp/appear/This graphic illustrates what engineers think may have caused the steel structure of the World Trade Center to collapse.-724635207/block//slider-buttons-level1":"\"d9602dbe7e4c045b7d5e60c696be42c3\"","$:/temp/appear/This webshot displays a link to an explanation of why the World Trade Center may have collapsed from the perspective of engineers.-724635207/block//slider-buttons-level1":"\"4159548af4014d3b7eb3f59d3056924d\"","$:/temp/appear/This webshot displays a portion of the meeting minutes for Battery Park City's Residents Association. Questions are answered about rent for tenants displaced by damage from 9/11, repairs and cleaning of apartments, and when apartments will be ready for occupancy.-2041694151/block//slider-buttons-level1":"\"fa470dd3e0fdb1080741f80af5ade199\"","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.-724635207/block//slider-buttons-level1":"\"b90b67c27e03571871c81716c1658c9e\"","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.1447210293/block//citation":"\"7fc5a6e0c73a9b04226d696f9b947f8d\"","$:/temp/appear/This webshot provides general information about the engineering and construction of the Twin Towers.1447210293/block//slider-buttons-level1":"\"147b7d0b82e1c7dcb1b30975f555189a\"","$:/temp/appear/Three-D model of Ground Zero with St. Paul's Chapel highlighted.-112022025/block//slider-buttons-level1":"\"5d22ddab48d0de2471aa15538b5c5775\"","$:/temp/appear/Tiddlers-1493198882/block//dataset":"\"d9c577b225354e16605abd2d771955e9\"","$:/temp/appear/Tiddly211407297/block//dataset":"\"21a39d81a53e89acdf9eaface0ef82dc\"","$:/temp/appear/Tiddly720385555/block//dataset":"\"2fac5fc404b5e1153137427f0e5a9663\"","$:/temp/appear/Transcluding-1861790927/block//dataset":"\"276a37f730da57b7b17ca3a5d9aa37d5\"","$:/temp/appear/Transcluding-31571497/block//dataset":"\"2a9d439c21f7c4e44b85f496653fede0\"","$:/temp/appear/Unknown337508187/block//slider-buttons-level2":"\"dcc855f58bbe2f63da3a04e2b8bdf30a\"","$:/temp/appear/Unknown72351461/block//slider-buttons":"\"0ec3b0870407c6a633ccce2e73a9a58d\"","$:/temp/appear/What is TiddlyWiki?-1434962192/block//challenge":"\"6c52328a898aa873d8d819c12739e9aa\"","$:/temp/appear/What is TiddlyWiki?-1434962192/block//free":"\"c87750e22dce5c6c7b955fa8d2cde8bc\"","$:/temp/appear/What is TiddlyWiki?-1434962192/block//hypertext":"\"11cdad8c7fb6c357a06f4d94f04c83a9\"","$:/temp/appear/What is TiddlyWiki?-1434962192/block//software":"\"b6522f6e5fd26a781c89b6d47f296735\"","$:/temp/appear/What is TiddlyWiki?-672006115/block//challenge":"\"a941046d21d8ba39bcc68eaaab334ac1\"","$:/temp/appear/What is TiddlyWiki?-672006115/block//free":"\"6502adc1f6d754a6e95397659d077847\"","$:/temp/appear/What is TiddlyWiki?-672006115/block//hypertext":"\"26e596bc43eaf569f293f972e771c75e\"","$:/temp/appear/What is TiddlyWiki?-672006115/block//software":"\"5ae4dc7f0c34b57dc7b7fca8e62259de\"","$:/temp/appear/What is TiddlyWiki?720385555/block//dataset":"\"d033a4ed9f8ba87393b83a977a98dd3a\"","$:/temp/appear/Wiki211407297/block//dataset":"\"d1eca216c7ccdc90d1d45daca552a513\"","$:/temp/appear/Wiki720385555/block//dataset":"\"ed26a26b58fce3c5d9100c5bf3e6f6a5\"","$:/temp/appear/Witnessing-142613885/block//slider-buttons-level1":"\"c0ba381127d4a0d8b1940af6b93fd48f\"","$:/temp/appear/Witnessing264853545/block//slider-buttons-level1":"\"f8a1e9b889b54aa412dd406bcac3cf21\"","$:/temp/appear/Writing Hypertextually-1646321229/block//dataset":"\"e33f709f235a70b5594204443163e0af\"","$:/temp/appear/appropriating,-481949749/block//slider-buttons":"\"e473ec5dacaf266c226056559c198c02\"","$:/temp/appear/appropriating-481949749/block/":"\"865ec9fe9357cbb3b3d83010a66d7e2b\"","$:/temp/appear/appropriating-481949749/block//slider-buttons":"\"5d37b09939f479a91e397526537670b2\"","$:/temp/appear/appropriating337508187/block//slider-buttons-level2":"\"4ec02bd85a3d19f4decb9ab4b448bd66\"","$:/temp/appear/appropriating72351461/block//slider-buttons":"\"4f0eaea6bb44c3cff910ac405b9d5049\"","$:/temp/appear/contributing-481949749/block//pink-button":"\"a4e36278672edb8fc6cd8f362dba706b\"","$:/temp/appear/contributing-481949749/block//slider-buttons":"\"a41db8dd1a5758e9c89dc69242f8296b\"","$:/temp/appear/following-481949749/block//slider-buttons":"\"71b0d9e027407de4087f3d35aa0d5bc4\"","$:/temp/appear/hosting-481949749/block/":"\"857f6ce0b09daeff13ac5d3a3aec676b\"","$:/temp/appear/publishing337508187/block//slider-buttons-level2":"\"62428b53e704f1b5d4a1c4f3d72b410e\"","$:/temp/appear/publishing72351461/block//slider-buttons":"\"24dc77bb17d8bc1782254a2829beb833\"","$:/temp/appear/text337508187/block//slider-buttons-level1":"\"d44e21f62a7276fbb2c8dafd516fbdfd\"","$:/temp/appear/xymphora.blogspot.com-468960991/block//slider-buttons-level1":"\"6a888d637d571a03c8386a45f7e505cf\"","$:/temp/appear/xymphora.blogspot.com1718061363/block//slider-buttons-level1":"\"ffa2e8ef592eec1dd4367fcf5180dbde\"","$:/temp/newtiddler":"\"53ac11a3a1f0bd7c344ed5e43f9e80ae\"","$:/temp/search":"\"d2738336456b5ed5dc0e87f4bd577da7\"","$:/theme":"\"69f84799403e9fe0fdf73cce324181dd\"","$:/themes/tiddlywiki/heavier":"\"d02f25bc9fffb8903211417fe4646f1d\"","$:/themes/tiddlywiki/punch":"\"ee126fa0dddadb3f0a70be4666e483e5\"","$:/themes/tiddlywiki/readonly":"\"3fcb323e909df3a3177b4f04fa99de13\"","$:/themes/tiddlywiki/tight-heavier":"\"60d1406a5a6564ef9b64235803a5bd40\"","$:/themes/tiddlywiki/vanilla/metrics/storytop":"\"9d0ae1939fbdbbef0a0f500fe5417dad\"","$:/themes/tiddlywiki/vanilla/options/stickytitles":"\"fbb9ba70dde8519f13b983eb35f3e375\"","$:/themes/tiddlywiki/vanilla/settings/backgroundimage":"\"8c34a706b49df6f2f7f079ff35aeb45b\"","$:/themes/tiddlywiki/vanilla/sticky":"\"22a94ab65f111299fb99a9fe00d562d9\"","$:/themes/tongerner/emphasized":"\"de929f9040545b9704e1e0d1e7503389\"","$:/view":"\"7dfffa3557327d879ae5c52fac98fbbb\"",".":"\"50bde79fe7b8c43996395599e1a76432\"","11sep2001wherewereyou.org":"\"1d9921a89b1bdda9983bf4a9be08fa5f\"","123-MONADS-BJSpdf.pdf":"\"9ebbb2c760ee5b0f5ab08b431fa125d4\"","1mc.blogspot.com":"\"25153ea98dd3ae0d1ab1e68af387a4cd\"","216.5.68.88":"\"dd859111488d9203bb36a9fdb6373488\"","3-level listing of sites & pages":"\"c208f146f7240787aec50f92da5f419b\"","4.36.67.70":"\"601b3315ac6a5a67be6b113edb11b904\"","45thpeacemakers.de4est.com":"\"38264025ea6cf01d8fd3b499aed378d0\"","64.156.27.17":"\"a31ef0dcb7d9a0f4e433544dbc02c1b4\"","66.40.240.240":"\"ea62ca478a8966387d5df3fcb5cd1a42\"","911 Blog Links":"\"2bb53ded605f0df185675ae0e1f0265d\"","911 Blogs To Explore":"\"63d2f18cf58726e0a5d9fba64e5bfb53\"","911blog":"\"cc3cd7d38c3b675e4a80cf9688dad6d4\"","911blog templates":"\"cc3033f865e06f03fbf9050bdaf95f30\"","911site template":"\"ac17778001748f47f3b9b6c73380af12\"","911sitenote template":"\"ad928f71885e284127ec8949ed151469\"","911sites":"\"72dfe6aa141b160076bba227cdd819d2\"","A Web page that anyone can write":"\"003afacb79906c1ff585c0a3634e5516\"","A collection of images gathered on the Terror Hits Home site's splash page.":"\"45c1e400f8a1c80d35c18590440873c3\"","A fire truck covered in debris at ground zero.":"\"3f30a55a7bff88eb89c24ed746587389\"","A flag hanging in the damaged Pentagon became a symbol of the Marine Corps' strength.":"\"73b597052efda88bcb8efc930af3e6b2\"","A list of the released names of the flight attendants who died on American Airlines Flight 11":"\"db5277be22eab5c73502d99e05320a4b\"","A list of the released names of the flight attendants who died on American Airlines Flight 77":"\"07cad9aff91fd20cb65699bec96993f8\"","A list of the released names of those passengers who died on American Airlines Flight 11":"\"2520663c723c52cef0476cea9174026b\"","A list of the released names of those passengers who died on American Airlines Flight 77":"\"7a73774003433547bb5b06779b2336ec\"","A new article stating that the attacks weren't just the terrorists' fault, it was our government's too.":"\"8b209adc203a5b3674d000296a44fed0\"","A platform for writing, reading, thinking, teaching, learning":"\"a2baa51f7e8639fcad3f986b6b95dc84\"","A priest in California created this banner for the Episcopal Church Center in New York.":"\"648ba748e18f652f2a94591e2c5b6421\"","A rector of Parish of Trinity Church writes about how the world has changed and a poignant moment when his colleague rang the bell at St. Paul's Chapel, located at Ground Zero on Friday, September 14, 2001.":"\"c0326a20dbf5811b85af8240359c0b76\"","A shot of pedestrians shortly after the attacks among debris from the towers.":"\"2c3dd94428435a01f999c7f9713a3ce0\"","A site hosting photos of the 9/11 attacks.":"\"6fc98d60e1d5cbe9636faa11962c1e23\"","A tribute to the rescue workers - a poem over a graphic depicting a firefighter bowing his head with two angels.":"\"a9641fde15d6df8e3d6252a350428263\"","A website showing before and after pictures of World Trade Center displays a photo of the twin towers before the 9/11 attacks.":"\"ce4032d10d226566e469d27a7cf39c55\"","AZSites LLC.":"\"ca443a34707c5da21a2fce092e1e4da7\"","Actors and networks are monads":"\"4b86f0a052b5a05f2420eddffe5b9ab2\"","Actors are defined by networks. Networks are defined by actors.":"\"fc6764dc4a62922120a1cee1d82a0656\"","Add metadata fields to be applied to identified objects in entirely new study":"\"49ad8ce20c1c28369c541de7a15dd3cf\"","Add-on":"\"5923cd575f5e1d11bd054ee6452babf0\"","Advising":"\"d46bc2c494ab8d5c6c866e2d4b599072\"","Advocating":"\"08536270e05b66ad0fe472c66fccc337\"","Aerial photo of Ground Zero shows the proximity of St. Paul's Chapel and Trinity Church.":"\"c549b1ea5127b8fced18827d3293342d\"","Afghan Women's Mission urges US Goverment to resist military response":"\"cae33e74124e03abd931111c962970a7\"","After the U.S. war on terror is declared popularity for Osama Bin Laden increases.":"\"2126b4d049c0b2a87658dbe71be45b3d\"","After the attacks, the Marine Corps reported an increase in the number of Marines returning to active duty.":"\"5320f4ee2bfad5ac1ee70bf52e14bd83\"","Ahlul Bayt Digital Islamic Library Project":"\"7a9973bd71551fbbfe1c111fa55928c4\"","Airwise News":"\"048a3396b285a3b8669823733d46bd33\"","Airwise News followed developments in airport security, such as the deployment of National Guard troops at the end of September.":"\"b3186891ee3905d3aa7e6d0bf239c384\"","Airwise News published updated flight schedules for major U.S. airlines after the attacks.":"\"2f7d4fdb944637004dc786064385e9bc\"","Airwise News reported large layoffs by airlines in the weeks after the attacks.":"\"6b8461399c4cf99fa0ace7690e67269b\"","Alam, Fareena":"\"2a5c473d182cc53254fe5fd1be1b0fb8\"","Alternative To? Replacement for?":"\"d90cd3ce5b6094843f68a58c224fe59e\"","American Airlines":"\"3f823d1eee85ef4d110e42cf05f65899\"","American Airlines dispatches teams to help families of those affected by tragedy":"\"52b3104c05fdfce5f9350e5253cc788a\"","American Airlines established a separate page with updates related to the terrorist attacks and plane hijackings.":"\"a1e0e4277d07a850d69fd84f629ed234\"","American Airlines release a partial list of the victims involved in the 9/11 attack":"\"09c468dbc3ecaf5b7c83a0f8785cc81c\"","American: Airlines announced that all airplanes had been accounted for and safe.":"\"5c977c292b824daea52759fffd285873\"","An unknown producer created this page to explain what he suspects about Flight 93. He provides evidence he has found that leads him to believe that the government has not provided the public with the whole story.":"\"71e8fed08a52db2b273791dfb6c7a91a\"","Andrew Horwitz believed that September 11 represented a major shift in American politics.":"\"fbf58b2286d682e28f8c51a0872fb788\"","Andrew Horwitz recorded in his blog his desire to help others.":"\"06231d501bb5b1e43991a42168b75863\"","Andrew Horwitz treated the first anniversary of September 11 as a day of reflection on the shock and confusion of the tragedy and what followed.":"\"9fc3ee486112bc4d16eb65ea53c65a34\"","Andrew Horwitz witnessed the tragedy firsthand and recorded his disbelief and shock as events unfolded on September 11.":"\"5fa2b154a9baa1ce9ebc46e83475860d\"","Andrew Horwitz' blog dedicated a separate page of entries to the disaster at the World Trade Center.":"\"012233fa3976e47a2e67c58cba3aa5e3\"","Andrew Horwitz' blog revealed an interest in learning more about the World Trade Center and how this tragedy could have occurred.":"\"3df10f93d22384f50b434a7624795658\"","Anhold, Jon":"\"adfd468fcf5d29e3b66e41ba5f537c43\"","Anti-military":"\"8e6b0c33d6cdf5b3022b60072b056551\"","Appropriating":"\"9f02a5f16cbc632863407a462f9f6333\"","Arab American Jounal posted article reporting on leaders appealing to people to not lump all Arabs/Muslims with the terrorists and their perspectives.":"\"8fc596a457f0b7c734df8fdd59d1fbcd\"","Arab American Jounal posted summary of individual rights as provided by the National Lawyer's Guild.":"\"7298ef8baf8c39710550654ee1348698\"","Arab American Journal posted Attorney General's statement regarding Arabs and Muslims":"\"905a9b3dc109ed23947db0b68f831a51\"","Arab American Journal posted prayers for peace from several different religions.":"\"2faa02755c425db410ba3473fc0cfa13\"","Arab American Journal posted response to support offered to its community.":"\"7f50282e6d51286a026b57476d3f6d93\"","Arab American Journal posts patriotic content":"\"0d651044633a62e3369cfa5ba442b5e9\"","Arlington National Cemetery":"\"654e8e54fa77c8725124b0e35af2ba81\"","Articles categorized by source on the Evergreen State College library site.":"\"2c67910cc308bc070b76da09dff8aeb8\"","Artist posted patriotic images":"\"343cc05af970257245e4caf69f06508c\"","As early as the evening of September 11th, search and rescue dogs were used to search for survivors.":"\"bf3b190e72981e4f91dfaa73ec88f1d6\"","As the war on terror begins overseas, American Muslims face tensions at home.":"\"093f9380fb65c54eb89c97068696a1eb\"","Assessment & Presentation of Set of Observed Pages":"\"47197fccfaf7467ba655dd1929cfadc7\"","Assisting":"\"812fc245e6d890d6af79b5a0dc34cfcd\"","At the end of September, the FBI released photos of the 19 hijackers of the four planes that crashed on 9/11.":"\"601d69079b614d736253600509bac085\"","BPC's Emergency Information site allows users to check names of people reported safe or missing. They can also upload information about the status of safe or missing people.":"\"20ce23b931089bd935c8a1930524710d\"","Background":"\"81394217cfa8a40faef60d621746e025\"","Battery Park City":"\"93146b84756b661ffac82879aea90ee6\"","Battery Park City's site links helpful information to its residents about environmental concerns caused by debris from the 9/11 attacks.":"\"3d529d7f7fe8a82e1e82261c70be9609\"","Ben Fritz, one of the three founders of spinsanity, reports on a New York Post editorial board blaming the Clinton administration, and the Monica Lewinsky affair for the 9/11 terrorist attacks.":"\"b632d4078683a10854543a4e9a7fdd20\"","Ben Fritz, one of the three founders of spinsanity, reports on a column written by Robert Scheer claiming it to be invalid.":"\"aaf0086f4f3536274891f4ad78dfc180\"","Ben Fritz, one of the three founders of spinsanity, reports on an article in the Washington Post written by Jim Hoagland that uses victims as a rhetoric shield to make is position more powerful.":"\"cbe22f4a31373b929665d9c2e51c3c05\"","Ben Fritz, one of the three founders of spinsanity, writes an article about the importance of rational thinking after the terrorist attacks.":"\"dc5d85f18f22e517943205ee79f16109\"","Blogger posted various quotes in response to 9/11.":"\"ba925d07df0d24e583e7f02ee009a369\"","Bloggers such as Andrew Horwitz reported their feelings of shock and dismay on September 11.":"\"e24cdc49f8c5f696637abb9abbd15a07\"","Both WTC in NYC are hit by planes on 9/11/01":"\"0a848224522d54b1f67f3b107908f1aa\"","Branch":"\"88609334703b38f73f3cd96e2a023fac\"","Brendan Nyhan, one of the three founders of spinsanity reports on Andrew Sullivans attack of leftist opponents of the \"war on terrorism\".":"\"e418969a199b0c62a7914aa842f50bca\"","British Prime Minister Tony Blair's webpage spelled out the case against Osama bin Laden.":"\"b81fd485db7963d594551a62ed21fd68\"","Bryan Keefer, one of the three founders of spinsanity, writes about Ann Coulter's positions on profiling, and deportation.":"\"02f130ad54a918dd5847fea05498bdb3\"","Bryan Keefer, one of the three founders of spinsanity, writes an article about Michael Kelly's position on American's against the war on terror being pro-terrorist.":"\"f0b31937893b2dfd379983ca972ff237\"","Business":"\"9766351db89d08b177ad50a784088fce\"","Catholic University Students held candlelight vigil for victims.":"\"98326a67b57d59960eb0437808f8fe70\"","Catholic University of America":"\"0515f9e4893dee1c0e0331934665989c\"","Charity/Civic":"\"e20fc71f8f0e69e0a60bf18bb3e691f5\"","Christopher Fahey shows photos taken from his roof in time sequence as the smoke became closer and denser.":"\"e43cd18bd50530b4320219206cd478aa\"","Civilian casualities of the war in Afghanistan.":"\"717ce3d93ac3d5dcac7332d223f73c12\"","Columbia Business School":"\"2d74ab27a98898bf0429b3e8f0f27a9d\"","Commondreams.org reports on prospects for Afghanistan's future":"\"6aa05f37c4394087389b6183d0428fac\"","Compassionate Friends -Atlanta Georgia Area Chapters":"\"00cb9b1fe1a6df01fcc55ccce07355b4\"","Components":"\"b47dd2a33e63e9037a5c11958fd197ab\"","Condemming":"\"4940858b80e0accac57bd1df551f1dbb\"","Connecting with others was an important coping activity after September 11.":"\"522cb2ff557fecd80c8442b6e69d28bf\"","CourtLink Corporation":"\"d755b1afd38e0ee0e89e9dc1053d1bef\"","Create Cell Tiddlers":"\"d224800fdfb2202d40244d1909617ee7\"","Crediting terrorists by calling a 'crime' a 'war'.":"\"1a23dc40d9c9e9d3e49b60c698189163\"","Crosstab of Objects Sharing Two Characteristics":"\"ab5cb7b7677be1622f63b9ea18c9ef84\"","Cynthia Malaraan captures images of the planes hitting the World Trade Center from her bedroom window.":"\"f855420b077fc8b3ac15ca0d428d9d00\"","Cynthia Malaraan displays a collection of photos to memorialize the view of the NYC skyline from her bedroom window before the attacks.":"\"5dd84c368855a1355c290e7201cfe85d\"","Cynthia Malaraan displays photos of the changed NYC skyline and the 9/11 memorial lights shining into the sky. She also explains how the attacks caused the intent of her website to evolve.":"\"bc0a2ab9e1190c5094313738c64fbdc7\"","Cynthia Malaraan explains that her series of paintings are inspired by her memory of the skyline from her bedroom window before the 9/11 attacks.":"\"c0cef2b9d830bdfd4507ecf58a8c6d77\"","Cynthia Malaraan reflects on 9/11 one year later. She displays patriotism and hope with her own painting of the United States flag.":"\"d7c9db64dae379217d65a411f4e60de8\"","Cynthia Malaran reflects on 9/11 and how it hurts her to view the many missing persons fliers throughout NYC.":"\"71dd8174ef4944cfacfb2e6c57b97bff\"","Data and Analysis Preparation":"\"e092b3ca55ad856bb4eba9e519a39717\"","David Pawson posted a sarcastic response to an email sent him about the significance of the number eleven.":"\"7386d7378a1f8f241167def60e928532\"","David Pawson posted a story mocking the fear of anthrax contamination.":"\"2878fbdb1647a0a0bae264a56fd333e4\"","Debris from the towers after the attack measure over an inch off the ground; papers and even personal belongings are blasted far away from ground zero.":"\"9c9951f35395f4098398e47dfd34ad96\"","Dedicated":"\"c3556c5477b4c5344bce36e956642d55\"","Demo 1: Producer Actions in the post-September 11 Web Sphere":"\"c1ca0c67f2891c3619ace8ff40156fe5\"","Demo 2: Identifying and analyzing archived Web pages":"\"4e00bb8400aec40fe71a573c97e9a8b3\"","Demo 3: Integrating TiddlyWiki with the ODU Toolkit":"\"ddceb6d75d715f3ba02c975b255f0fa6\"","Demo 4: Images after September 11":"\"e44840a92e1c2f7f4026d8292ef7df98\"","Demonstrations":"\"799cd9f00aa3897a53ff22901052fb43\"","Department of Civil Engineering at The University of Sydney":"\"3b78e812c3adef2fa5b6e2fe47791047\"","Descriptions and photos of the missing were posted online.":"\"0f61a37428cd49da37367edad4e6e667\"","Digital Methods and Monadic Exploration":"\"9d4906235a3aee1ecfdbd5f9d0ae8a57\"","Digital Methods and Monadic Thinking":"\"ea000ed5c90c4f104a226c4dfc8e0463\"","Digital Text Cycles":"\"dfd1b25467f71a543576bc4f63cefb03\"","Digital traces afford navigation through overlapping monads constructed through shared tags":"\"763d40f3b11998d29e23ced3757dc303\"","DoughertyWebImages":"\"441b2f20bfeac575bf7324654f2f54cf\"","DoughertyWebImages template":"\"2ba4854458eed2cd0175576eb2b57d14\"","Dr. Muqtedar Khan called upon American Muslims to address extremist Islamic philosophies.":"\"5adb78f918967e76cf497543c02dc15e\"","Dr. Muqtedar Khan published a column advocating for unconditional condemnation and political and social unity.":"\"28b13c5c2ebfb66a757732c3819bfecb\"","Dr. Muqtedar Khan published an article explaining relevant details of Muslim theology and issues with the US.":"\"5ad07809634764fa845c6e071e1adc5f\"","Dr. Muqtedar Khan published article demanding Muslims step up and not tolerate extemist activity and expand their perspectives.":"\"f2b1ae3fabad8bc994117c1ec69961f0\"","Draft of '$:/core/ui/Buttons/home'":"\"04556f36b2d419215851e516463953ab\"","Draft of '$:/core/ui/PageTemplate/pagecontrols'":"\"964ecb6d7dcfe4ac5be924f2aef1aef3\"","Draft of '$:/plugins/eucaly/popuptagger/macros'":"\"697888feef4154d05038e4119cb94e85\"","Draft of '$:/plugins/tongerner/toolbar/sidebar-button'":"\"1db3c51ce6ac5e6142acc415b660ab1d\"","Draft of '911 Blog Links'":"\"7b01ca6166d1da0d3648671b7bebb17d\"","Draft of 'Digital Methods and Monadic Thinking' by steve":"\"a76c097f7be803c60e72c8662a7b70f3\"","Draft of 'Emphasized theme'":"\"617503a4a038b01e725b1792653c1743\"","Draft of 'Navigation to Pages Sharing Two Characteristics'":"\"4cfdd865a0ceaeae6b6b7c69693aef61\"","Draft of 'New Tiddler 1'":"\"25b65c3fe9e247eb88a8b206e7249af0\"","Draft of 'New Tiddler 2'":"\"36293c6d8ff0b00727305a24a6fd2853\"","Draft of 'Web images after September 11, 2001'":"\"1f14dfbd8e96fc160b76d08601606371\"","Draft of 'Web pages tagged Branch and Charity/Civic'":"\"8bec10e6ab27177d5e785a3caca20113\"","EduHound":"\"10fb58ab547422a5441678c75712d452\"","EduHound creates a ribbon for others to download in support of the USA (patriotism)":"\"e32fc5f3c5d4b91e2bb2281b4aebe7af\"","EduHound expresses sympathy for those touched by the events of September 11":"\"ee4fb2cfdd0a14c0b2a5e7a9625bf165\"","EduHound links to sites to help educators with the tragedy":"\"01b676c333b81faeef0dd04794e634f6\"","EduHound posts a flag graphic on their website to symbolize patriotism":"\"61ba9da9c288a506e00ad535c6801de8\"","EduHound provides links to news sites about the events of September 11":"\"c38c35e2479c75d2093b1ea979a27583\"","EduHound provides links to sites where someone can lend aid to those affected by the tragedy.":"\"c17a53c45c4e4b156ca755d176756eae\"","Education Week":"\"e3610dc3cea93cb5f8c8a1548a592017\"","Educational":"\"5dc27fa4d67ff1100c6170e12ebb5f86\"","Electronic Privacy Information Center":"\"0969ab75460684a300ab82fa6b4ea122\"","Embeds the grammar of hypertext in the punctuation of writing":"\"18599a109a988826e2713904472a0937\"","Emphasized theme":"\"004f56e155ab8ea9140478f522912455\"","Engaging in Web Sphere Analysis using Monadic Thinking":"\"17634a55863cfcf4ddb2d7a8d09fdf62\"","Epiphany Lutheran Church":"\"a39add30c5bf8e915156ebbc762d3b10\"","Episcopal St. Paul's Chapel, located yards from Ground Zero, became a haven for rescue workers providing food, supplies, chiropractic services, and more.":"\"a59286ed1a293bfdeab26c3f34f58e7d\"","Events of September 11 presented new challenges to teachers nationwide and required creative ways to help students to cope with the tragedy.":"\"6fcbe7a7fe1bc16794c28c7b09dedb7d\"","Evergreen State College":"\"47f9d5611365add465e186c199b5310d\"","Evergreen State College linked to a photo gallery of the Pentagon attack.":"\"1c2a753ef8b35d3b47d73164e8e36f8f\"","Evergreen State College linked to the Department of Defense's Casualty Update reports.":"\"36a98af340095417224dd7d462718447\"","Explaining":"\"e1f333a2e671579e2061cf835a02cc8f\"","Fahey, Christopher":"\"7018b33bdaa8a7e9d56c22ae35435016\"","Fareena Alam, a British Muslim journalist, expressed her reaction to the attacks in an interview with Newsweek.":"\"6fc0dc5a2800fbcc84671e44ee9f7c5c\"","Fareena Alam, a British Muslim journalist, suggested that the world not jump to the conclusion that Muslims were responsible for 9/11.":"\"b9a074fe7236950ad029edd4c094f9ca\"","Filtering":"\"13184b65fead02ddc0cec147aa180332\"","Fire fighters walk through all the dust, building materials, and debris which cover everything surrounding the twin towers after the attack.":"\"495f79bd6b55a1a62b6d6cb902e85c5d\"","Foot_Schneider.pdf":"\"25d3fc1936588ea623cfa26cc0c9a5d7\"","For the Westboro Baptist Church, the tragedy of September 11 was further evidence supporting their belief that God hates America.":"\"393bad84b9906ce2b15189ed743c89f7\"","Four Words":"\"fedd6b31d4d1946817664f8a7c7383e0\"","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the explosions following the impact of the airplanes.":"\"b4e5551b481e862e859c6d830c8f8119\"","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the impact of the first plane.":"\"bb607f31b6efe1785f14c0deac5d2644\"","From her office window, photographer Sara Schwittek was able to photograph the events of 9/11. This image shows the smoldering remains of the World Trade Center at 7 AM the following morning.":"\"ec9b3a793ceb050149e1355afdbf2251\"","FrontSlide":"\"7c99ad51f632e84b2762619b17c3f83b\"","Galleries of quilts that were donated to raise money for the Families of Freedom Scholarship Fund. The quilts are categorized as Symbolic, Patriotic, or Spiritual.":"\"5a120489e434b7b09b61fb99098e0da3\"","Gallery of patriotic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"\"fd97700e43fb9bbf7d4a1bd669a8a5d5\"","Gallery of spiritual quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"\"85ccdd83876096c518c3aedb82c46a36\"","Gallery of symbolic quilts that were donated to raise money for the Families of Freedom Scholarship Fund.":"\"3dd9d749bb073e4687fda85e493bfc10\"","Gary Hunt's \"Outpost of Freedom\" believed that the events of September 11 should be understood in relation to instances of government intrusion such as the siege of the Branch Davidians in Waco in 1993.":"\"b7605d87ef55f3e36ed37237bec6626d\"","Get Started with TiddlyWiki":"\"ea499b90e4ea1bf35df7927b1f92c269\"","Get started with TiddlyWiki":"\"5b87a246bab93619f4229d3a1de7333a\"","Government":"\"e3f9175025885953046b3d007a2a9d6e\"","Governor Pataki moved quickly to provide financial assistance to New Yorkers affected by 9/11.":"\"d40428b57c8105d5314f42e0ed76b71d\"","Graphic":"\"305d0e40cc7c8228374c4affbed0ad25\"","GroundZero was a memorial site built but Native New Yorker, Tony Tonns.":"\"546aaddf0e4217074f92fc1f0d0f2eee\"","HERE IS NEW YORK asks for volunteers to help with their image archive.":"\"05852569536bea12331aa24492efd6bc\"","HERE IS NEW YORK explains their purpose of selling photographs to benefit children affected by the tragedy.":"\"cbb3a1b11d3fa2e9bb886c795f45951f\"","HERE IS NEW YORK gives directions for uploading photos.":"\"a767f5f0464fd27f62808d974ff6319b\"","HERE IS NEW YORK is established as an exhibition to display photos from the tragedy.":"\"23abf80db9084a9510b153569a3c4081\"","Haller, John":"\"06af3340847c18321d94c223c27add2b\"","HashTag Macro":"\"2379b333467166c0708d7ca51b560dd9\"","HelloThere":"\"2caf89a3124100b9249c0bb282e3b584\"","Here is New York":"\"7de573ef5c60aac0dfd431742b5336d0\"","HillesundTextCycle.pdf":"\"a519c41c5b8d4ab4669e73219ce64055\"","Hindu Unity":"\"17e4ce321bdf22acdd86f7bb130c6c9d\"","Hindu Unity warned that the religion of Islam itself, not only fundamentalism, posed a threat.":"\"a33076ca9bbf238cba1be011b4a576d3\"","Home page of the United Way America is demonstrating ways of helping and a list of major donors to the September 11th Fund.":"\"8d3750f87b5887fde5cba40a9f2e042b\"","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. A quote from Abraham Sofaer from The San Fransico Chronicle article is shown.":"\"71c82feeb4cbba6d9fe810240829eeef\"","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Shelby Steele (The Wall Street Journal), and Thomas Sowell (The Washington Times) are shown.":"\"e724c59e3fb59750ceb425628ee862f6\"","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Steve Johnson (The San Jose Mercury News), and The Baltimore Sun are shown.":"\"03a2c1de248b90a12bd11d01bb8020c4\"","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Thomas Sowell (The Washington Times), and Marc Sandalow (The San Francisco Chronicle) are shown.":"\"9eb0c5c5e9128552a96cf7bce4465fe6\"","Hoover Institution hosts articles from Hoover fellows condemning the terrorist attacks. Quotes from Susan Sward, Elizabeth Fernandez, and Bill Wallace (The San Francisco Chronicle), as well as Ronald Brownstein (The Los Angeles Times) are shown.":"\"cb0c9515a2c73f8a6a7c4d9408562138\"","Hoover Institution on War, Revolution and Peace":"\"4c1da04592e6c93fd2a59f83cfd43053\"","Horwitz, Andrew":"\"486c2e29d52173b467ebf5a1e4b1bd92\"","Hosting":"\"79cc3fe96f7f53d5003c404d3df18d6b\"","Hugh L. Carey of Battery Park City Authority reflects on the events of the past year, thanks supporters, and encourages a return to normalcy.":"\"0e184e6a645e88d4bc4101767029d452\"","Hunt, Gary":"\"2f91f469f8a2d46ca46151369bf7eff6\"","Hyper":"\"b3df7718667e2e4731d34be274fbe4e7\"","Iconic image of fallen towers posted at entrance to website.":"\"3e2cd31d3dd8c4c90e72a07088cc1436\"","Identify and Define Analysis Tags":"\"9e6dbf1104ddf33ac955f1a706811c2c\"","Images of September 11 on the Web":"\"be693f36dd68036c4c5874baac39ec3d\"","ImportedRows":"\"673dd0df72eddc77cbf1bd448fe0763a\"","In response to superstition about the significance of the number eleven, David Pawson posted a widely circulated sarcastic piece.":"\"1e4c7fc70e958d82557f25f8f7ff7cd0\"","In the days after September 11 the NY.com site hosted a list of possible missing persons from the World Trade Center. It relied on visitor participation to update information.":"\"4bd01e088c909e2526f21d0d7e11c142\"","In the days following September 11 the NY.com site created a list of the missing at the World Trade Center to help people find each other.":"\"22ce23244d356f4dcaa16945b544453c\"","In the days following the attack, the Westboro Baptist Church was among those who interpreted events in line with their beliefs.":"\"191b7250c7b88b75c1ee88f9c3a8b8b5\"","In this new article a columnist writes the attacks of 9/11 are crimes, not grounds for war.":"\"55241cc0d7729e9e81d7916c3009f2dd\"","In this webshot the producer discusses the evidence that leads him to believe that the military was involved in bringing down Flight 93.":"\"d820b8c1e1e0e5633b594bca1b3a095f\"","In this webshot, the producer discusses the probability that a bomb exploded on Flight 93.":"\"d80bc12a246e5d60726395c8d6351e53\"","In this webshot, the producer discusses the probability that the passengers of Flight 93 worked together to overpower the terrorists.":"\"8a56505fa55f04e63417a11223ffa27d\"","Individual/Volunteer":"\"39bdf5a5f2af11c6380d9ee49b49c2f5\"","Informing":"\"4555771006ad045553163f5309dbc0c2\"","Jessamyn West was among those whose flight was grounded after September 11.":"\"1edbac1dd57b67101294eace275b85c1\"","Jewish Family & Life Media Inc.":"\"ed648e4c2a3ec1054b0a823439625587\"","JewzNewz.com suggests in their \"Take Action\" section, that every Jewish home have a Yahreit candle burning memorializing the loss of life during the 9/11 attacks.":"\"153139af76054efd78fd2bf02d17f759\"","Joe Sobran is blaming the United State's foreign policy for the attacks and hopes for peace. Sobran is thankful Al Gore wasn't our president.":"\"4b074f0ca2387bceeca237bc070cea24\"","Joe Sobran responded to angry emails he received about his columns.":"\"a114ff01cf78cc6f608ea87c75d18adf\"","John Haller created WorldTradeCenterAftermath.com as a central resource for emergency , victim assistance, and donations contact information.":"\"6c3f0a8b478fd5a949622be754203003\"","John Labriola gives a first-hand account of his story.":"\"6840bcd16cb5c9538dbe1007a94e1713\"","John Labriola links to the red cross for help":"\"614cd328adfd0de238dcd57dc9ed885a\"","John Labriola provides a quote from The Art of Happiness written by the Dalai Lama.":"\"7ca33ccaf6631c9bd0f27e07443927f7\"","Jon Anhold creates a website to collect eyewitness photos, provide a guestbook to upload sentiments, and links to organizations that need monetary support.":"\"6e204f56a13e79890495c1c24631b334\"","Jon Anhold hosts a cartoon showing us how the attacks have pulled the country together and made it stronger.":"\"a9e3e797c6c404902704f43e270ed680\"","Jon Anhold hosts a photographic of the second plane about to collide with the World Trade Center.":"\"98381516d9b78fb9c13681059c697ee4\"","Jon Anhold hosts a picture of the Anchorage Daily News front page for 9/11/2001.":"\"df0aaf0c08aecb560b8af7742120f171\"","Jon Anhold hosts a television screen shot of CNN's live coverage of the terrorist attacks.":"\"a787e078c16fad1aa557410b26a426f2\"","Journal of Arab Students":"\"11c8c17cc98a88f48ae8a25fc5ebcb10\"","Kendall Clark report on how Bush will use US Code Title 10 to move swiftly on the war against terrorism":"\"2d844f5f9c0469eef793defc2820408c\"","Key challenges for scholars working with archived web pages":"\"4a1b5c825ef691f464cc46827923ec05\"","Khan, Muqtedar":"\"703b36d977d222fcf8974083117dff58\"","King, Cory R":"\"c92bf0b7379b1d1121bf6747570ee812\"","Kolb2009OtherSpaces":"\"2fa58e1b93745243a7d333b1d4b15b9f\"","Labriola, John":"\"11bca8a03c1a4f2dd853e6d774a79668\"","Layout adjustment plugin":"\"8ff5e408ddff72ed3503196928311a78\"","Learning Hypertextually":"\"f048bd5a77e2340edf93da9d2dab4f77\"","Librarian Jessamyn West's blog dealt with September 11 by linking to resources, especially those library and information-gathering themed.":"\"17d1ef9ca3e4d762cef369c43a2fcea0\"","Librarian Jessamyn West's blog linked to resources and other sites' perspectives on the tragedy.":"\"ecf523e5411cb319f1928e3501ddb41d\"","Linking":"\"1e1833d2c60a914f43ef9f035aca898a\"","Links to resources for those looking to volunteer, donate money, or need assistance.":"\"aec4f1a1ae9ecc6fb89aa0be0f89858f\"","Live":"\"5d042e58d635ae10e2338aaec8905516\"","Lonely Planet":"\"02583b9d454e57efaa9df4013abd339c\"","MIT Community reacts to 9/11 events by publishing links to resources to help fundraise, volunteer, or participate in discusion board.":"\"b04d8863defd0d4a886d0e48cec21732\"","MIT builds replica of World Trade Center wall for community to honor and memorialize victims with flowers or to take time to reflect on 9/11 tragedy.":"\"c772e6ed986acf487b11c406bcf6712e\"","MIT community reacts to 9/11 events by creating a linked page of resources and scheduled activities.":"\"7a299715c5d3ad6aff91ab64a7e9fd4a\"","Malaraan, Cynthia":"\"ccaf7cd137504f76b2d4a4fc4d62d4d7\"","Many New York State security concerns arose after the attack.":"\"f7193045c17ac6070cfe214e04da7034\"","Many organization offered help and support to students, parents and teachers.":"\"68404f12ba8a13c83105a9b8ad663d60\"","Many photos of the attack, taken from various sources, were published online.":"\"aeb24653ed8a18190677149c1ceb606b\"","Massachusetts Institute of Technology":"\"b63cfbb01821fb8740c3fb702f62a665\"","Masterclass":"\"b69d60ae4003b2d3c76b21216ffb9c88\"","Memorial page from the Arab American Journal":"\"e938ba9c44a51b6db4d6736117e5223b\"","Memorial site posted collection of links to similar sites.":"\"0e9c348162c15d3dd62cf58bdc31b8cb\"","Memorializing":"\"cd3aefcc89226fdc15ba5794cbd748c0\"","Message of sympathy and response by American Airlines.":"\"9866864aa9167ddcab97c2c43f50ad2f\"","Monachos":"\"c4154b2df790b66d4f701e28a09698a0\"","Monachos is providing links to prayers and hymns to help people cope with the tragedy.":"\"a35212ccb09cd2dcce534f53ccbc1a39\"","Monachos.net offers Orthodox responses to the attacks, including prayers and hymns.":"\"bebeb149650e3ba61aa9b1d455115665\"","Monadic Exploration":"\"348ffddcbda3fb51d968e539458ea0f8\"","Monads are expressed as different ways of navigating through data sets":"\"8812c04ec9c1fc50befb783f5bf9f2ff\"","Mosque invited non-Muslims to attend lecture.":"\"ffe1324087196e262c3759a3f1364031\"","Multi-dimensional":"\"61ce52cb2b7179850b318795f8849738\"","NY.com":"\"3bd21c0a9644117cbdc13f277db9677e\"","NYCstories.com":"\"409539ec291465aa6f3a7b963931c854\"","NYS Emergency Management Office":"\"d5560ed6eb1c114ea20137f3928f5a1d\"","NYS Emergency Management Office posted links to relevant third-party sites for further information and assistance.":"\"9037c6974cdb3d8db85629de1aa94477\"","NYS Emergency Management office posted recovery assistance resources for public assistance workers.":"\"0762d8f029ba64f202dc84ee613d7669\"","NYS Emergency Management site posted initial statement from Govenor Pataki regarding the World Trade Center attack.":"\"1224c2ac33c7d9be2d1b62f410f5e0a0\"","NYS Emergency Management site posted relevant phone numbers.":"\"6389bdf870de5feb425d4560ee956c70\"","National Underwriter Company":"\"ad89d3c7cd5b96f23dc023652d223a4e\"","Nausea Manifesto":"\"dc4967e596a065ced6000a9518f39652\"","New Tiddler":"\"c647c6f25540833ffcb5909477fbe88e\"","New York State Division of Military and Naval Affairs":"\"e12acfddf9cfb18592bb4c7b7a01e50d\"","New York State continued to issue security alerts weeks after the attacks.":"\"ae4bea2353e8246c7aaf480622e80fc8\"","New York World Trade Center Memorial":"\"7f6096cc3ba9bda9e09608527549f649\"","New York World Trade Center Memorial displaying patriotic imagery and links to news and the Salvation Army's Crisis website.":"\"53e32d123f45fdf93da7ee39c70df246\"","New York World Trade Center Memorial is providing links to other memorial websites.":"\"f34e391f3fd764090df735d5638b092d\"","News article reacting to President George W. Bush's national address after 9/11.":"\"c05ab52cdff2875be3b9e5b612762b4f\"","O'Brien, Heather Anne Davis":"\"45184a9aa7442269a8ea069dc0ebfa4c\"","OCRT encourages assistance in the form of donations to the September 11th Fund by United Way.":"\"6bc4f52ea2224617b3fa8b965daf703b\"","OCRT encourages religious tolerance and condemns the actions of those responsible for the attack.":"\"5eb3939e804421afd5ce9c707de440b1\"","Object-oriented Historiography":"\"37347e598421eabce24ec13cb3a5e0dc\"","On September 11th, Airwise News reported that the Federal Aviation Administration had halted operations at U.S. airports.":"\"1ddabec559e13c813b830378a937989d\"","On September 21, Airwise News reported a $15 billion government compensation plan to bolster the airlines and offer some liability protection.":"\"5d22b536b4f37ec7c1b22f0904a30122\"","On her official homepage, Senator Hillary Rodham Clinton made useful information available to those who wished to assist others after the tragedy.":"\"c261f025902b2dd9f8b2adfb81aab251\"","On her official website, Senator Hillary Rodham Clinton posted the text of her statements in Congress commemorating the efforts of New Yorkers who responded to the tragedy.":"\"76f80c9d2ec9362e33c3753702889773\"","On the first anniversary of September 11 Andrew Horwitz reflected on his sense of gratitude for being alive, for sharing stories with others.":"\"1622a603663de960de6ee6bef737cee7\"","Online directories and memorials tracked those missing after 9/11.":"\"df388da14acac5bae9c8305567fa2360\"","Ontario Consultants on Religious Tolerance":"\"8066b6974a3b3dae314f21dfd07c81fe\"","Open Source":"\"ec7ec6deaf1c830570262bfe786ef33a\"","Outline":"\"8d7eb6ed9d56341f15f2074ee00863cc\"","Pataki posted messages of support from iloveny.com on site.":"\"b6ad6cb9e2498554e357829388525f92\"","Patriotic and memorial graphics were published for visitors to upload to their own sites.":"\"6db99cb67ec213fd3267032c650259a0\"","Pawson, David":"\"5aeafd22b2e9ab83cb00a0fc4812c7d6\"","People's Poetry Gathering":"\"89c0267446925eca774786486b8a0693\"","People's Poetry Gathering hosts a collection of poetry about the 9/11 tragedy and supplies upload links for contributors.":"\"41706f1368f359b331b6638bb8e0c726\"","Personal blog reflecting on events":"\"54907af809d6634f4f509271947358ce\"","Pet owners were sometimes able to return to their homes in closed areas downtown to rescue their animals.":"\"cfdab21bf86a327f1a2255a5890330b1\"","Photo":"\"a02d211dc4494ebeec6b0459da61b9ec\"","Photo of St. Paul's Chapel with firefighters gathering in the debris. Note: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"\"b1d671f892216db1e738e8cb1272304c\"","Photo of demonstration":"\"566e4f2fc0b08cabc9ac04483bd9d51f\"","Photo showing Trinity Church in the foreground and the World Trade Center in the background.\nNote: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"\"4879ccd1284ac84b49da7003b6f26542\"","Photo showing the collapse of the South Tower from a nearby building. Note: image missing from archived site was found on current Trinity site: http://www.trinitywallstreet.org/news/photos/5":"\"f6abf46f61167295f46e4b3946f909bf\"","Photographer Sara Schwittek captures images of fliers requesting blood, information, and supplies.":"\"39fbabe48403101ccf8065f4f1df2913\"","Photographer Sara Schwittek captures images of patriotism and remembrance.":"\"993b17f30a35f9eff0a81f1ac0cbb1ec\"","Photographer's pictures witnessing the first plane crashing into the towers.":"\"25507b885bd87fbd9e6dd19c931db12c\"","Photos of President Bush and smoke billowing out of the World Trade Centers are part of a collection of images Evergreen State College compiled.":"\"1268ee43476a0a750d9ce8ca65523b0e\"","Pipes, Daniel":"\"4d8dbc5ddc685db8c3d2772975b8d4f7\"","Poll illustrates opinion of around the world in/out of favor with a trial or a counter attack.":"\"5851ec84c7380e4684f9193496c9ffbc\"","Popup Tagger Tiddler":"\"b60fbc4098882ade48a7db6825f54a9a\"","Practices":"\"dd5ba851a89e5cd26b4c5b30dcda8ab9\"","Present":"\"0682682a35bea442c9bc33c833e448bc\"","President George W. Bush's speech makes good points about the 'enemy' shortly before declaring a war.":"\"b17952cc332c8ad2ef88e8f2082c4eba\"","Press release from US Commission on Civil Rights":"\"5b47989b29a6e380bffc737e1d6d8d17\"","Principles of monadic thinking":"\"d8a2186f6876cbd978d3ae1a3eaa6bee\"","Producer":"\"26f03fd745b9042658125de4b2f7bcbd\"","Project Pitch":"\"725f82df5ed1a54aa9e99a9c20eae0ad\"","Prosthetic Monkey":"\"1ad59151a4082cb43b90bed9b2dd07ad\"","Public Interest/Advocacy":"\"a66cb736281d61144157098ffa8d034d\"","Published photos honoring those who served as first responders.":"\"e8b6f3728ca622cb9067960efec1915c\"","Publishing":"\"e6f993a79f93de707197c581f400ecb6\"","Quilt4America":"\"8bab39ceaa922a107b760daebd643230\"","Quilt4America publishes an idea to help memorialize victims by creating quilts designed by the American public. Quilts are then given to families in honor of their loved ones.":"\"76a3a9483a6928db94b1c2585cc9ab8a\"","Quilts.com raises funds for victims of the tragedy.":"\"2f43025348bc1a8e580ad075e4b4702f\"","Rayhawk.com":"\"1e3a2ac6e8848b8c42117be47dff2f5f\"","Reading Hypertextually":"\"fe37719887be4bc3586eef31a7b3707b\"","Readings":"\"b5de4f552cb6ee300d0d943daf18d382\"","Readings template":"\"6860b2874818c878f642cd7cc58319ce\"","Reflecting":"\"c0d802e85574e3a85f4147581c3c129e\"","Reflections on #dmi17":"\"1fe95053a2f7f505f0691c9099f918ba\"","Religious":"\"45c1275c3fc5ba624394b013558abf56\"","RenameTags":"\"6bb61e62ce7e37cb3b26e9ab4565a64e\"","Reporting":"\"7caa5d4476a0f26cb6c92da5d062cab1\"","Research Question 1":"\"513eb8bf1785a4481578fd8402b4968f\"","Research Question 2":"\"30980455139f16aa2b53efc5bb28e08a\"","Research Question 3":"\"831648ce61565ddea0fedbac27f6a0e8\"","Research Question 4":"\"3fae476b8c124dd5d6879b9da326429e\"","Research Question 5":"\"0b691db8fdfdf2594dc9ef146e53cecd\"","Research Question 6":"\"0c68e5a2ca921678385ebf88c1aa7990\"","Research Questions":"\"ad1298f6998fc5184280b20a10e65d2c\"","Resources":"\"4986e1125a0ecd39608d598b90637266\"","SEE/Afghan Women's Mission":"\"92cb7e05768465f0af068ad663cf2385\"","Schwittek, Sara":"\"26b541c1f9436f482837daa65665698c\"","Senator Hillary Rodham Clinton":"\"958ef43e5753bad53da46a83f8493b4a\"","Senator Hillary Rodham Clinton echoed the the sentiment of unity many felt in the days after the tragedy. She voiced her support for the Bush administration's response to September 11, repeating the refrain, \"You are with [us] or you are not.\"":"\"fc7b577b81896deeb8e745bb24ca3ed7\"","Senator Hillary Rodham Clinton's official webpage displayed numerous links, phone numbers, and other useful information for finding loved ones or assisting recovery after the tragedy.":"\"ddb89dc345666947b019c505f939ac9f\"","September 11th Victims' Relief Fund":"\"84c8a54d68549faafee6573131999782\"","September11":"\"c12ef1e26e13f4c0e59636035fef9411\"","Simultaneous declarations of war by President George W. Bush and Osama bin Laden.":"\"d917d0992e53af13f5a96630b21bd5b8\"","Single Page Application":"\"32a63bebe9bf044a1acaf082d915d6ac\"","Sit posted feed from webcam aimed at Ground Zero.":"\"efdf44b81b2e140e1e00ed4c1005f2fa\"","Site Listings by Attribute":"\"71cbfadffb4ae3aac4bc3b0302083d74\"","Site Listings by Attribute 1":"\"d9c1bc95813dca575866dcac4bc3f26a\"","Site chronologically listing the events that transpired on September 11, 2001.":"\"2d351ecb0ebb3df278fafb860ed17a5a\"","Site featured images of missing persons with associated contact information.":"\"8bf25a2f2fc96424e18a0259516a5d17\"","Site posted links to 3rd party donation sites.":"\"87ee4b362ac7ddcd1d1603337e78ccf9\"","Site posted various links to 911 missing person resources.":"\"72d51470f34b48180503966da0717847\"","Sites linked to patriotic music and information about the American flag.":"\"2e372555eebf654d4867661822e9f79a\"","Sites listed hotline phone numbers in New York City to help find the missing.":"\"aa4af0920f9f923d985f95be12e62c5c\"","Sites posted photos of victims.":"\"1b481b3262d60223e2574de0ab354059\"","Sites such as Gary Hunt's \"Outpost of Freedom\" argued that September 11 was the consequence of the United States' actions throughout the world.":"\"6c00e1745f5f570ef137ffdf866da3af\"","Situating the Case":"\"dc9a3cc47b4dde8f99c18bf3ab1f940f\"","Slide1":"\"1b399c7f6131179d3a37cbc12bae9b19\"","SlideShowMacros":"\"fbff71941d46bb851b3111728843b87c\"","Slideshows":"\"5ed28ee9871d530a9d1764a521845e09\"","Snark":"\"a505ef7c955d59202272a6e92a91e6dc\"","Sobran, Joe":"\"38bea72efa65db9c542be79e6202cd08\"","Soon after the attack, Senator Hillary Clinton's webpage posted messages of condolence that likened the tragedy to the surprise attack at Pearl Harbor.":"\"1c49e2673390fdedba6733a2140b6dcc\"","Splash page of the New York World Trade Center Memorial. Visitors are encouraged to leave messages for the victims family and friends.":"\"e45077af28819ada76c5a1b284cdbf66\"","Splash page of the Why Project - a site devoted to art about the attacks.":"\"382e959b6cc319c251fe25b850bbc8a3\"","St. Paul's Chapel spawns a new congregation as rescue workers seek nourishment - both physical and spiritual.":"\"53d1b7723542bcbfd7e76d578618ea06\"","Stott, Reid":"\"9a2a89d0db3550f6ba935fa513566626\"","Strategic Forecasting LLC":"\"de892d6f6b4c2207dd01e3547747d0b9\"","Stray animals around the World Trade Center site were rescued by the AnimalAid program, established by United Animal Nations.":"\"a217ccce5c50382f2be3f03337800d69\"","Symbols often speaks more than words. United In Memory: 11 September 2001 symbol represents many efforts directed to remember and reflect on the events that happened on 9/11/01.":"\"31aa7d74479130ca2c55684769abcd30\"","Syndicated columnist, Joe Sobran, writes about how the terrorist attacks were a reaction to US foreign policy.":"\"0c8f1e4dcf732a68fb76792ccdbfd0c6\"","Table Attributes":"\"9fde992ce2143771a5f24a8944ce29e8\"","TableTiddlers Template":"\"500b4f99ad034fff746f100e93a32bfc\"","Tagging":"\"5e2f41d40d723a2ee5c9f3d448c4142a\"","Teachers respond to tragic events trying to provide their care to children and ensure safety":"\"4bf354226282b25b80aaef3c89685d9d\"","Teaching Hypertextually":"\"0c6a744e61deafc2a3ccf39161066268\"","Techniques":"\"bb5b125c08e2d444ea56ab17a0104fcd\"","Templating":"\"c74833381b9661c2209bb1aced72be15\"","Terror Hits Home":"\"1cedf9bc9257a57164de6f608aabbd17\"","Text":"\"3932be6c8661fc35b166995d829ad77e\"","Text Hyper Wiki Tiddly":"\"2dc4ea432d1fd0dd322649e53a2cbc69\"","Text in this webshot describes the materials and structural system of the Twin Towers. A graphic illustrates a typical floor plan within the building.":"\"ca405414bf7539b49b65486953cab742\"","Text in this webshot suggests one possible explantion as to why the supports of the building collapsed after the planes hit the Twin Towers.":"\"5b43d3485489a355c612e197b670a033\"","TextStretch":"\"9c4e6114fc00ce5ea6ae6a0b31346e16\"","The Ahlul Bayt Digital Islamic Library Project answered questions about Islam and terror, and demonstrated that the attacks of September 11 were un-Islamic.":"\"65c23867c935236ef7f78c018033a5f1\"","The Ahlul Bayt Digital Islamic Library Project condemned the terrorist attacks as un-Islamic, citing the Quran to support its contention.":"\"d87f9c250bc0405f314d61c1d6e8c2c3\"","The Ahlul Bayt Digital Islamic Library Project displayed the sentiment of former President George H.W. Bush condemning anti-Muslim and anti-Arab prejudice.":"\"b521143b7fd105079623c1de54381f04\"","The Ahlul Bayt Digital Islamic Library Project provided links to text and images demonstrating that terrorism is un-Islamic and showing the sympathy that Muslims throughout the world felt for America's loss.":"\"07d226a8018aec0d46a20c2f920580aa\"","The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children grieved for America after September 11.":"\"0a07cd4fcedbc6e918c2fc3476d397bc\"","The Ahlul Bayt Digital Islamic Library Project showed how Palestinian children shared America's grief after the tragedy.":"\"67738eb952773c375d8ccea7810feca0\"","The Ahlul Bayt Digital Islamic Library Project showed how Palestinians grieved for America after September 11.":"\"8edc7cf91606aefa54a27e8c3e68e167\"","The Ahlul Bayt Digital Islamic Library Project showed images of Palestinians grieving for America after September 11.":"\"a4984596f7f55384f1acceb1b74e0041\"","The Ahlul Bayt Digital Islamic Library Project showed images of unity between Muslims and Americans.":"\"a6df0dc4bbea7fbc07acc34e9b07d9ab\"","The Ahlul Bayt Digital Islamic Library Project showed the ways Muslims around the world grieved for America after September 11.":"\"1a03c4cb9360d077902ad0b94f082ed6\"","The Ahlul Bayt Digital Islamic Library Project, a site devoted to teaching visitors about Islam, published its response to the tragedy on a separate set of pages.":"\"2e0a3f9bf92907e1af337a115b9ea16d\"","The British Muslim Fareena Alam posted a Department of State chart showing that in 1997, Latin America, not the Middle East, was responsible for most global terrorism against the U.S.":"\"24ecb212eed7bc0bdb7c0050c3524032\"","The British Muslim Fareena Alam re-published many articles on her website questioning who was really responsible for the attacks.":"\"1cd9914ca1a8876145de3481bf57af5e\"","The Catholic University of America hosted a lecture about Islam.":"\"73ce9350d039340a925997702bd56bdc\"","The Catholic University of America published the speeches made at their vigil.":"\"16fdc51ab1e538c3be3ef4c8c5279914\"","The Catholic University of American sent a letter to parents detailing their response to the Anthrax threat.":"\"1ee864b734b6efa1c4d75e2caa53d271\"","The Chief Executive of American Airlines recorded messages for employees, and the airline posted the text of the messages with a phone number for those who wished to hear the message.":"\"b8dada7f202487480494fbdf03210940\"","The Columbia Business School reports that their entire student body, staff, and faculty are safe, and lists a variety of useful information regarding the return to normalcy after the 9/11 attacks.":"\"06e8cecf0a97b8114cd5e65b204c3044\"","The Compassionate Friends chapter in Atlanta, Georgia reaches out to memorialize the victims of 9/11.":"\"c6a2c5d3b09dd42a9944dc4fc46f17d1\"","The Compassionate Friends of Atlanta, Georgia appropriate photos showing the workers at Ground Zero":"\"536e3bd7deb1917704f6a074055559b8\"","The Compassionate Friends of Atlanta, Georgia share the front page of a newsletter from another organization.":"\"6f95da45e7fce8d8605dd5571c4336f7\"","The Compassionate Friends of Atlanta, Georgia, displays a flag in solidarity of the tragedy.":"\"a06f10fce8e39b8e21d7c08848212d6a\"","The Compassionate Friends of Atlanta, Georgia, displays a photo combining a crying eagle with the Twin Towers.":"\"f2860e3d10a9d7a750c63d99c4f83e00\"","The Department of Justice warned that they would prosecute those who perpetrated false anthrax threats.":"\"05c256663ca80cc87ffab8f93eb140c5\"","The Department of Justice was responsible for enforcement of the new anti-terrorism legislation passed in the end of October.":"\"55807a296a65f603cf4f6780adcaa577\"","The Episcopal Church":"\"3ae2de09c4624839c475274cd277d17e\"","The Episcopal Church organizes a relief effort for the rescue workers.":"\"9f94d763061638ef6e057817eb3a7d81\"","The Episcopal Church posted this video of the Seamen's Church Institute which provided meals, socks, aspirin, shirts, for the rescue workers at Ground Zero hours after the attacks.":"\"eaf624cc41b7eb359900c3051bb202f9\"","The Episcopal Church responds to the attacks.":"\"ab66a7f2cb217c80ff98198bf963206f\"","The Families of Freedom Scholarship Fund is raising funds for the children and spouses of the victims.":"\"a5835bcb71e775b621f0e03208240b54\"","The Federal Bureau of Investigation released names of the 19 hijackers of the planes that crashed on 9/11, and requested information through a hotline.":"\"60626b77818ad2650dbbb0bd6b3b67c0\"","The Interfaith Alliance posted observations of reactions.":"\"d3a95184fb36e92b68eb728fe5f2d27a\"","The Interfaith Alliance urged people to embrace nonviolence, privately and publicly, and organize interfaith vigils.":"\"a217bbed3b11fd47b6e69be2a63652a1\"","The Journal of Arab Students advised Arab students after the September 11 attacks.":"\"5730988a8b5ad3ecc56b23ed928f919f\"","The Journal of Arab Students condemned the attacks on its front page.":"\"3056768d65de336a93caacde8d76b30d\"","The Journal of Arab Students invited students to attend a memorial for the victims of the September 11 tragedy.":"\"2d3ef719fb1e667a4ba3528f40d31591\"","The Lonely Planet, publisher of travel guides, hosted a discussion board devoted to the topic of September 11.":"\"ac335c54e34abcd95e789bf6131d5e4b\"","The NY.com site links to survivor lists at the nyc.gov site as well as other useful information for helping survivors and relief.":"\"caa02d11f006b819f81388c4f698f793\"","The New York State National Guard was mobilized in response to the attack.":"\"27ec3aea72bd66020c1aa4bc4fa28ddd\"","The New York World Trade Center Memorial site providing a memorial message and link to message board.":"\"37233dce1cb2651a760545c89c220faa\"","The Outpost of Freedom argued that the World Trade Center was the symbol of American world governance and the Pentagon a symbol of the misuse of power.":"\"dc76e8b36b079c411c66aec0bac923a7\"","The Outpost of Freedom argued that the first responders, firefighters and police, impeded the ability of victims to escape the collapsing World Trade Center.":"\"540fb33dbc6f625e27616390d21739ba\"","The Outpost of Freedom did not believe the United States had the legal authority to retaliate against Osama bin Laden.":"\"bb52780a5682c3a02496391e0c898b96\"","The September 11 Victims' Relief Fund gave an address where aid could be mailed.":"\"962aa93f6c35a1c852918af4ee31b365\"","The September 11 Victims' Relief Fund links to stories in the news about itself.":"\"f1b4805625bb73cc2cf94289cfeb3cb0\"","The September 11th Victims' Relief Fund was established \"to serve the long term needs of the victims.\"":"\"b036c40e115dd0187f228beea4aba402\"","The Topps Company known for sports cards, creates a line of Enduring Freedom Picture Cards.":"\"b4290bdfc7be4e64c5186dec898fb76f\"","The Trinity Parish, which includes the Trinity Church and St. Paul's chapel, is adjacent to Ground Zero. The church buildings and people were important in assisting the emergency workers.":"\"ab93e5df258499d3309094bc01ecd8a2\"","The USO is asking for donations so they can support the US Armed Forces.":"\"12b400237d88055842a6a2dcc0e3d87d\"","The USO is describing the difficulties our troops face with the war on terrorism and how the USO is responding.":"\"5469c58886f90f403e164cb185f53900\"","The USO is providing options for people to donate to benefit the troops.":"\"bf66625faf15b04ee150346812129fc5\"","The USO is providing services to the troops, their families and communities.":"\"0861ab57fcae24cab05ee898e8659344\"","The United Methodist News Service published many online stories about the ways September 11 affected the lives of Methodists, and how Methodists should respond to the tragedy.":"\"66e2644829745f85f50c8304d38e0912\"","The United States Marine Corps posted a contact number for people to call for information after the tragedy.":"\"5fcca7def13568b4d4947dfd8ab89689\"","The United Way is offering ways to help, shown here Give to the September 11th Fund.":"\"47e00f7e90a9d3bb7884b4bee79f9558\"","The United Way is offering ways to help, shown here Talk to Children and Teens.":"\"453064ec763811950b8057a1dedba382\"","The United Way is offering ways to help, shown here promoting tolerance.":"\"25c7344aff1f6a675353b2fa6ebbbdf6\"","The United Way is offering ways to help, shown here supporting your local United Way.":"\"606c581d39a48544a3e6c18e38623079\"","The United Way is offering ways to help, shown here volunteering.":"\"2ec880bb8d1d01f61b3fb8edc37457cc\"","The United Way's list of major donors to the September 11th Fund and the amount that company has committed to give.":"\"de09d05426610a943f5e15a18650b8e8\"","The Web as an Object of Study":"\"06414cda1c05e2cf8561bfe22c610ef7\"","The Westboro Baptist Church codified its belief that God hated America because of its tolerance for homosexuality in parodies of well-known songs.":"\"f6c5b1b839425b571c7f89eb51be37ef\"","The Westboro Baptist Church posted information about its protests in the wake of September 11. The group blamed tolerance of homosexuality for causing the tragedy.":"\"1f74d102814bcfdea9c122fa5d9e38da\"","The Westboro Baptist Church provided a simple interpretation of events: September 11 happened because God hates America because of its sins.":"\"e45973a98977888c2532697d52f65c7b\"","The Westboro Baptist Church sought to interpret the tragedy using Biblical verses to support the notion that September 11 was punishment from God.":"\"db81f6fe8de318524bf98a84324f893b\"","The Women's International League for Peace and Freedom asked its members to contact Congresspersons on October 10 to urge peaceful responses to the tragedy.":"\"c266879e18b8cc201ea7eb4e75dcea77\"","The Women's International League for Peace and Freedom posted contact information to combat discrimination following Septmeber 11.":"\"ec9a28d229d0c2bc3bfd30364b50e459\"","The Women's International League for Peace and Freedom provided resources to urge leaders to respond peacefully to the tragedy of September 11.":"\"0cccf58498507c5c8339c9bd7421b49c\"","The Women's International League for Peace and Freedom wrote to President Bush and Congress advocating a nonmilitary response to September 11.":"\"a83336240cec52a94fe16581ebd629c5\"","The Women's International League for Peace and Justice opposed war and racism and promoted the values of freedom for all and peaceful responses to terror.":"\"6816c35ca8d32a29cdd6e6e4ba2d79e5\"","The World Trade Center Memorial site published memorial text and images from all over the world.":"\"70108717224a9a641bee035c4721537b\"","The group Hindu Unity accused Pakistan of supporting the attacks.":"\"fccfc84fa022eda9367b231e6683f676\"","The group Hindu Unity compared the actions of Indian Hindus with Pakistani Muslims, suggesting that Hindus supported the United States, while Muslims opposed them.":"\"bf982c396b3ccf5f8aed9dbe0f2df727\"","The group Hindu Unity condemned Oprah Winfrey for supporting donations to Afghan children, claiming that the children were future terrorists.":"\"b7eaeed6840b83219aad298890a5f5c4\"","The group Hindu Unity condemned the attacks and warned against the danger of Islam.":"\"d413dfaf38e9851df7fe21ca6625d168\"","The home page of quilter Carolyn Lee Vehslage highlighting the recent benefit auction for the Families of Freedom Scholarship Fund.":"\"24044344fabb9551c78b0d0b3f362411\"","The site NY.com briefly maintained a list of survivors and missing persons on its pages, but by September 15 had had to remove the list.":"\"fa31873c0450367cb29b14cb5bd3137c\"","The whole is always smaller than its parts":"\"48d2e0971feae3fffb53e83455bbff79\"","There are many forms of grieving and reflecting on difficult, uncomprehending events. Thinking and using thoughts expressed by others may be helpful way of dealing with the tragedy of terrorist attacks.":"\"d326ebbca0ed2db12113483396c49b12\"","There were multiple sites with images of memorial ribbons.":"\"20a105a4cfa7ac0d4ba6f5341fdf5249\"","These photos are part of a collection of images Evergreen State College compiled.":"\"d3753b5703a5d1e6e318d188f3cf89ee\"","Thinking Hypertextually":"\"644443dcfd7b158d3f714649934f26eb\"","This graphic illustrates what engineers think may have caused the steel structure of the World Trade Center to collapse.":"\"f9205bc05d9e2c0fbb2eabf34761caa2\"","This page shares links to a variety of folklore surrounding the 9/11 terrorist attacks.":"\"170787ca33b0019a71d84036ff3518fb\"","This site allows people to submit stories about their own 9/11 experiences.":"\"6f8bb66f35439168084ca2fece6466f4\"","This webshot displays United Airlines' first official statement after the occurrence of the attacks on 9/11.":"\"9ff777e06a53a17d28fdd9bc9f6a5579\"","This webshot displays United Airlines' second official statement only hours after the occurrence of the attacks on 9/11.":"\"951fe43b1289411d02fadabbd4524cd6\"","This webshot displays a link to an explanation of why the World Trade Center may have collapsed from the perspective of engineers.":"\"dda4e46b3f9e08075349ab873402800e\"","This webshot displays a portion of the meeting minutes for Battery Park City's Residents Association. Questions are answered about rent for tenants displaced by damage from 9/11, repairs and cleaning of apartments, and when apartments will be ready for occupancy.":"\"b90c36fa61dad581f064f6b7583f50d5\"","This webshot displays a ten point statement created by the Electronic Privacy of Information Center that urges lawmakers to protect the civil liberties that define the American way of life.":"\"8729a30bf4f0b7e80e3be7b8c978fb18\"","This webshot displays information regarding the 9/11 crashes and assistance that would be provided to families of victims.":"\"376d87e7ef6cbe98daef477baeeaf118\"","This webshot displays part of the list of law professors that support the Electronic Privacy Information Center in the protection of freedom.":"\"3353a7e01aee7aec0c41e802f269c4e9\"","This webshot displays part of the list of organizations that support the Electronic Privacy Information Center in the protection of freedom.":"\"0b159ec394b22fc91ff0c1de4f539812\"","This webshot displays the form that people can fill out to endorse the defense of freedoms in the United States.":"\"213260e991c328e4bbe552bc6b491986\"","This webshot illustrates that the Electronic Privacy Information Center or EPIC feels that despite recent attacks, Americans should be aware and work to maintain their freedom of privacy.":"\"dba2cd41d9fc1341ff6cbd384fc57576\"","This webshot includes stories from eyewitnesses of the Flight 93 crash.":"\"1267d31cc7cf16ef182c19c33fd400cf\"","This webshot introduces Cynthia Malaraan's website which uses imagery and a diary to pay tribute to the changes in NYC caused by the 9/11 attacks.":"\"9eb7f8154f40e1cee6ee321c9c9474ac\"","This webshot provides general information about the engineering and construction of the Twin Towers.":"\"458c5c6b69103edda45824a9cd9f7b39\"","Three-D model of Ground Zero with St. Paul's Chapel highlighted.":"\"fd128a923eb5b0f93bc92967ea74c646\"","Throughout the Fall of 2001, Senator Hillary Rodham Clinton's office actively made information available and assisted relief efforts throughout the various tragedies of September 11, the anthrax scare, and the crash of Flight 587 in Queens, NY.":"\"cc752d90f83bdf4171b7709730756aa9\"","Tiddlers":"\"9b3696eeb10c552ca8d462b415fb17bd\"","Tiddly":"\"206ec3b1b36892f31482a2e1702bac0b\"","TiddlyWiki: A Tool for Monadic Exploration":"\"963d016762f5d29770ae7ce5e22be172\"","Timeline of events on September 11th, 2001 from 10:10AM-10:48AM":"\"d2343482c07e185da4215fe30a636691\"","Timeline of events on September 11th, 2001 from 10:53AM-12:04PM":"\"fcf810f58c69f30807e83f9e7d16497a\"","Timeline of events on September 11th, 2001 from 12:13PM-1:50PM":"\"ecb78f355d68f32828347c632384a846\"","Timeline of events on September 11th, 2001 from 2:00PM-8:45PM":"\"a045d5c57d8ea2c325f44bba05946f6a\"","Timeline of events on September 11th, 2001 from 8:45AM-9:22AM":"\"a1c64af24a7dc42362de21dc35b47c93\"","Timeline of events on September 11th, 2001 from 9:22AM-10:08AM":"\"d975256b7f5ab6a634b0ce3e8e05febe\"","Tonns, Tony":"\"ee10eb0487063ae414c750b080f9d607\"","Tony Tonns set up Ground Zero to memorialize those who lost their lives.":"\"ad1d708b13f152f690e1edcdec774747\"","Toolbar plugin":"\"c8ec165a08a143341ee15b042ee114cd\"","TopTopMenu":"\"ca6d28f317dc76442cb8d36a4318a475\"","Topps Company, Inc":"\"e0ab2a2f35ab41c555d02703af4c6310\"","Toward the Tabular Text":"\"bade37a15a19b26a91e0718770d1b092\"","Transcluding":"\"dada2485b95100b1f5ffd8169b513f60\"","U. S. Department of Justice":"\"b0c42c294ef8e41919319e229193b29f\"","Union United Methodist Church":"\"ab61de9007d3c6ebe84294a7f0cf77f7\"","United Air Lines, Inc":"\"81c218e6a8d07264c7c6d69cc6e80fee\"","United Airlines expresses very limited information regarding the 9/11 attacks. They give their condolences to those affected by the attacks and provide hotlines for those who want more information.":"\"2d2dea3f165af33a89e6183a4bfd3735\"","United Airlines provides links to information about two flights that were involved in 9/11.":"\"201e89043a3e376db2820a947e5bfd78\"","United Animal Nations":"\"e961d1e8ee7120329fd773fd788b56aa\"","United Animal Nations provided assistance for animals and pet owners affected by the World Trade Center collapse, as well as for search and rescue dogs.":"\"c79979f31e0260e25b01fef47d90c354\"","United Methodist News Service":"\"ff57c7c4441677148555358edae18563\"","United Service Organizations (USO)":"\"b8c15d385aa6da956a435d7d38e676d1\"","United States Marine Corps":"\"3f6408d4b56d72c0b515f76e7db4eb3a\"","United Way of America":"\"9c4347fed88ece8a1c6dbf7d951c1f4a\"","United Way's role in the recovery effort and ways to give.":"\"b19705879028b94289c98bfa81fbbd03\"","Unknown,":"\"36acff853a2a089c5e7a73ed543ac472\"","Untitled":"\"8737c8c3e40c502da9daf4f95a6042d0\"","Untitled 1":"\"2bacb66b5b092ac54a6bb570b6fa7154\"","Uptoolbar plugin":"\"7ef9e6deda720f8a30de2d9dd1dbec07\"","Varieties of Hypertext":"\"e1cef6e5d02c7832ca345e375f601db6\"","Viewing Archived Pages in Context":"\"1c73b6c51ed98bb9c8b70d896c04467c\"","Visible evidence speaks even more profoundly to reality if the terrorist attacks":"\"9123b838857ccf10531df87717d5e0b9\"","War actions create more damage, instead should we try to capture and prosecute Bin Laden.":"\"466d17e51d7208d2e74ef43aa9d0955f\"","War will come at a cost of our freedom, but isn't the war about preserving our freedom? Paradox.":"\"7e004be97d2769c1ae75cb89d79743a2\"","Web Campaigning: Web Sphere Analysis":"\"f18c7cca6fd6b7ffd802baa39e8312fc\"","Web images after September 11, 2001":"\"3d43a7ca5aee21ba4d0abcf08497a4e6\"","Web pages tagged Add-on and Educational":"\"907c62c0b39dfd0c1431a633fe3dd9f5\"","Web pages tagged Add-on and Government":"\"06c3dd595b263f37f141db332b7ef74c\"","Web pages tagged Add-on and Public Interest/Advocacy":"\"400f3a0c518c29071ee7f58db517c49a\"","Web pages tagged Add-on and Publishing":"\"3b4e409a3854c69a47452807a07f0fcd\"","Web pages tagged Appropriating and Photo":"\"7df5a0a2861215eb21b19d5d06282ae6\"","Web pages tagged Branch and Charity/Civic":"\"6505f91f981231b3b1b59949ffef6e5b\"","Web pages tagged Branch and Educational":"\"96d309a81b7189599a47fad59a04c9d8\"","Web pages tagged Branch and Government":"\"56cf2eeabc5a9d1199970f0a4238f89c\"","Web pages tagged Branch and Public Interest/Advocacy":"\"e2617c61da94063492876e709d3dfc6b\"","Web pages tagged Business and Add-on":"\"56f3c121756d849f47ad6dfe285a6cb9\"","Web pages tagged Business and Appropriating":"\"5e9d5ef80c467cff796bdd76e27c7348\"","Web pages tagged Business and Assisting":"\"48c3bafa3045a9131ace950da653a715\"","Web pages tagged Business and Hosting":"\"0014d0776552cde5c9c0b98fdd42f9c0\"","Web pages tagged Charity/Civic and Appropriating":"\"ba4d2b0b010ecaf5b07409bfa56cdf07\"","Web pages tagged Dedicated and Business":"\"cd72bda2b8184fb35b330cb36f3791bb\"","Web pages tagged Dedicated and Educational":"\"b8e4feabb1e37d6dd22e7b28001c98f2\"","Web pages tagged Educational and Branch":"\"d58682773a92e0eb12cc7d769fbf6918\"","Web pages tagged Educational and Hosting":"\"6b19776477b469a2d086126c4728aa93\"","Web pages tagged Educational and Publishing":"\"2c5c69b7be098ce4c9a32430f364b14c\"","Web pages tagged Government and Add-on":"\"ca95ee32d8415c1f70512be807e776e0\"","Web pages tagged Individual/Volunteer and Appropriating":"\"4fd24cdda859699d1b80399a59956afb\"","Web pages tagged Individual/Volunteer and Hosting":"\"9c3a7b159df7f786a7c10510f5016bda\"","Web pages tagged Individual/Volunteer and Informing":"\"031e937d7838680934beead3540cfd36\"","Web pages tagged Publishing and Graphic":"\"685a2d10e506f55aa82c888c375a7db3\"","Web pages tagged September11 and Anti-military":"\"8d7daa28a4d062a5df862396a627c635\"","Web pages tagged September11 and Snark":"\"826fc1d7fb870a87c820fa7d4722f354\"","Web-action":"\"97bf170b188e1e9c24c8807374d9cf24\"","Web-as-Object-of-Study.pdf":"\"cbfce7429bfd210671278b0a72c77760\"","WebArchiveInterface Macros":"\"067a93f2e8ed5aa3bbca0739252d78a0\"","Webshot illustrates a producer publishing text condeming terrorism using a religious viewpoint.":"\"96ba742d38676d481ce378c377fe83e1\"","Webshot illustrates a producer publishing text informing how people may join volunteer efforts or contribute to disaster relief fund":"\"d3e2a5699c31c639dbd55b840fa8c1c7\"","Webshot illustrates a producer publishing text reflecting on the 9/11 tragedy in behalf of the Council of Bishops for The United Methodist Church.":"\"8973851def899127859ce564c3cd52e7\"","Webshot shows quotes from various officials reporting on 'hate' crimes around the U.S. after the attacks":"\"06d963484b63b146c9247fbf4bd9b63b\"","Website display a picture from ground view of the attack on the World Trade Center.":"\"753a212476fc849aec86ff5667d08148\"","Website displaying photos of the aftermath of the 9/11 attacks.":"\"5422e0c8f7df6b989719905fa046b821\"","Website displays photos of the second plane approaching and hitting the second tower.":"\"d9a5cc52b9561eac190595c6b3e43816\"","West, Bob":"\"5d7074cf7f81e57e7f769a997241dc95\"","West, Jessamyn":"\"6e6dbfdd12e9e1ad86090000baa9a186\"","Westboro Baptist Church":"\"0da28277430967fcdf70f33a3910df81\"","What is TiddlyWiki?":"\"23120baf13286a53fc8ce3373449eb05\"","While there was a high death toll from the attack, does it mean a war is necessary?":"\"90ca9ec671b6c17f84cc01382f06c8a4\"","Why Project":"\"9b6ca8b3892c1a12e1ae75eeef8111e4\"","Wiki":"\"915a1f92068c491f26477a1a4f24a134\"","Wiki Notes":"\"167c583dd15f2b91b752c0facd2e18c5\"","Witnessing":"\"f823bc0bad8f7de9652171db36c52277\"","Women's International League for Peace and Freedom":"\"3faffd5c3cb5d8a7504ac479da8c008a\"","World Trade Aftermath site listed missing persons hotlines/phone numbers.":"\"b1f8a2b50c3c62a856c32872de8aac3d\"","World Trade Center Memorial":"\"4fefc2ff4184a0da68b34f02bfa7a119\"","WorldTradeAftermath.com posted ways to donate and/or volunteer and support.":"\"8e53a1fce1fff5d967b5e280ae0357a8\"","Writing Hypertextually":"\"3f7228bb0546423c9f05c7bedba7044a\"","abc.net.au":"\"7abb61857b0688ae881ad4fc0986c56d\"","abunimah.org":"\"c5b03ce3f25666199f4180f867983d05\"","acidlogic.com":"\"e0334e1f84e00ba5c745ebd8fd97c67a\"","afireinside.8m.com":"\"4413d87d909826dcb869331c5f54bf18\"","afterchaos.com":"\"b58ea5216126816262212305aa9e27e2\"","al-islam.org":"\"fb7c91b07a237217f3803cc600528fb2\"","alltheweb.com":"\"8fe819146cc94ecb5240efe443096d97\"","analysis-field template":"\"e776cfb6313202669504c2ce5271512a\"","angel-art.net":"\"38323cce285450923540cf6bd15954b6\"","annie.newdream.net":"\"9cac1bf43e934720305f5188305cf1f8\"","appropriating Add-on":"\"ab830757348890139e83104b5f970b0c\"","appropriating Branch":"\"0dce27e3df0c51e65f89643118144002\"","appropriating Dedicated":"\"4a39c140438177b9ecfab1d096e2806e\"","appropriating Unknown":"\"56eeb14e6658a2a3ae9ddd9a432b6978\"","appropriatingAdd-on":"\"6a3c74a6279519498ba18e33c02d41da\"","arcurl":"\"bbe474250d16ab6f91ddec238f9c41b9\"","arstechnica.com":"\"e4da95e212b939fc4fbd9d22c00f1c54\"","assisting Add-on":"\"ab2c5f638bfa1927823ca53592fb3061\"","assisting Branch":"\"a4253b7b78ac7a15a2f5d30b8d39f745\"","assisting Dedicated":"\"446c65445d3458a4c3e68f303f4fc9d7\"","assisting Unknown":"\"619ddac6ed5fd0d51b29d4bcc874a210\"","assyria.nineveh.com":"\"8d73e681d582b1d8f9b558c94f788b26\"","badvogato.org":"\"2b2b888a51ea0e562acb5327f8b85386\"","bbs.cbsnews.com":"\"b28f9f3a78647e6962341bdd2a33965e\"","billdrew.net":"\"175fb1d346980380c18c40fa249516eb\"","blahblahblog":"\"948b55d5ff0c26ce1e92d0f097101764\"","blog-cells":"\"e169c1be0f5ca5c45fcac0c3cc291b5f\"","blogstalker.blogspot.com":"\"e2ab0dfc4ddd066142c95c3c33754e49\"","boards.educationworld.com":"\"8f466dd1f051c35bcd31be1cbdf3a75b\"","boards.heartlight.org":"\"73f66bd7e03b04a1e3dae8091d42dcd9\"","bovineamerica.com":"\"3d22e06fea0c5a125047add6b574decc\"","cagle.slate.msn.com":"\"9490e2823b9a95d0a8b08699901dfff0\"","catholicdirectory.org":"\"9377c8cec5cb35faa64f9d826ccd05f7\"","cdr.flavorj.com":"\"d815dc4124654c628fb7173cc751b28c\"","cells":"\"452be86169ac8ab7659c7edae625eadd\"","chat3.suresite.com":"\"acbe03c5d92e8d2244e8da29a4609a58\"","cinchouse.com":"\"2d9eb3812d5a22de1434e90c42ff791e\"","clkoberg.com":"\"5990e340b06d2bacf9529c0b4bc8288e\"","commondreams.org":"\"7fe54338c44b01a9c54e91d1d2ba6cd8\"","community.cnn.com":"\"417c21e0c96d3d15c69db68d2689d3f9\"","content-action":"\"dad24845842b819e8f3986f221f83596\"","contributing Add-on":"\"5724ac53da65f47db37cb7b7d810ca81\"","contributing Branch":"\"b32f0e7073072af580deafdf832325c6\"","contributing Dedicated":"\"92d5b1c6a04ad71377a86ae3711fba53\"","contributing Unknown":"\"cbf4438d29553516b95a606e98a902a1\"","csoakley.com":"\"c0dc15b4cfec031cc6fff719464411fc\"","date":"\"808d6c5a2910f1b605895e29f952a003\"","davidgrenier.weblogger.com":"\"97716d9fa0ba40aa95f9f0403d6ff299\"","demotag":"\"bfda33a699f5101c8beea6a40d3bea97\"","discussion.canada.com":"\"7bdc623712d5b46e1c358224e0a22703\"","dork2014monadic.pdf":"\"4739392e010ee8bcb275311cac7816a1-2\"","drifters.net":"\"bb9a274e12c2b3f445a3af1b4dfdb3ce\"","drop-d.com":"\"72664ba5979c7f25868532f7ae72dc31\"","dump":"\"055151392d0cbf2072c43d95376f0328\"","eastwest.nu":"\"9a7c096029eb98d293e8e2d02eb288bc\"","emc.elte.hu":"\"4ac16efd3c42c48ab831a3ba1da62b8b\"","emperors-clothes.com":"\"4efb6df24d2e2db5d00a431c1fbe1767\"","end":"\"775055a94b6ad5b402e269bb2d4d8f42\"","english.planetarabia.com":"\"15d5261a065157e9aad97d23c688296b\"","evilfluffer.blogspot.com":"\"354dca52d4b38c4eddfbc6b4ef322901\"","federalreserve.gov":"\"a355b69287dcbe2d2d62ba2b6870e6f1\"","following Add-on":"\"98a2a12644bfca11415baf74e71d20ce\"","following Branch":"\"9da9aef0410107a73759726b0255c150\"","following Dedicated":"\"aacb607ee6807c881dff8b2870b623d4\"","following Unknown":"\"be5c1b4d0f963954b371252a7a37698a\"","fray.com":"\"65558cc92948586396438b9caa1d0c62\"","gemm.com":"\"28a8fa6eb45b61cd9498d0259c24604d\"","genehack.org":"\"45e7a36737e1905dffd06b7f820affcd\"","geocities.com":"\"a917e0863314be07d07f6b392820f950\"","goodnewsaboutgod.com":"\"5607ced05bbdfc1a73fe2f64d26c2354\"","home.earthlink.net":"\"65287191d46a0fff1a84baa2de99cc1a\"","hosting Add-on":"\"24d8bbc03382236446808b6e66109a03\"","hosting Branch":"\"8764d73162df3e5c176518ac22848428\"","hosting Dedicated":"\"971340ad11249ffe4b21a0e97407dca7\"","hosting Unknown":"\"0fa0c80e16898d7f23b6c6bd3f6d5c38\"","islamic-city.com":"\"47fc7d95cce4d29c6b2670419d2ce0fe\"","jfg.girlscouts.org":"\"d2bdb431125f0ee13853f6c8d3cf53ff\"","jish.nu":"\"76b6aad363c82833fb17cf5bd1b8674c\"","justicemail.com":"\"c1abbbbe36749d8197767d1b31bb93ac\"","kottke.org":"\"8d4de162d95d050b148cf47d2e8df978\"","lawandeverythingelse.com":"\"6d784fef82c7c384a334d28b4d422d83\"","lightacandle.sol.dk":"\"aa120499be878ecf45a28fd61a4c353f\"","linking Add-on":"\"a7652c447ce6a76eac203af63a7afdaa\"","linking Branch":"\"c7f3bcbe210bbdee05e7fd07ade53b74\"","linking Dedicated":"\"2f6549dc45ad6fdabb99c4e8a97da02e\"","linking Unknown":"\"3cf5da798063c7cd70e4a61269d2c983\"","local host wayback page":"\"1fb438f3fd85b6170548f5b53baeadc4\"","manson.exodus.net":"\"debe6baa120b48eb8a70abf564525817\"","medium":"\"362aecbe587c66fbf22e0ef5752569d6\"","menic.utexas.edu":"\"f080c51b6862e8de60f69e186ff8667c\"","my.webmd.com/roundtable_topic":"\"464e1982e7cf3f90fe0814ca57218a93\"","mystory.inter.net":"\"5f87080abaa2a800844593145be694d8\"","navbar":"\"7c5a168895004b7470778f0ee41f6002\"","ncccusa.org":"\"7cef61acc992621858e9aed3431633dd\"","nebraskasynod.org":"\"7721eabab8177d1cea1c07fb695f86ed\"","news.bbc.co.uk":"\"e57c9fe4dc1343b08b7984439b5ad345\"","origurl":"\"0cfd4a48c0d8029395ff43d1496af9ff\"","pages.prodigy.net":"\"e3b84ad7330bfead9a9b0058aede5e83\"","papertoys.com":"\"922e6de1a0084484a0f455b0c8caffaf\"","pew-internet-report.pdf":"\"13549bb121aa59078286e5c0fe9152ba\"","producer":"\"f4a7419624f12269bae65a07dce15c63\"","producer-approach":"\"24eeebec2aa7b984e4463cb531b636f7\"","producer-name":"\"a37facf6b446817785bb5467ea8f19fd\"","producer-type":"\"9bb67ee3b3dfe1f96eccda0c521a072a\"","pub84.ezboard.com":"\"edab93a7f38759c912fe6907ff0b085e\"","publishing Add-on":"\"438820423b95c81ee1e9404e336ae8db\"","publishing Branch":"\"12362221d5cebf4ff033bd522fd762b0\"","publishing Dedicated":"\"e3afe917b1d4221e5b785eb3648f65f5\"","publishing Unknown":"\"02a9fbb98e0c2f6f28c9236ea03ee175\"","publishingUnknown":"\"9c669a8caf6ba478e74c110ca0ca538c\"","remember.worldatwar.org":"\"d191673ef83ed37a1404cfdacc8d66ad\"","safe.millennium.berkeley.edu":"\"1d0e93345f1df35bc3a902cbcea6cf77\"","scripting.com":"\"0a249af515724def2d5b638e1f98556b\"","show":"\"0887b4342192d5fb6abc6c8d8ac23a7c\"","showdox":"\"10264c646511f26150da9e04e2cea6d3\"","specials.msn.com":"\"adad54fe291c8936c9bbf1d11c5d3b33\"","spinsanity":"\"f8c47b4db72921f12f939a92e80b4f10\"","stylesheet":"\"d2e678d96643d4220c2e603595cfbfc0\"","sunews.syr.edu":"\"9cb29038f0ccc4572428fe085f4b352e\"","tabletalk.salon.com":"\"f406ab9989f853d8fda62609c8e7ddbb\"","tags":"\"45d45ecc13b0f2f2abf26622166df6aa\"","temp blog post for testing":"\"644b1c17ece74c5b3db36eca2d1d0b14\"","terror.joshstorz.com":"\"65f749b6a4529492aa9321a61665a525\"","thankyou.fast-networks.net":"\"a4750e7de25d8272d457a7d79b2729d1\"","thegospelzone.com":"\"48455ec57999b2eeecf7e50d2adae82a\"","thetruereligion.org":"\"8d182cb3fcaff2c9b746d544bef62428\"","title":"\"2869c00a72ef1b8b61bd3b5f719eb5bf\"","us.geocities.yahoo.com":"\"c7de83dc93b26c84e55620a0c49b66cc\"","vandendorpe15.pdf":"\"08a25a61cf117639add76f47f91dcc75\"","vandendorpe8.pdf":"\"40ffaa72880ee08153d81ac003f81ae4\"","web-action":"\"b838fb2d79d9102f15706b01f8f4d6f6\"","web-campaigning-pp27-35.pdf":"\"37290ffb40263ba3c750001cdc198a91\"","web.mit.edu":"\"fe0149957ba99feb8c311f3f9d06a845\"","wherewereyou.org":"\"4e7f1b4e723fc2620a9014d18de15e46\"","worldtradeaftermath.com":"\"88f37ad23dcfa35358d167d11b918854\"","wtc.blogspot.com":"\"638f3839cf0b0dd617192b8cfd5afdae\"","wtc.chats.co.il":"\"93197efe45e368de578389111cfdef04\"","ww.blahblahblog.com":"\"5ad26b968d1027ce1c719bea0166960d\"","www.99dogs.com":"\"e5c32102d7832f3902d06db1d5f04126\"","www.abc.net.au":"\"6eede4e626418de4577ebbcc7f4d8c0f\"","www.afghan-network.net":"\"f9db947774df078bdd209c4e78133d25\"","www.alhewar.com":"\"ecb568f4a04f7785e9a5004d819cdebb\"","www.ambushsite.com":"\"7f8ad2e789de062a5f277a1d921b29f8\"","www.appleseeds.org":"\"261bf828b0e7753f4cefbc2bfdaffdd5\"","www.arabamerican.com":"\"53384fdb60afd0e308197376e167606d\"","www.attackonusa.f2s.com":"\"03498acda19a241ffc39fd0585fc0138\"","www.bettingonamerica.com":"\"1b251e0ad70fd1e021e52fda24a4a0d9\"","www.broward.org":"\"4c22b5b123836f257a8d60fe19f14aed\"","www.browardschools.com":"\"31677bf1dbc921ba3d2c892fd8075c36\"","www.cjf.org":"\"5b8222635589b5e25fb473f185248a29\"","www.deafdate.com":"\"07d2cd5023089fafdd8a320f0db8bc0c\"","www.disastercenter.com":"\"2d550b9093bae74f2d7ed44976e2775e\"","www.edc.org":"\"29a5d4d10cded347a07018fb7414954e\"","www.educateamerica.org":"\"17a5ee5abc5caace8d97a3a803547525\"","www.episcopalchurch.org":"\"4bb5d574c6e161651448af2934e08a97\"","www.fourthturning.com":"\"e26735903464eae6407b85612267e2ba\"","www.geocities.com/american_freedom_91101/":"\"8a4d9357d163ccffce84771d32d85d6f\"","www.geocities.com/athnsios":"\"fbbc36594ad4eb2ee871003b5f4c6f03\"","www.griefnet.org":"\"15cc1dad9cf14a08833342b10e5579da\"","www.harbus.org":"\"a8190212b3493850fc711655041438fe\"","www.heartlight.org":"\"152a0988ae69ab68c2f13d686a39494b\"","www.hezb-e-islami.org":"\"09c6d69a952b7b0a6153edba51cb18ae\"","www.hinduonnet.com":"\"8706b198bcede9cd2c554659c1013de1\"","www.howard.edu":"\"ff479570ad54df3487b54e05d85a8bc5\"","www.iuinfo.indiana.edu":"\"1f09f1bd9747328d351a5aa7759f8661\"","www.javaranch.com":"\"80a9337b05686a737c8980e4734693e2\"","www.jish.nu":"\"7f12550e1fbb62cb69a6b824f39f3e01\"","www.likeanorb.com":"\"aa150d9012d979469a127e827b008826\"","www.middleeastwire.com":"\"094690fbb9827684a76fa1d714727dd7\"","www.nacc.org":"\"94237b5f4ae0df222b50312ce56590de\"","www.newsday.com":"\"ff4e496e7d0a4f8a263767f4adce22cd\"","www.newyorkworldtradecentermemorial.com":"\"8730ef0855d40351c75c341388e03cc7\"","www.paul.dube.net":"\"bcb1ad38ad1b02a18c5dce36803383ac\"","www.pentagondisaster.com":"\"60ce5057d39e292664175715c931d28c\"","www.powerlineblog.com/archives/2017/06/update-and-thoughts-on-the-scalise-shooting.php":"\"9ba5c1ac497d62d47b0c9b5d1ccde5be\"","www.poynter.org":"\"93c366bc997b0fa207e79863245d807b\"","www.ravelly.com":"\"186d0c4849ade1f3d1b1ea0fbe7ff59e\"","www.september11news.com":"\"f694cdfea8fa90c8348592b6a8d4f4e2\"","www.sfsu.edu":"\"4dabec53f0aaf913c67980a8a147aab9\"","www.siworld.com":"\"88399951d83b9ed1629a8bc9fed74d09\"","www.specwarnet.com":"\"40721fa02dda1a811460f45d3a4928b0\"","www.sun.com":"\"73f2611f846892db167eb69c22ff0133\"","www.theguestbook.com":"\"d960b91148787749d06c15a9211c627a\"","www.thewallsonline.com":"\"909cf90e576244669ffba8a88159957d\"","www.virtualmiracles.com":"\"209f8e9dcd2e053ab313354bd4871908\"","www.witchvox.com":"\"4d9369955130c254033777c8e58b07fe\"","www.witchvox.net":"\"c3d77c2d1ead3ab9dedbbee1377fdbcd\"","www.worldtradecentermemorial.com":"\"82a6ac513ce26d07b1280ce843b4abc2\"","www.wtcbombings.com":"\"96e3e7945d30ce61ee7a6e4670321ec2\"","www.wtchope.org":"\"fe00f3517dd211e5313d99dda47b90a7\"","www.wtcmemorialquilt.com":"\"fe97105b2fcfecbd3284dca064d99b97\"","www.zahov1.f2s.com":"\"96169c4899ce6e9194aa6662edb598d3\"","www2.arch.ttu.edu":"\"0fb786b2dc1b69afa80b30fff2bc4d86\"","www2b.abc.net.au":"\"6fa7d593ff7c06917f55ed208952931e\"","xymphora.blogspot.com":"\"be57369ac4bf788b27a4a976d120c6a3\""}
{
"tiddlers": {
"$:/plugins/tiddlywiki/xlsx-utils/controls": {
"title": "$:/plugins/tiddlywiki/xlsx-utils/controls",
"caption": "XLSX Utilities",
"tags": "$:/tags/ControlPanel",
"text": "\\define help-button(state)\n<$button popup=\"\"\"$:/state/expand-help/$state$\"\"\" class=\"tc-btn-invisible tc-popup-keep\">\n{{$:/core/images/help}}\n</$button>\n\\end\n\n\\define help-content(type,state)\n<$reveal tag=\"span\" state=\"\"\"$:/state/expand-help/$state$\"\"\" type=\"popup\" position=\"below\">\n<div class=\"tc-drop-down tc-popup-keep\" style=\"padding: 0.5em; max-width: 30em; white-space: normal;\">\n<$transclude tiddler=\"\"\"$:/plugins/tiddlywiki/xlsx-utils/docs/$type$\"\"\" mode=\"block\"/>\n</div>\n</$reveal>\n\\end\n\n\\define renameProxyTitle()\n$:/state/plugins/tiddlywiki/xlsx-utils/rename-$(currentTiddler)$\n\\end\n\n\\define rename-current-tiddler()\n<$edit-text tag=\"input\" tiddler=<<renameProxyTitle>> placeholder=\"Rename\" default=<<currentTiddler>> size=\"50\"/>\n<$reveal type=\"nomatch\" state=\"\"\"$(renameProxyTitle)$\"\"\" text=<<currentTiddler>> default=<<currentTiddler>> tag=\"span\">\n<$button>\n<$action-deletetiddler $tiddler=<<renameProxyTitle>>/>\ncancel\n</$button>\n<$button>\n<$action-sendmessage $message=\"tm-rename-tiddler\" from=<<currentTiddler>> to={{$(renameProxyTitle)$}}/>\n<$action-deletetiddler $tiddler=<<renameProxyTitle>>/>\nrename\n</$button>\n<$set name=\"proxy-title\" value={{$(renameProxyTitle)$}}>\n<$list filter=\"\"\"[<proxy-title>is[tiddler]]\"\"\">\nWarning: tiddler already exists\n</$list>\n</$set>\n</$reveal>\n\\end\n\n\\define expand-collapse-button(state)\n<$reveal state=\"\"\"$:/state/expand/$state$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"span\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"\"\"$:/state/expand/$state$\"\"\" $value=\"no\"/>\n{{$:/core/images/down-arrow}}\n</$button>\n</$reveal>\n<$reveal state=\"\"\"$:/state/expand/$state$\"\"\" type=\"nomatch\" text=\"yes\" default=\"no\" tag=\"span\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"\"\"$:/state/expand/$state$\"\"\" $value=\"yes\"/>\n{{$:/core/images/right-arrow}}\n</$button>\n</$reveal>\n\\end\n\n\\define expand-collapse-content(state,content,class)\n<$reveal state=\"\"\"$:/state/expand/$state$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"div\" class=\"\"\"$class$\"\"\" animate=\"yes\" retain=\"yes\">\n$content$\n</$reveal>\n\\end\n\n\\define up-down-buttons(parent,child)\n<$list filter=\"[list<$parent$>butfirst[]field:title<$child$>limit[1]]\" variable=\"listItem\">\n<$button class=\"tc-btn-invisible\">\n<$action-listops $tiddler=<<$parent$>> $subfilter=\"+[move:-1<$child$>]\"/>\n{{$:/core/images/chevron-up}}\n</$button>\n</$list>\n<$list filter=\"[list<$parent$>butlast[]field:title<$child$>limit[1]]\" variable=\"listItem\">\n<$button class=\"tc-btn-invisible\">\n<$action-listops $tiddler=<<$parent$>> $subfilter=\"+[move:1<$child$>]\"/>\n{{$:/core/images/chevron-down}}\n</$button>\n</$list>\n\\end\n\n\\define edit-button(state)\n<$reveal state=\"\"\"$:/state/edit/$state$\"\"\" type=\"nomatch\" text=\"yes\" default=\"no\" tag=\"span\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"\"\"$:/state/edit/$state$\"\"\" $value=\"yes\"/>\n<$action-setfield $tiddler=\"\"\"$:/state/expand/$state$\"\"\" $value=\"yes\"/>\n{{$:/core/images/edit-button}}\n</$button>\n</$reveal>\n<$reveal state=\"\"\"$:/state/edit/$state$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"span\">\n<$button class=\"tc-btn-invisible\">\n<$action-setfield $tiddler=\"\"\"$:/state/edit/$state$\"\"\" $value=\"no\"/>\n{{$:/core/images/done-button}} Finish editing\n</$button>\n</$reveal>\n\\end\n\n\\define delete-item-button(filter,parent,title,prompt)\n<$button class=\"tc-btn-invisible\">\n<$action-deletetiddler $filter=\"\"\"$filter$\"\"\"/>\n<$action-listops $tiddler=\"\"\"$parent$\"\"\" $subfilter=\"-[[$title$]]\"/>\n{{$:/core/images/delete-button}}$prompt$\n</$button>\n\\end\n\n\\define edit-field()\n<$select tiddler=<<field>> field=\"import-field-list-op\" default=\"none\">\n<option value=\"none\">Set field</option>\n<option value=\"append\">Append to list field</option>\n</$select>\n<$edit-text tiddler=<<field>> field=\"import-field-name\" size=\"10\" tag=\"input\" placeholder=\"field name\"default=\"\"/>\n<$reveal state=\"\"\"$(field)$!!import-field-list-op\"\"\" type=\"match\" text=\"none\" default=\"none\" tag=\"span\">\nto\n</$reveal>\n<$reveal state=\"\"\"$(field)$!!import-field-list-op\"\"\" type=\"match\" text=\"append\" default=\"none\" tag=\"span\">\nthe\n</$reveal>\n<$select tiddler=<<field>> field=\"import-field-type\" default=\"string\">\n<option value=\"date\">date</option>\n<option value=\"string\">string</option>\n</$select>\n<$select tiddler=<<field>> field=\"import-field-source\" default=\"column\">\n<option value=\"column\">from column</option>\n<option value=\"constant\">constant</option>\n</$select>\n<$reveal state=\"\"\"$(field)$!!import-field-source\"\"\" type=\"match\" text=\"column\" default=\"column\" tag=\"span\">\n<$edit-text tiddler=<<field>> field=\"import-field-column\" tag=\"input\" placeholder=\"column\" default=\"\"/>\nprefixed\n<$edit-text tiddler=<<field>> field=\"import-field-prefix\" tag=\"input\" placeholder=\"prefix\" default=\"\"/>,\nsuffixed\n<$edit-text tiddler=<<field>> field=\"import-field-suffix\" tag=\"input\" placeholder=\"suffix\" default=\"\"/>\n</$reveal>\n<$reveal state=\"\"\"$(field)$!!import-field-source\"\"\" type=\"match\" text=\"constant\" default=\"column\" tag=\"span\">\n<$edit-text tiddler=<<field>> field=\"import-field-value\" tag=\"input\" placeholder=\"constant\" default=\"\"/>\n</$reveal>\n<$checkbox tiddler=<<field>> field=\"import-field-skip-tiddler-if-blank\" checked=\"yes\" unchecked=\"no\" default=\"no\">\nSkip this tiddler when field blank\n<br/>\nTitle:\n<$tiddler tiddler=<<field>>>\n<<rename-current-tiddler>>\n</$tiddler>\n\\end\n\n\\define view-field()\n<$link to=<<field>>>\n<$list filter=\"[<field>!has[import-field-list-op]]\" variable=\"listItem\">\nSet field ''<$view tiddler=<<field>> field=\"import-field-name\"/>'' to\n</$list>\n<$list filter=\"[<field>get[import-field-list-op]prefix[append]]\" variable=\"listItem\">\nAppend to list field ''<$view tiddler=<<field>> field=\"import-field-name\"/>''\n</$list>\n<$list filter=\"[<field>has[import-field-prefix]]\" variable=\"listItem\">\n''<code><$view tiddler=<<field>> field=\"import-field-prefix\"/></code>'' +\n</$list>\n<$list filter=\"[<field>get[import-field-type]prefix[date]]\" variable=\"listItem\">\ndate\n</$list>\n<$list filter=\"[<field>get[import-field-source]prefix[column]]\" variable=\"listItem\">\nvalue from column ''<$view tiddler=<<field>> field=\"import-field-column\"/>''\n</$list>\n<$list filter=\"[<field>get[import-field-source]prefix[constant]]\" variable=\"listItem\">\nconstant ''<code><$view tiddler=<<field>> field=\"import-field-value\"/></code>''\n</$list>\n<$list filter=\"[<field>has[import-field-suffix]]\" variable=\"listItem\">\n+ ''<code><$view tiddler=<<field>> field=\"import-field-suffix\"/></code>''\n</$list>\n</$link>\n\\end\n\n\\define list-fields()\n<ul class=\"tc-import-spec-row-list\">\n<$list filter=\"[list<row>]\" variable=\"field\" emptyMessage=\"<div>(No field import specifiers)</div>\">\n<li class=\"tc-import-spec-field-wrapper\">\n<$reveal state=\"\"\"$:/state/edit/$(row)$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"span\">\n<<edit-field>>\n<<up-down-buttons parent:\"row\" child:\"field\">>\n<$macrocall $name=\"delete-item-button\" filter=\"[<field>]\" parent=<<row>> title=<<field>>/>\n</$reveal>\n<$reveal state=\"\"\"$:/state/edit/$(row)$\"\"\" type=\"nomatch\" text=\"yes\" default=\"no\" tag=\"span\">\n<<view-field>>\n</$reveal>\n</li>\n</$list>\n</ul>\n\\end\n\n\\define view-row-content()\n<$reveal state=\"\"\"$:/state/edit/$(row)$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"ul\" class=\"tc-import-spec-row-controls\" animate=\"yes\" retain=\"yes\">\n<li>\n<$macrocall $name=\"delete-item-button\" filter=\"[<row>] [<row>getlist[]]\" parent=<<sheet>> title=<<row>> prompt=\" Delete this row\"/>\n</li>\n<li>\nTitle:\n<$tiddler tiddler=<<row>>>\n<<rename-current-tiddler>>\n</$tiddler>\n</li>\n<li>\nRow type:\n<$select tiddler=<<row>> field=\"import-row-type\" default=\"by-field\">\n<option value=\"by-field\">By field</option>\n<option value=\"by-column\">By column</option>\n</$select>\n</li>\n<li>\n<$button class=\"tc-btn-invisible\">\n<$action-createtiddler $basetitle=\"$:/_ExcelImporter/ImportSpecifiers/Field\" $savetitle=\"$:/temp/newtiddler\" import-spec-role=\"field\" import-field-name=\"fieldname\" import-field-type=\"string\" import-field-source=\"column\" import-field-column=\"Column Name\" />\n<$action-listops $tiddler=<<row>> $subfilter=\"[{$:/temp/newtiddler}] +[putfirst[]]\"/>\n{{$:/core/images/new-button}} Add new field\n</$button>\n</li>\n</$reveal>\n<<list-fields>>\n\\end\n\n\\define view-row()\n<div class=\"tc-import-spec-row-wrapper\">\n<h5>\n<$macrocall $name=\"expand-collapse-button\" state=<<row>>/>\nEach row: <$list filter=\"[list<row>import-field-name[title]]\" variable=\"field\" emptyMessage=\"\n<$link to=<<field>>>(title field not set)</$link>\"><<view-field>></$list>\n<$macrocall $name=\"edit-button\" state=<<row>>/>\n<<up-down-buttons parent:\"sheet\" child:\"row\">>\n<$macrocall $name=\"help-button\" state=<<row>>/>\n</h5>\n<$macrocall $name=\"help-content\" type=\"row\" state=<<row>>/>\n<$macrocall $name=\"expand-collapse-content\" state=<<row>> content=<<view-row-content>> class=\"tc-import-spec-row\"/>\n</div>\n\\end\n\n\\define list-rows()\n<div class=\"tc-import-spec-sheet-list\">\n<$list filter=\"[list<sheet>]\" variable=\"row\" emptyMessage=\"<div>(No row import specifiers)</div>\">\n<<view-row>>\n</$list>\n\\end\n\n\\define view-sheet-content()\n<$reveal state=\"\"\"$:/state/edit/$(sheet)$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"ul\" class=\"tc-import-spec-sheet-controls\" animate=\"yes\" retain=\"yes\">\n<li>\n<$macrocall $name=\"delete-item-button\" filter=\"[<sheet>] [<sheet>getlist[]] [<sheet>getlist[]getlist[]]\" parent=<<workbook>> title=<<sheet>> prompt=\" Delete this sheet\"/>\n</li>\n<li>\nTitle:\n<$tiddler tiddler=<<sheet>>>\n<<rename-current-tiddler>>\n</$tiddler>\n</li>\n<li>\nImport sheet name:\n<$edit-text tiddler=<<sheet>> field=\"import-sheet-name\" size=\"50\"/>\n</li>\n<li>\n<$button class=\"tc-btn-invisible\">\n<$action-createtiddler $basetitle=\"$:/_ExcelImporter/ImportSpecifiers/Row\" $savetitle=\"$:/temp/newtiddler\" import-spec-role=\"row\"/>\n<$action-listops $tiddler=<<sheet>> $subfilter=\"[{$:/temp/newtiddler}] +[putfirst[]]\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/edit/]] }}} $value=\"yes\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/expand/]] }}} $value=\"yes\"/>\n{{$:/core/images/new-button}} Add new row\n</$button>\n</li>\n</$reveal>\n<<list-rows>>\n\\end\n\n\\define view-sheet()\n<div class=\"tc-import-spec-sheet-wrapper\">\n<h4>\n<$macrocall $name=\"expand-collapse-button\" state=<<sheet>>/>\nSheet: <$link to=<<sheet>>><$view tiddler=<<sheet>> field=\"import-sheet-name\"/></$link>\n<$macrocall $name=\"edit-button\" state=<<sheet>>/>\n<<up-down-buttons parent:\"workbook\" child:\"sheet\">>\n<$macrocall $name=\"help-button\" state=<<sheet>>/>\n</h4>\n<$macrocall $name=\"help-content\" type=\"sheet\" state=<<sheet>>/>\n<$macrocall $name=\"expand-collapse-content\" state=<<sheet>> content=<<view-sheet-content>> class=\"tc-import-spec-sheet\"/>\n</div>\n\\end\n\n\\define list-sheets()\n<div class=\"tc-import-spec-workbook-list\">\n<$list filter=\"[list<workbook>]\" variable=\"sheet\" emptyMessage=\"<div>(No sheet import specifiers)</div>\">\n<<view-sheet>>\n</$list>\n</div>\n\\end\n\n\\define view-workbook-content()\n<$reveal state=\"\"\"$:/state/edit/$(workbook)$\"\"\" type=\"match\" text=\"yes\" default=\"no\" tag=\"ul\" class=\"tc-import-spec-workbook-controls\" animate=\"yes\" retain=\"yes\">\n<li>\n<$macrocall $name=\"delete-item-button\" filter=\"[<workbook>] [<workbook>getlist[]] [<workbook>getlist[]getlist[]] [<workbook>getlist[]getlist[]getlist[]]\" prompt=\" Delete this workbook\"/>\n</li>\n<li>\nTitle:\n<$tiddler tiddler=<<workbook>>>\n<<rename-current-tiddler>>\n</$tiddler>\n</li>\n<li>\nCaption:\n<$edit-text tiddler=<<workbook>> field=\"caption\" size=\"50\"/>\n</li>\n<li>\n<$button class=\"tc-btn-invisible\">\n<$action-createtiddler $basetitle=\"$:/_ExcelImporter/ImportSpecifiers/Sheet\" $savetitle=\"$:/temp/newtiddler\" import-spec-role=\"sheet\" import-sheet-name=\"Sheet name\"/>\n<$action-listops $tiddler=<<workbook>> $subfilter=\"[{$:/temp/newtiddler}] +[putfirst[]]\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/edit/]] }}} $value=\"yes\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/expand/]] }}} $value=\"yes\"/>\n{{$:/core/images/new-button}} Add new sheet\n</$button>\n</li>\n</$reveal>\n<<list-sheets>>\n\\end\n\n\\define view-workbook()\n<div class=\"tc-import-spec-workbook-wrapper\">\n<h3>\n<$macrocall $name=\"expand-collapse-button\" state=<<workbook>>/>\nWorkbook: <$link to=<<workbook>>><$view tiddler=<<workbook>> field=\"caption\"/></$link>\n<$macrocall $name=\"edit-button\" state=<<workbook>>/>\n<$macrocall $name=\"help-button\" state=<<workbook>>/>\n</h3>\n<$macrocall $name=\"help-content\" type=\"workbook\" state=<<workbook>>/>\n<$macrocall $name=\"expand-collapse-content\" state=<<workbook>> content=<<view-workbook-content>> class=\"tc-import-spec-workbook\"/>\n</div>\n\\end\n\n\\define list-workbooks()\n<ul class=\"tc-import-spec-editor-controls\">\n<li>\n<$button class=\"tc-btn-invisible\">\n<$action-createtiddler $basetitle=\"$:/_ExcelImporter/ImportSpecifiers/Workbook\" $savetitle=\"$:/temp/newtiddler\" import-spec-role=\"workbook\" caption=\"New workbook\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/edit/]] }}} $value=\"yes\"/>\n<$action-setfield $tiddler={{{ [{$:/temp/newtiddler}addprefix[$:/state/expand/]] }}} $value=\"yes\"/>\n{{$:/core/images/new-button}} Add new workbook\n</$button>\n</li>\n</ul>\n<div class=\"tc-import-spec-editor-list\">\n<$list filter=\"[all[shadows+tiddlers]import-spec-role[workbook]sort[caption]]\" variable=\"workbook\">\n<<view-workbook>>\n</$list>\n</div>\n\\end\n\n<h1>\nControls for XLSX Spreadsheet Utilities\n</h1>\n\n<div class=\"tc-import-spec-selector\">\n<h2>\nCurrent Import Specification\n</h2>\n<$list filter=\"[all[shadows+tiddlers]import-spec-role[workbook]limit[1]]\" emptyMessage=\"\"\"\nThere are no import specifications available. Use the controls below to create one\n\"\"\">\nThis is the import specification that will be used for the next import of an `.XLSX` file\n<$select tiddler=\"$:/config/plugins/tiddlywiki/xlsx-utils/default-import-spec\">\n<$list filter=\"[all[shadows+tiddlers]import-spec-role[workbook]sort[caption]]\">\n<option value=<<currentTiddler>>><$text text={{!!caption}}/></option>\n</$list>\n</$select>\n</$list>\n</div>\n\n<div class=\"tc-import-spec-editor-wrapper\">\n<h2>\n Import Specifications\n<$macrocall $name=\"help-button\" state=\"\"/>\n</h2>\n<$macrocall $name=\"help-content\" type=\"editor\" state=\"\"/>\n<div class=\"tc-import-spec-editor\">\n<<list-workbooks>>\n</div>\n</div>\n"
},
"$:/plugins/tiddlywiki/xlsx-utils/deserializer.js": {
"text": "/*\\\ntitle: $:/plugins/tiddlywiki/xlsx-utils/deserializer.js\ntype: application/javascript\nmodule-type: tiddlerdeserializer\n\nXLSX file deserializer\n\n\\*/\n(function(){\n\n/*jslint node: true, browser: true */\n/*global $tw: false */\n\"use strict\";\n\n/*\nParse an XLSX file into tiddlers\n*/\nexports[\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\"] = function(text,fields) {\n\t// Collect output tiddlers in an array\n\tvar results = [],\n\t\tXLSXImporter = require(\"$:/plugins/tiddlywiki/xlsx-utils/importer.js\").XLSXImporter,\n\t\timporter = new XLSXImporter({\n\t\t\ttext: text\n\t\t});\n\t// Return the output tiddlers\n\treturn importer.getResults();\n};\n\n})();\n",
"title": "$:/plugins/tiddlywiki/xlsx-utils/deserializer.js",
"type": "application/javascript",
"module-type": "tiddlerdeserializer"
},
"$:/plugins/tiddlywiki/xlsx-utils/docs/editor": {
"title": "$:/plugins/tiddlywiki/xlsx-utils/docs/editor",
"text": "!!! Import Specifications\n\nImport specifications govern how spreadsheets are converted into individual tiddlers.\n\nEach \"workbook\" describes how spreadsheets of a particular format should be converted.\n"
},
"$:/plugins/tiddlywiki/xlsx-utils/docs/row": {
"title": "$:/plugins/tiddlywiki/xlsx-utils/docs/row",
"text": "!!! Row Import Specifications\n\nEach row import specification describes how one tiddler should be extracted from each row of the current sheet.\n\nNote that using multiple row import specifications within a sheet enables multiple tiddlers to be created from each row of the sheet.\n\nRows contain a list of field import specifications that describe how each field of the tiddler should be created.\n\n!!! Field Import Specifications\n\nField import specifications describe the value given to a particular field of a tiddler.\n\nThey follow a rich syntax for describing how each field of the tiddler is created. For example:\n\n* Set field `title` to string from column `Organization`\n* Set field `role` to string constant `organization`\n* Append to list field `list` the string from column `Country` prefixed with `Map:`\n\n"
},
"$:/plugins/tiddlywiki/xlsx-utils/docs/sheet": {
"title": "$:/plugins/tiddlywiki/xlsx-utils/docs/sheet",
"text": "!!! Sheet Import Specifications\n\nEach sheet import specification describes how a named sheet within a workbook should be converted into individual tiddlers.\n\nSheets contain a list of row import specifications that describe how individual rows of the sheet should be handled.\n\nEach sheet has the name of the sheet that it handles.\n\nNote that the first row of each sheet is interpreted as the title of each column.\n"
},
"$:/plugins/tiddlywiki/xlsx-utils/docs/workbook": {
"title": "$:/plugins/tiddlywiki/xlsx-utils/docs/workbook",
"text": "!!! Workbook Import Specifications\n\nEach workbook import specification describes how spreadsheets of a particular format should be converted into individual tiddlers.\n\nCreate a new workbook for each type of spreadsheet that you will be working with.\n\nWorkbooks contain a list of sheet import specifications that describe how individual sheets of the workbook should be handled.\n\nEach workbook has a caption that you can use to describe its purpose.\n"
},
"$:/plugins/tiddlywiki/xlsx-utils/xlsx.js": {
"text": "var old_exports = exports,JSZip = require(\"$:/plugins/tiddlywiki/jszip/jszip.js\");exports = {};if($tw.browser){module.exports=undefined;};/* xlsx.js (C) 2013-2015 SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*jshint -W041 */\n/*jshint funcscope:true, eqnull:true */\nvar XLSX = {};\n(function make_xlsx(XLSX){\nXLSX.version = '0.8.0';\nvar current_codepage = 1200, current_cptable;\nif(typeof module !== \"undefined\" && typeof require !== 'undefined') {\n\tif(typeof cptable === 'undefined') cptable = require('./dist/cpexcel');\n\tcurrent_cptable = cptable[current_codepage];\n}\nfunction reset_cp() { set_cp(1200); }\nvar set_cp = function(cp) { current_codepage = cp; };\n\nfunction char_codes(data) { var o = []; for(var i = 0, len = data.length; i < len; ++i) o[i] = data.charCodeAt(i); return o; }\nvar debom_xml = function(data) { return data; };\n\nvar _getchar = function _gc1(x) { return String.fromCharCode(x); };\nif(typeof cptable !== 'undefined') {\n\tset_cp = function(cp) { current_codepage = cp; current_cptable = cptable[cp]; };\n\tdebom_xml = function(data) {\n\t\tif(data.charCodeAt(0) === 0xFF && data.charCodeAt(1) === 0xFE) { return cptable.utils.decode(1200, char_codes(data.substr(2))); }\n\t\treturn data;\n\t};\n\t_getchar = function _gc2(x) {\n\t\tif(current_codepage === 1200) return String.fromCharCode(x);\n\t\treturn cptable.utils.decode(current_codepage, [x&255,x>>8])[0];\n\t};\n}\nvar Base64 = (function make_b64(){\n\tvar map = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\n\treturn {\n\t\tencode: function(input, utf8) {\n\t\t\tvar o = \"\";\n\t\t\tvar c1, c2, c3, e1, e2, e3, e4;\n\t\t\tfor(var i = 0; i < input.length; ) {\n\t\t\t\tc1 = input.charCodeAt(i++);\n\t\t\t\tc2 = input.charCodeAt(i++);\n\t\t\t\tc3 = input.charCodeAt(i++);\n\t\t\t\te1 = c1 >> 2;\n\t\t\t\te2 = (c1 & 3) << 4 | c2 >> 4;\n\t\t\t\te3 = (c2 & 15) << 2 | c3 >> 6;\n\t\t\t\te4 = c3 & 63;\n\t\t\t\tif (isNaN(c2)) { e3 = e4 = 64; }\n\t\t\t\telse if (isNaN(c3)) { e4 = 64; }\n\t\t\t\to += map.charAt(e1) + map.charAt(e2) + map.charAt(e3) + map.charAt(e4);\n\t\t\t}\n\t\t\treturn o;\n\t\t},\n\t\tdecode: function b64_decode(input, utf8) {\n\t\t\tvar o = \"\";\n\t\t\tvar c1, c2, c3;\n\t\t\tvar e1, e2, e3, e4;\n\t\t\tinput = input.replace(/[^A-Za-z0-9\\+\\/\\=]/g, \"\");\n\t\t\tfor(var i = 0; i < input.length;) {\n\t\t\t\te1 = map.indexOf(input.charAt(i++));\n\t\t\t\te2 = map.indexOf(input.charAt(i++));\n\t\t\t\te3 = map.indexOf(input.charAt(i++));\n\t\t\t\te4 = map.indexOf(input.charAt(i++));\n\t\t\t\tc1 = e1 << 2 | e2 >> 4;\n\t\t\t\tc2 = (e2 & 15) << 4 | e3 >> 2;\n\t\t\t\tc3 = (e3 & 3) << 6 | e4;\n\t\t\t\to += String.fromCharCode(c1);\n\t\t\t\tif (e3 != 64) { o += String.fromCharCode(c2); }\n\t\t\t\tif (e4 != 64) { o += String.fromCharCode(c3); }\n\t\t\t}\n\t\t\treturn o;\n\t\t}\n\t};\n})();\nvar has_buf = (typeof Buffer !== 'undefined');\n\nfunction new_raw_buf(len) {\n\t/* jshint -W056 */\n\treturn new (has_buf ? Buffer : Array)(len);\n\t/* jshint +W056 */\n}\n\nfunction s2a(s) {\n\tif(has_buf) return new Buffer(s, \"binary\");\n\treturn s.split(\"\").map(function(x){ return x.charCodeAt(0) & 0xff; });\n}\n\nvar bconcat = function(bufs) { return [].concat.apply([], bufs); };\n\nvar chr0 = /\\u0000/g, chr1 = /[\\u0001-\\u0006]/;\n/* ssf.js (C) 2013-2014 SheetJS -- http://sheetjs.com */\n/*jshint -W041 */\nvar SSF = {};\nvar make_ssf = function make_ssf(SSF){\nSSF.version = '0.8.1';\nfunction _strrev(x) { var o = \"\", i = x.length-1; while(i>=0) o += x.charAt(i--); return o; }\nfunction fill(c,l) { var o = \"\"; while(o.length < l) o+=c; return o; }\nfunction pad0(v,d){var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad_(v,d){var t=\"\"+v;return t.length>=d?t:fill(' ',d-t.length)+t;}\nfunction rpad_(v,d){var t=\"\"+v; return t.length>=d?t:t+fill(' ',d-t.length);}\nfunction pad0r1(v,d){var t=\"\"+Math.round(v); return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad0r2(v,d){var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nvar p2_32 = Math.pow(2,32);\nfunction pad0r(v,d){if(v>p2_32||v<-p2_32) return pad0r1(v,d); var i = Math.round(v); return pad0r2(i,d); }\nfunction isgeneral(s, i) { return s.length >= 7 + i && (s.charCodeAt(i)|32) === 103 && (s.charCodeAt(i+1)|32) === 101 && (s.charCodeAt(i+2)|32) === 110 && (s.charCodeAt(i+3)|32) === 101 && (s.charCodeAt(i+4)|32) === 114 && (s.charCodeAt(i+5)|32) === 97 && (s.charCodeAt(i+6)|32) === 108; }\n/* Options */\nvar opts_fmt = [\n\t[\"date1904\", 0],\n\t[\"output\", \"\"],\n\t[\"WTF\", false]\n];\nfunction fixopts(o){\n\tfor(var y = 0; y != opts_fmt.length; ++y) if(o[opts_fmt[y][0]]===undefined) o[opts_fmt[y][0]]=opts_fmt[y][1];\n}\nSSF.opts = opts_fmt;\nvar table_fmt = {\n\t0: 'General',\n\t1: '0',\n\t2: '0.00',\n\t3: '#,##0',\n\t4: '#,##0.00',\n\t9: '0%',\n\t10: '0.00%',\n\t11: '0.00E+00',\n\t12: '# ?/?',\n\t13: '# ??/??',\n\t14: 'm/d/yy',\n\t15: 'd-mmm-yy',\n\t16: 'd-mmm',\n\t17: 'mmm-yy',\n\t18: 'h:mm AM/PM',\n\t19: 'h:mm:ss AM/PM',\n\t20: 'h:mm',\n\t21: 'h:mm:ss',\n\t22: 'm/d/yy h:mm',\n\t37: '#,##0 ;(#,##0)',\n\t38: '#,##0 ;[Red](#,##0)',\n\t39: '#,##0.00;(#,##0.00)',\n\t40: '#,##0.00;[Red](#,##0.00)',\n\t45: 'mm:ss',\n\t46: '[h]:mm:ss',\n\t47: 'mmss.0',\n\t48: '##0.0E+0',\n\t49: '@',\n\t56: '\"上午/下午 \"hh\"時\"mm\"分\"ss\"秒 \"',\n\t65535: 'General'\n};\nvar days = [\n\t['Sun', 'Sunday'],\n\t['Mon', 'Monday'],\n\t['Tue', 'Tuesday'],\n\t['Wed', 'Wednesday'],\n\t['Thu', 'Thursday'],\n\t['Fri', 'Friday'],\n\t['Sat', 'Saturday']\n];\nvar months = [\n\t['J', 'Jan', 'January'],\n\t['F', 'Feb', 'February'],\n\t['M', 'Mar', 'March'],\n\t['A', 'Apr', 'April'],\n\t['M', 'May', 'May'],\n\t['J', 'Jun', 'June'],\n\t['J', 'Jul', 'July'],\n\t['A', 'Aug', 'August'],\n\t['S', 'Sep', 'September'],\n\t['O', 'Oct', 'October'],\n\t['N', 'Nov', 'November'],\n\t['D', 'Dec', 'December']\n];\nfunction frac(x, D, mixed) {\n\tvar sgn = x < 0 ? -1 : 1;\n\tvar B = x * sgn;\n\tvar P_2 = 0, P_1 = 1, P = 0;\n\tvar Q_2 = 1, Q_1 = 0, Q = 0;\n\tvar A = Math.floor(B);\n\twhile(Q_1 < D) {\n\t\tA = Math.floor(B);\n\t\tP = A * P_1 + P_2;\n\t\tQ = A * Q_1 + Q_2;\n\t\tif((B - A) < 0.0000000005) break;\n\t\tB = 1 / (B - A);\n\t\tP_2 = P_1; P_1 = P;\n\t\tQ_2 = Q_1; Q_1 = Q;\n\t}\n\tif(Q > D) { Q = Q_1; P = P_1; }\n\tif(Q > D) { Q = Q_2; P = P_2; }\n\tif(!mixed) return [0, sgn * P, Q];\n\tif(Q===0) throw \"Unexpected state: \"+P+\" \"+P_1+\" \"+P_2+\" \"+Q+\" \"+Q_1+\" \"+Q_2;\n\tvar q = Math.floor(sgn * P/Q);\n\treturn [q, sgn*P - q*Q, Q];\n}\nfunction general_fmt_int(v, opts) { return \"\"+v; }\nSSF._general_int = general_fmt_int;\nvar general_fmt_num = (function make_general_fmt_num() {\nvar gnr1 = /\\.(\\d*[1-9])0+$/, gnr2 = /\\.0*$/, gnr4 = /\\.(\\d*[1-9])0+/, gnr5 = /\\.0*[Ee]/, gnr6 = /(E[+-])(\\d)$/;\nfunction gfn2(v) {\n\tvar w = (v<0?12:11);\n\tvar o = gfn5(v.toFixed(12)); if(o.length <= w) return o;\n\to = v.toPrecision(10); if(o.length <= w) return o;\n\treturn v.toExponential(5);\n}\nfunction gfn3(v) {\n\tvar o = v.toFixed(11).replace(gnr1,\".$1\");\n\tif(o.length > (v<0?12:11)) o = v.toPrecision(6);\n\treturn o;\n}\nfunction gfn4(o) {\n\tfor(var i = 0; i != o.length; ++i) if((o.charCodeAt(i) | 0x20) === 101) return o.replace(gnr4,\".$1\").replace(gnr5,\"E\").replace(\"e\",\"E\").replace(gnr6,\"$10$2\");\n\treturn o;\n}\nfunction gfn5(o) {\n\t//for(var i = 0; i != o.length; ++i) if(o.charCodeAt(i) === 46) return o.replace(gnr2,\"\").replace(gnr1,\".$1\");\n\t//return o;\n\treturn o.indexOf(\".\") > -1 ? o.replace(gnr2,\"\").replace(gnr1,\".$1\") : o;\n}\nreturn function general_fmt_num(v, opts) {\n\tvar V = Math.floor(Math.log(Math.abs(v))*Math.LOG10E), o;\n\tif(V >= -4 && V <= -1) o = v.toPrecision(10+V);\n\telse if(Math.abs(V) <= 9) o = gfn2(v);\n\telse if(V === 10) o = v.toFixed(10).substr(0,12);\n\telse o = gfn3(v);\n\treturn gfn5(gfn4(o));\n};})();\nSSF._general_num = general_fmt_num;\nfunction general_fmt(v, opts) {\n\tswitch(typeof v) {\n\t\tcase 'string': return v;\n\t\tcase 'boolean': return v ? \"TRUE\" : \"FALSE\";\n\t\tcase 'number': return (v|0) === v ? general_fmt_int(v, opts) : general_fmt_num(v, opts);\n\t}\n\tthrow new Error(\"unsupported value in General format: \" + v);\n}\nSSF._general = general_fmt;\nfunction fix_hijri(date, o) { return 0; }\nfunction parse_date_code(v,opts,b2) {\n\tif(v > 2958465 || v < 0) return null;\n\tvar date = (v|0), time = Math.floor(86400 * (v - date)), dow=0;\n\tvar dout=[];\n\tvar out={D:date, T:time, u:86400*(v-date)-time,y:0,m:0,d:0,H:0,M:0,S:0,q:0};\n\tif(Math.abs(out.u) < 1e-6) out.u = 0;\n\tfixopts(opts != null ? opts : (opts=[]));\n\tif(opts.date1904) date += 1462;\n\tif(out.u > 0.999) {\n\t\tout.u = 0;\n\t\tif(++time == 86400) { time = 0; ++date; }\n\t}\n\tif(date === 60) {dout = b2 ? [1317,10,29] : [1900,2,29]; dow=3;}\n\telse if(date === 0) {dout = b2 ? [1317,8,29] : [1900,1,0]; dow=6;}\n\telse {\n\t\tif(date > 60) --date;\n\t\t/* 1 = Jan 1 1900 */\n\t\tvar d = new Date(1900,0,1);\n\t\td.setDate(d.getDate() + date - 1);\n\t\tdout = [d.getFullYear(), d.getMonth()+1,d.getDate()];\n\t\tdow = d.getDay();\n\t\tif(date < 60) dow = (dow + 6) % 7;\n\t\tif(b2) dow = fix_hijri(d, dout);\n\t}\n\tout.y = dout[0]; out.m = dout[1]; out.d = dout[2];\n\tout.S = time % 60; time = Math.floor(time / 60);\n\tout.M = time % 60; time = Math.floor(time / 60);\n\tout.H = time;\n\tout.q = dow;\n\treturn out;\n}\nSSF.parse_date_code = parse_date_code;\n/*jshint -W086 */\nfunction write_date(type, fmt, val, ss0) {\n\tvar o=\"\", ss=0, tt=0, y = val.y, out, outl = 0;\n\tswitch(type) {\n\t\tcase 98: /* 'b' buddhist year */\n\t\t\ty = val.y + 543;\n\t\t\t/* falls through */\n\t\tcase 121: /* 'y' year */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = y % 100; outl = 2; break;\n\t\t\tdefault: out = y % 10000; outl = 4; break;\n\t\t} break;\n\t\tcase 109: /* 'm' month */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.m; outl = fmt.length; break;\n\t\t\tcase 3: return months[val.m-1][1];\n\t\t\tcase 5: return months[val.m-1][0];\n\t\t\tdefault: return months[val.m-1][2];\n\t\t} break;\n\t\tcase 100: /* 'd' day */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.d; outl = fmt.length; break;\n\t\t\tcase 3: return days[val.q][0];\n\t\t\tdefault: return days[val.q][1];\n\t\t} break;\n\t\tcase 104: /* 'h' 12-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = 1+(val.H+11)%12; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 72: /* 'H' 24-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.H; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 77: /* 'M' minutes */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.M; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad minute format: ' + fmt;\n\t\t} break;\n\t\tcase 115: /* 's' seconds */\n\t\tif(val.u === 0) switch(fmt) {\n\t\t\tcase 's': case 'ss': return pad0(val.S, fmt.length);\n\t\t\tcase '.0': case '.00': case '.000':\n\t\t}\n\t\tswitch(fmt) {\n\t\t\tcase 's': case 'ss': case '.0': case '.00': case '.000':\n\t\t\t\tif(ss0 >= 2) tt = ss0 === 3 ? 1000 : 100;\n\t\t\t\telse tt = ss0 === 1 ? 10 : 1;\n\t\t\t\tss = Math.round((tt)*(val.S + val.u));\n\t\t\t\tif(ss >= 60*tt) ss = 0;\n\t\t\t\tif(fmt === 's') return ss === 0 ? \"0\" : \"\"+ss/tt;\n\t\t\t\to = pad0(ss,2 + ss0);\n\t\t\t\tif(fmt === 'ss') return o.substr(0,2);\n\t\t\t\treturn \".\" + o.substr(2,fmt.length-1);\n\t\t\tdefault: throw 'bad second format: ' + fmt;\n\t\t}\n\t\tcase 90: /* 'Z' absolute time */\n\t\tswitch(fmt) {\n\t\t\tcase '[h]': case '[hh]': out = val.D*24+val.H; break;\n\t\t\tcase '[m]': case '[mm]': out = (val.D*24+val.H)*60+val.M; break;\n\t\t\tcase '[s]': case '[ss]': out = ((val.D*24+val.H)*60+val.M)*60+Math.round(val.S+val.u); break;\n\t\t\tdefault: throw 'bad abstime format: ' + fmt;\n\t\t} outl = fmt.length === 3 ? 1 : 2; break;\n\t\tcase 101: /* 'e' era */\n\t\t\tout = y; outl = 1;\n\t}\n\tif(outl > 0) return pad0(out, outl); else return \"\";\n}\n/*jshint +W086 */\nfunction commaify(s) {\n\tif(s.length <= 3) return s;\n\tvar j = (s.length % 3), o = s.substr(0,j);\n\tfor(; j!=s.length; j+=3) o+=(o.length > 0 ? \",\" : \"\") + s.substr(j,3);\n\treturn o;\n}\nvar write_num = (function make_write_num(){\nvar pct1 = /%/g;\nfunction write_num_pct(type, fmt, val){\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\nfunction write_num_cm(type, fmt, val){\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\nfunction write_num_exp(fmt, val){\n\tvar o;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(Math.abs(val))*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(o.indexOf(\"e\") === -1) {\n\t\t\tvar fakee = Math.floor(Math.log(Math.abs(val))*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o[0] + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\twhile(o.substr(0,2) === \"0.\") {\n\t\t\t\to = o[0] + o.substr(2,period) + \".\" + o.substr(2+period);\n\t\t\t\to = o.replace(/^0+([1-9])/,\"$1\").replace(/^0+\\./,\"0.\");\n\t\t\t}\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o[o.length-1];\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nvar frac1 = /# (\\?+)( ?)\\/( ?)(\\d+)/;\nfunction write_num_f1(r, aval, sign) {\n\tvar den = parseInt(r[4]), rr = Math.round(aval * den), base = Math.floor(rr/den);\n\tvar myn = (rr - base*den), myd = den;\n\treturn sign + (base === 0 ? \"\" : \"\"+base) + \" \" + (myn === 0 ? fill(\" \", r[1].length + 1 + r[4].length) : pad_(myn,r[1].length) + r[2] + \"/\" + r[3] + pad0(myd,r[4].length));\n}\nfunction write_num_f2(r, aval, sign) {\n\treturn sign + (aval === 0 ? \"\" : \"\"+aval) + fill(\" \", r[1].length + 2 + r[4].length);\n}\nvar dec1 = /^#*0*\\.(0+)/;\nvar closeparen = /\\).*[0#]/;\nvar phone = /\\(###\\) ###\\\\?-####/;\nfunction hashq(str) {\n\tvar o = \"\", cc;\n\tfor(var i = 0; i != str.length; ++i) switch((cc=str.charCodeAt(i))) {\n\t\tcase 35: break;\n\t\tcase 63: o+= \" \"; break;\n\t\tcase 48: o+= \"0\"; break;\n\t\tdefault: o+= String.fromCharCode(cc);\n\t}\n\treturn o;\n}\nfunction rnd(val, d) { var dd = Math.pow(10,d); return \"\"+(Math.round(val * dd)/dd); }\nfunction dec(val, d) { return Math.round((val-Math.floor(val))*Math.pow(10,d)); }\nfunction flr(val) { if(val < 2147483647 && val > -2147483648) return \"\"+(val >= 0 ? (val|0) : (val-1|0)); return \"\"+Math.floor(val); }\nfunction write_num_flt(type, fmt, val) {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_flt('n', ffmt, val);\n\t\treturn '(' + write_num_flt('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_flt(type,fmt.substr(fmt[1]==' '?2:1),val);\n\tvar o, oo;\n\tvar r, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0r(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = pad0r(val,0); if(o === \"0\") o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1)) !== null) return write_num_f1(r, aval, sign);\n\tif(fmt.match(/^#+0+$/) !== null) return sign + pad0r(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1)) !== null) {\n\t\to = rnd(val, r[1].length).replace(/^([^\\.]+)$/,\"$1.\"+r[1]).replace(/\\.$/,\".\"+r[1]).replace(/\\.(\\d*)$/,function($$, $1) { return \".\" + $1 + fill(\"0\", r[1].length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/)) !== null) {\n\t\treturn sign + rnd(aval, r[2].length).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#,##0(\\.?)$/)) !== null) return sign + commaify(pad0r(aval,0));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/)) !== null) {\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(\"\"+(Math.floor(val))) + \".\" + pad0(dec(val, r[1].length),r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/)) !== null) return write_num_flt(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/)) !== null) {\n\t\to = _strrev(write_num_flt(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o[ri++]:x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone) !== null) {\n\t\to = write_num_flt(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/)) !== null) {\n\t\tri = Math.min(r[4].length,7);\n\t\tff = frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", r[1], ff[1]);\n\t\tif(oa[oa.length-1] == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + r[2] + \"/\" + r[3];\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/)) !== null) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/)) !== null) {\n\t\to = pad0r(val, 0);\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n if((r = fmt.match(/^([#0?]+)\\.([#0]+)$/)) !== null) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/)) !== null) {\n\t\tri = dec(val, r[1].length);\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(flr(val)).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(ri,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"#,###\": var x = commaify(pad0r(aval,0)); return x !== \"0\" ? sign + x : \"\";\n\t\tdefault:\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nfunction write_num_cm2(type, fmt, val){\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\nfunction write_num_pct2(type, fmt, val){\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\nfunction write_num_exp2(fmt, val){\n\tvar o;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(Math.abs(val))*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(!o.match(/[Ee]/)) {\n\t\t\tvar fakee = Math.floor(Math.log(Math.abs(val))*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o[0] + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o[o.length-1];\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nfunction write_num_int(type, fmt, val) {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_int('n', ffmt, val);\n\t\treturn '(' + write_num_int('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm2(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct2(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp2(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_int(type,fmt.substr(fmt[1]==' '?2:1),val);\n\tvar o;\n\tvar r, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = (\"\"+val); if(val === 0) o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1)) !== null) return write_num_f2(r, aval, sign);\n\tif(fmt.match(/^#+0+$/) !== null) return sign + pad0(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1)) !== null) {\n\t\to = (\"\"+val).replace(/^([^\\.]+)$/,\"$1.\"+r[1]).replace(/\\.$/,\".\"+r[1]).replace(/\\.(\\d*)$/,function($$, $1) { return \".\" + $1 + fill(\"0\", r[1].length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/)) !== null) {\n\t\treturn sign + (\"\"+aval).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#,##0(\\.?)$/)) !== null) return sign + commaify((\"\"+aval));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/)) !== null) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify((\"\"+val)) + \".\" + fill('0',r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/)) !== null) return write_num_int(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/)) !== null) {\n\t\to = _strrev(write_num_int(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o[ri++]:x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone) !== null) {\n\t\to = write_num_int(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/)) !== null) {\n\t\tri = Math.min(r[4].length,7);\n\t\tff = frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", r[1], ff[1]);\n\t\tif(oa[oa.length-1] == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + r[2] + \"/\" + r[3];\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/)) !== null) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/)) !== null) {\n\t\to = \"\" + val;\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(/^([#0]+)\\.([#0]+)$/)) !== null) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/)) !== null) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify(\"\"+val).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(0,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"#,###\": var x = commaify(\"\"+aval); return x !== \"0\" ? sign + x : \"\";\n\t\tdefault:\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nreturn function write_num(type, fmt, val) {\n\treturn (val|0) === val ? write_num_int(type, fmt, val) : write_num_flt(type, fmt, val);\n};})();\nfunction split_fmt(fmt) {\n\tvar out = [];\n\tvar in_str = false, cc;\n\tfor(var i = 0, j = 0; i < fmt.length; ++i) switch((cc=fmt.charCodeAt(i))) {\n\t\tcase 34: /* '\"' */\n\t\t\tin_str = !in_str; break;\n\t\tcase 95: case 42: case 92: /* '_' '*' '\\\\' */\n\t\t\t++i; break;\n\t\tcase 59: /* ';' */\n\t\t\tout[out.length] = fmt.substr(j,i-j);\n\t\t\tj = i+1;\n\t}\n\tout[out.length] = fmt.substr(j);\n\tif(in_str === true) throw new Error(\"Format |\" + fmt + \"| unterminated string \");\n\treturn out;\n}\nSSF._split = split_fmt;\nvar abstime = /\\[[HhMmSs]*\\]/;\nfunction eval_fmt(fmt, v, opts, flen) {\n\tvar out = [], o = \"\", i = 0, c = \"\", lst='t', q, dt, j, cc;\n\tvar hr='H';\n\t/* Tokenize */\n\twhile(i < fmt.length) {\n\t\tswitch((c = fmt[i])) {\n\t\t\tcase 'G': /* General */\n\t\t\t\tif(!isgeneral(fmt, i)) throw new Error('unrecognized character ' + c + ' in ' +fmt);\n\t\t\t\tout[out.length] = {t:'G', v:'General'}; i+=7; break;\n\t\t\tcase '\"': /* Literal text */\n\t\t\t\tfor(o=\"\";(cc=fmt.charCodeAt(++i)) !== 34 && i < fmt.length;) o += String.fromCharCode(cc);\n\t\t\t\tout[out.length] = {t:'t', v:o}; ++i; break;\n\t\t\tcase '\\\\': var w = fmt[++i], t = (w === \"(\" || w === \")\") ? w : 't';\n\t\t\t\tout[out.length] = {t:t, v:w}; ++i; break;\n\t\t\tcase '_': out[out.length] = {t:'t', v:\" \"}; i+=2; break;\n\t\t\tcase '@': /* Text Placeholder */\n\t\t\t\tout[out.length] = {t:'T', v:v}; ++i; break;\n\t\t\tcase 'B': case 'b':\n\t\t\t\tif(fmt[i+1] === \"1\" || fmt[i+1] === \"2\") {\n if(dt==null) { dt=parse_date_code(v, opts, fmt[i+1] === \"2\"); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'X', v:fmt.substr(i,2)}; lst = c; i+=2; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase 'M': case 'D': case 'Y': case 'H': case 'S': case 'E':\n\t\t\t\tc = c.toLowerCase();\n\t\t\t\t/* falls through */\n\t\t\tcase 'm': case 'd': case 'y': case 'h': case 's': case 'e': case 'g':\n\t\t\t\tif(v < 0) return \"\";\n\t\t\t\tif(dt==null) { dt=parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\to = c; while(++i<fmt.length && fmt[i].toLowerCase() === c) o+=c;\n\t\t\t\tif(c === 'm' && lst.toLowerCase() === 'h') c = 'M'; /* m = minute */\n\t\t\t\tif(c === 'h') c = hr;\n\t\t\t\tout[out.length] = {t:c, v:o}; lst = c; break;\n\t\t\tcase 'A':\n\t\t\t\tq={t:c, v:\"A\"};\n\t\t\t\tif(dt==null) dt=parse_date_code(v, opts);\n if(fmt.substr(i, 3) === \"A/P\") { if(dt!=null) q.v = dt.H >= 12 ? \"P\" : \"A\"; q.t = 'T'; hr='h';i+=3;}\n else if(fmt.substr(i,5) === \"AM/PM\") { if(dt!=null) q.v = dt.H >= 12 ? \"PM\" : \"AM\"; q.t = 'T'; i+=5; hr='h'; }\n\t\t\t\telse { q.t = \"t\"; ++i; }\n\t\t\t\tif(dt==null && q.t === 'T') return \"\";\n\t\t\t\tout[out.length] = q; lst = c; break;\n\t\t\tcase '[':\n\t\t\t\to = c;\n\t\t\t\twhile(fmt[i++] !== ']' && i < fmt.length) o += fmt[i];\n\t\t\t\tif(o.substr(-1) !== ']') throw 'unterminated \"[\" block: |' + o + '|';\n\t\t\t\tif(o.match(abstime)) {\n\t\t\t\t\tif(dt==null) { dt=parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'Z', v:o.toLowerCase()};\n\t\t\t\t} else { o=\"\"; }\n\t\t\t\tbreak;\n\t\t\t/* Numbers */\n\t\t\tcase '.':\n\t\t\t\tif(dt != null) {\n\t\t\t\t\to = c; while((c=fmt[++i]) === \"0\") o += c;\n\t\t\t\t\tout[out.length] = {t:'s', v:o}; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase '0': case '#':\n\t\t\t\to = c; while(\"0#?.,E+-%\".indexOf(c=fmt[++i]) > -1 || c=='\\\\' && fmt[i+1] == \"-\" && \"0#\".indexOf(fmt[i+2])>-1) o += c;\n\t\t\t\tout[out.length] = {t:'n', v:o}; break;\n\t\t\tcase '?':\n\t\t\t\to = c; while(fmt[++i] === c) o+=c;\n\t\t\t\tq={t:c, v:o}; out[out.length] = q; lst = c; break;\n\t\t\tcase '*': ++i; if(fmt[i] == ' ' || fmt[i] == '*') ++i; break; // **\n\t\t\tcase '(': case ')': out[out.length] = {t:(flen===1?'t':c), v:c}; ++i; break;\n\t\t\tcase '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':\n\t\t\t\to = c; while(\"0123456789\".indexOf(fmt[++i]) > -1) o+=fmt[i];\n\t\t\t\tout[out.length] = {t:'D', v:o}; break;\n\t\t\tcase ' ': out[out.length] = {t:c, v:c}; ++i; break;\n\t\t\tdefault:\n\t\t\t\tif(\",$-+/():!^&'~{}<>=€acfijklopqrtuvwxz\".indexOf(c) === -1) throw new Error('unrecognized character ' + c + ' in ' + fmt);\n\t\t\t\tout[out.length] = {t:'t', v:c}; ++i; break;\n\t\t}\n\t}\n\tvar bt = 0, ss0 = 0, ssm;\n\tfor(i=out.length-1, lst='t'; i >= 0; --i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 'h': case 'H': out[i].t = hr; lst='h'; if(bt < 1) bt = 1; break;\n\t\t\tcase 's':\n\t\t\t\tif((ssm=out[i].v.match(/\\.0+$/))) ss0=Math.max(ss0,ssm[0].length-1);\n\t\t\t\tif(bt < 3) bt = 3;\n\t\t\t/* falls through */\n\t\t\tcase 'd': case 'y': case 'M': case 'e': lst=out[i].t; break;\n\t\t\tcase 'm': if(lst === 's') { out[i].t = 'M'; if(bt < 2) bt = 2; } break;\n\t\t\tcase 'X': if(out[i].v === \"B2\");\n\t\t\t\tbreak;\n\t\t\tcase 'Z':\n\t\t\t\tif(bt < 1 && out[i].v.match(/[Hh]/)) bt = 1;\n\t\t\t\tif(bt < 2 && out[i].v.match(/[Mm]/)) bt = 2;\n\t\t\t\tif(bt < 3 && out[i].v.match(/[Ss]/)) bt = 3;\n\t\t}\n\t}\n\tswitch(bt) {\n\t\tcase 0: break;\n\t\tcase 1:\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >= 60) { dt.S = 0; ++dt.M; }\n\t\t\tif(dt.M >= 60) { dt.M = 0; ++dt.H; }\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >= 60) { dt.S = 0; ++dt.M; }\n\t\t\tbreak;\n\t}\n\t/* replace fields */\n\tvar nstr = \"\", jj;\n\tfor(i=0; i < out.length; ++i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 't': case 'T': case ' ': case 'D': break;\n\t\t\tcase 'X': out[i] = undefined; break;\n\t\t\tcase 'd': case 'm': case 'y': case 'h': case 'H': case 'M': case 's': case 'e': case 'b': case 'Z':\n\t\t\t\tout[i].v = write_date(out[i].t.charCodeAt(0), out[i].v, dt, ss0);\n\t\t\t\tout[i].t = 't'; break;\n\t\t\tcase 'n': case '(': case '?':\n\t\t\t\tjj = i+1;\n\t\t\t\twhile(out[jj] != null && (\n\t\t\t\t\t(c=out[jj].t) === \"?\" || c === \"D\" ||\n\t\t\t\t\t(c === \" \" || c === \"t\") && out[jj+1] != null && (out[jj+1].t === '?' || out[jj+1].t === \"t\" && out[jj+1].v === '/') ||\n\t\t\t\t\tout[i].t === '(' && (c === ' ' || c === 'n' || c === ')') ||\n\t\t\t\t\tc === 't' && (out[jj].v === '/' || '$€'.indexOf(out[jj].v) > -1 || out[jj].v === ' ' && out[jj+1] != null && out[jj+1].t == '?')\n\t\t\t\t)) {\n\t\t\t\t\tout[i].v += out[jj].v;\n\t\t\t\t\tout[jj] = undefined; ++jj;\n\t\t\t\t}\n\t\t\t\tnstr += out[i].v;\n\t\t\t\ti = jj-1; break;\n\t\t\tcase 'G': out[i].t = 't'; out[i].v = general_fmt(v,opts); break;\n\t\t}\n\t}\n\tvar vv = \"\", myv, ostr;\n\tif(nstr.length > 0) {\n\t\tmyv = (v<0&&nstr.charCodeAt(0) === 45 ? -v : v); /* '-' */\n\t\tostr = write_num(nstr.charCodeAt(0) === 40 ? '(' : 'n', nstr, myv); /* '(' */\n\t\tjj=ostr.length-1;\n\t\tvar decpt = out.length;\n\t\tfor(i=0; i < out.length; ++i) if(out[i] != null && out[i].v.indexOf(\".\") > -1) { decpt = i; break; }\n\t\tvar lasti=out.length;\n\t\tif(decpt === out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tfor(i=out.length-1; i>= 0;--i) {\n\t\t\t\tif(out[i] == null || 'n?('.indexOf(out[i].t) === -1) continue;\n\t\t\t\tif(jj>=out[i].v.length-1) { jj -= out[i].v.length; out[i].v = ostr.substr(jj+1, out[i].v.length); }\n\t\t\t\telse if(jj < 0) out[i].v = \"\";\n\t\t\t\telse { out[i].v = ostr.substr(0, jj+1); jj = -1; }\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t}\n\t\telse if(decpt !== out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tjj = ostr.indexOf(\".\")-1;\n\t\t\tfor(i=decpt; i>= 0; --i) {\n\t\t\t\tif(out[i] == null || 'n?('.indexOf(out[i].t) === -1) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")-1:out[i].v.length-1;\n\t\t\t\tvv = out[i].v.substr(j+1);\n\t\t\t\tfor(; j>=0; --j) {\n\t\t\t\t\tif(jj>=0 && (out[i].v[j] === \"0\" || out[i].v[j] === \"#\")) vv = ostr[jj--] + vv;\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t\tjj = ostr.indexOf(\".\")+1;\n\t\t\tfor(i=decpt; i<out.length; ++i) {\n\t\t\t\tif(out[i] == null || 'n?('.indexOf(out[i].t) === -1 && i !== decpt ) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")+1:0;\n\t\t\t\tvv = out[i].v.substr(0,j);\n\t\t\t\tfor(; j<out[i].v.length; ++j) {\n\t\t\t\t\tif(jj<ostr.length) vv += ostr[jj++];\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t}\n\t}\n\tfor(i=0; i<out.length; ++i) if(out[i] != null && 'n(?'.indexOf(out[i].t)>-1) {\n\t\tmyv = (flen >1 && v < 0 && i>0 && out[i-1].v === \"-\" ? -v:v);\n\t\tout[i].v = write_num(out[i].t, out[i].v, myv);\n\t\tout[i].t = 't';\n\t}\n\tvar retval = \"\";\n\tfor(i=0; i !== out.length; ++i) if(out[i] != null) retval += out[i].v;\n\treturn retval;\n}\nSSF._eval = eval_fmt;\nvar cfregex = /\\[[=<>]/;\nvar cfregex2 = /\\[([=<>]*)(-?\\d+\\.?\\d*)\\]/;\nfunction chkcond(v, rr) {\n\tif(rr == null) return false;\n\tvar thresh = parseFloat(rr[2]);\n\tswitch(rr[1]) {\n\t\tcase \"=\": if(v == thresh) return true; break;\n\t\tcase \">\": if(v > thresh) return true; break;\n\t\tcase \"<\": if(v < thresh) return true; break;\n\t\tcase \"<>\": if(v != thresh) return true; break;\n\t\tcase \">=\": if(v >= thresh) return true; break;\n\t\tcase \"<=\": if(v <= thresh) return true; break;\n\t}\n\treturn false;\n}\nfunction choose_fmt(f, v) {\n\tvar fmt = split_fmt(f);\n\tvar l = fmt.length, lat = fmt[l-1].indexOf(\"@\");\n\tif(l<4 && lat>-1) --l;\n\tif(fmt.length > 4) throw \"cannot find right format for |\" + fmt + \"|\";\n\tif(typeof v !== \"number\") return [4, fmt.length === 4 || lat>-1?fmt[fmt.length-1]:\"@\"];\n\tswitch(fmt.length) {\n\t\tcase 1: fmt = lat>-1 ? [\"General\", \"General\", \"General\", fmt[0]] : [fmt[0], fmt[0], fmt[0], \"@\"]; break;\n\t\tcase 2: fmt = lat>-1 ? [fmt[0], fmt[0], fmt[0], fmt[1]] : [fmt[0], fmt[1], fmt[0], \"@\"]; break;\n\t\tcase 3: fmt = lat>-1 ? [fmt[0], fmt[1], fmt[0], fmt[2]] : [fmt[0], fmt[1], fmt[2], \"@\"]; break;\n\t\tcase 4: break;\n\t}\n\tvar ff = v > 0 ? fmt[0] : v < 0 ? fmt[1] : fmt[2];\n\tif(fmt[0].indexOf(\"[\") === -1 && fmt[1].indexOf(\"[\") === -1) return [l, ff];\n\tif(fmt[0].match(cfregex) != null || fmt[1].match(cfregex) != null) {\n\t\tvar m1 = fmt[0].match(cfregex2);\n\t\tvar m2 = fmt[1].match(cfregex2);\n\t\treturn chkcond(v, m1) ? [l, fmt[0]] : chkcond(v, m2) ? [l, fmt[1]] : [l, fmt[m1 != null && m2 != null ? 2 : 1]];\n\t}\n\treturn [l, ff];\n}\nfunction format(fmt,v,o) {\n\tfixopts(o != null ? o : (o=[]));\n\tvar sfmt = \"\";\n\tswitch(typeof fmt) {\n\t\tcase \"string\": sfmt = fmt; break;\n\t\tcase \"number\": sfmt = (o.table != null ? o.table : table_fmt)[fmt]; break;\n\t}\n\tif(isgeneral(sfmt,0)) return general_fmt(v, o);\n\tvar f = choose_fmt(sfmt, v);\n\tif(isgeneral(f[1])) return general_fmt(v, o);\n\tif(v === true) v = \"TRUE\"; else if(v === false) v = \"FALSE\";\n\telse if(v === \"\" || v == null) return \"\";\n\treturn eval_fmt(f[1], v, o, f[0]);\n}\nSSF._table = table_fmt;\nSSF.load = function load_entry(fmt, idx) { table_fmt[idx] = fmt; };\nSSF.format = format;\nSSF.get_table = function get_table() { return table_fmt; };\nSSF.load_table = function load_table(tbl) { for(var i=0; i!=0x0188; ++i) if(tbl[i] !== undefined) SSF.load(tbl[i], i); };\n};\nmake_ssf(SSF);\n/* map from xlml named formats to SSF TODO: localize */\nvar XLMLFormatMap = {\n\t\"General Number\": \"General\",\n\t\"General Date\": SSF._table[22],\n\t\"Long Date\": \"dddd, mmmm dd, yyyy\",\n\t\"Medium Date\": SSF._table[15],\n\t\"Short Date\": SSF._table[14],\n\t\"Long Time\": SSF._table[19],\n\t\"Medium Time\": SSF._table[18],\n\t\"Short Time\": SSF._table[20],\n\t\"Currency\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\"Fixed\": SSF._table[2],\n\t\"Standard\": SSF._table[4],\n\t\"Percent\": SSF._table[10],\n\t\"Scientific\": SSF._table[11],\n\t\"Yes/No\": '\"Yes\";\"Yes\";\"No\";@',\n\t\"True/False\": '\"True\";\"True\";\"False\";@',\n\t\"On/Off\": '\"Yes\";\"Yes\";\"No\";@'\n};\n\nvar DO_NOT_EXPORT_CFB = true;\n/* cfb.js (C) 2013-2014 SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*jshint eqnull:true */\n\n/* [MS-CFB] v20130118 */\nvar CFB = (function _CFB(){\nvar exports = {};\nexports.version = '0.10.2';\nfunction parse(file) {\nvar mver = 3; // major version\nvar ssz = 512; // sector size\nvar nmfs = 0; // number of mini FAT sectors\nvar ndfs = 0; // number of DIFAT sectors\nvar dir_start = 0; // first directory sector location\nvar minifat_start = 0; // first mini FAT sector location\nvar difat_start = 0; // first mini FAT sector location\n\nvar fat_addrs = []; // locations of FAT sectors\n\n/* [MS-CFB] 2.2 Compound File Header */\nvar blob = file.slice(0,512);\nprep_blob(blob, 0);\n\n/* major version */\nvar mv = check_get_mver(blob);\nmver = mv[0];\nswitch(mver) {\n\tcase 3: ssz = 512; break; case 4: ssz = 4096; break;\n\tdefault: throw \"Major Version: Expected 3 or 4 saw \" + mver;\n}\n\n/* reprocess header */\nif(ssz !== 512) { blob = file.slice(0,ssz); prep_blob(blob, 28 /* blob.l */); }\n/* Save header for final object */\nvar header = file.slice(0,ssz);\n\ncheck_shifts(blob, mver);\n\n// Number of Directory Sectors\nvar nds = blob.read_shift(4, 'i');\nif(mver === 3 && nds !== 0) throw '# Directory Sectors: Expected 0 saw ' + nds;\n\n// Number of FAT Sectors\n//var nfs = blob.read_shift(4, 'i');\nblob.l += 4;\n\n// First Directory Sector Location\ndir_start = blob.read_shift(4, 'i');\n\n// Transaction Signature\nblob.l += 4;\n\n// Mini Stream Cutoff Size\nblob.chk('00100000', 'Mini Stream Cutoff Size: ');\n\n// First Mini FAT Sector Location\nminifat_start = blob.read_shift(4, 'i');\n\n// Number of Mini FAT Sectors\nnmfs = blob.read_shift(4, 'i');\n\n// First DIFAT sector location\ndifat_start = blob.read_shift(4, 'i');\n\n// Number of DIFAT Sectors\nndfs = blob.read_shift(4, 'i');\n\n// Grab FAT Sector Locations\nfor(var q, j = 0; j < 109; ++j) { /* 109 = (512 - blob.l)>>>2; */\n\tq = blob.read_shift(4, 'i');\n\tif(q<0) break;\n\tfat_addrs[j] = q;\n}\n\n/** Break the file up into sectors */\nvar sectors = sectorify(file, ssz);\n\nsleuth_fat(difat_start, ndfs, sectors, ssz, fat_addrs);\n\n/** Chains */\nvar sector_list = make_sector_list(sectors, dir_start, fat_addrs, ssz);\n\nsector_list[dir_start].name = \"!Directory\";\nif(nmfs > 0 && minifat_start !== ENDOFCHAIN) sector_list[minifat_start].name = \"!MiniFAT\";\nsector_list[fat_addrs[0]].name = \"!FAT\";\nsector_list.fat_addrs = fat_addrs;\nsector_list.ssz = ssz;\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nvar files = {}, Paths = [], FileIndex = [], FullPaths = [], FullPathDir = {};\nread_directory(dir_start, sector_list, sectors, Paths, nmfs, files, FileIndex);\n\nbuild_full_paths(FileIndex, FullPathDir, FullPaths, Paths);\n\nvar root_name = Paths.shift();\nPaths.root = root_name;\n\n/* [MS-CFB] 2.6.4 (Unicode 3.0.1 case conversion) */\nvar find_path = make_find_path(FullPaths, Paths, FileIndex, files, root_name);\n\nreturn {\n\traw: {header: header, sectors: sectors},\n\tFileIndex: FileIndex,\n\tFullPaths: FullPaths,\n\tFullPathDir: FullPathDir,\n\tfind: find_path\n};\n} // parse\n\n/* [MS-CFB] 2.2 Compound File Header -- read up to major version */\nfunction check_get_mver(blob) {\n\t// header signature 8\n\tblob.chk(HEADER_SIGNATURE, 'Header Signature: ');\n\n\t// clsid 16\n\tblob.chk(HEADER_CLSID, 'CLSID: ');\n\n\t// minor version 2\n\tvar mver = blob.read_shift(2, 'u');\n\n\treturn [blob.read_shift(2,'u'), mver];\n}\nfunction check_shifts(blob, mver) {\n\tvar shift = 0x09;\n\n\t// Byte Order\n\tblob.chk('feff', 'Byte Order: ');\n\n\t// Sector Shift\n\tswitch((shift = blob.read_shift(2))) {\n\t\tcase 0x09: if(mver !== 3) throw 'MajorVersion/SectorShift Mismatch'; break;\n\t\tcase 0x0c: if(mver !== 4) throw 'MajorVersion/SectorShift Mismatch'; break;\n\t\tdefault: throw 'Sector Shift: Expected 9 or 12 saw ' + shift;\n\t}\n\n\t// Mini Sector Shift\n\tblob.chk('0600', 'Mini Sector Shift: ');\n\n\t// Reserved\n\tblob.chk('000000000000', 'Reserved: ');\n}\n\n/** Break the file up into sectors */\nfunction sectorify(file, ssz) {\n\tvar nsectors = Math.ceil(file.length/ssz)-1;\n\tvar sectors = new Array(nsectors);\n\tfor(var i=1; i < nsectors; ++i) sectors[i-1] = file.slice(i*ssz,(i+1)*ssz);\n\tsectors[nsectors-1] = file.slice(nsectors*ssz);\n\treturn sectors;\n}\n\n/* [MS-CFB] 2.6.4 Red-Black Tree */\nfunction build_full_paths(FI, FPD, FP, Paths) {\n\tvar i = 0, L = 0, R = 0, C = 0, j = 0, pl = Paths.length;\n\tvar dad = new Array(pl), q = new Array(pl);\n\n\tfor(; i < pl; ++i) { dad[i]=q[i]=i; FP[i]=Paths[i]; }\n\n\tfor(; j < q.length; ++j) {\n\t\ti = q[j];\n\t\tL = FI[i].L; R = FI[i].R; C = FI[i].C;\n\t\tif(dad[i] === i) {\n\t\t\tif(L !== -1 /*NOSTREAM*/ && dad[L] !== L) dad[i] = dad[L];\n\t\t\tif(R !== -1 && dad[R] !== R) dad[i] = dad[R];\n\t\t}\n\t\tif(C !== -1 /*NOSTREAM*/) dad[C] = i;\n\t\tif(L !== -1) { dad[L] = dad[i]; q.push(L); }\n\t\tif(R !== -1) { dad[R] = dad[i]; q.push(R); }\n\t}\n\tfor(i=1; i !== pl; ++i) if(dad[i] === i) {\n\t\tif(R !== -1 /*NOSTREAM*/ && dad[R] !== R) dad[i] = dad[R];\n\t\telse if(L !== -1 && dad[L] !== L) dad[i] = dad[L];\n\t}\n\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type === 0 /* unknown */) continue;\n\t\tj = dad[i];\n\t\tif(j === 0) FP[i] = FP[0] + \"/\" + FP[i];\n\t\telse while(j !== 0) {\n\t\t\tFP[i] = FP[j] + \"/\" + FP[i];\n\t\t\tj = dad[j];\n\t\t}\n\t\tdad[i] = 0;\n\t}\n\n\tFP[0] += \"/\";\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type !== 2 /* stream */) FP[i] += \"/\";\n\t\tFPD[FP[i]] = FI[i];\n\t}\n}\n\n/* [MS-CFB] 2.6.4 */\nfunction make_find_path(FullPaths, Paths, FileIndex, files, root_name) {\n\tvar UCFullPaths = new Array(FullPaths.length);\n\tvar UCPaths = new Array(Paths.length), i;\n\tfor(i = 0; i < FullPaths.length; ++i) UCFullPaths[i] = FullPaths[i].toUpperCase().replace(chr0,'').replace(chr1,'!');\n\tfor(i = 0; i < Paths.length; ++i) UCPaths[i] = Paths[i].toUpperCase().replace(chr0,'').replace(chr1,'!');\n\treturn function find_path(path) {\n\t\tvar k;\n\t\tif(path.charCodeAt(0) === 47 /* \"/\" */) { k=true; path = root_name + path; }\n\t\telse k = path.indexOf(\"/\") !== -1;\n\t\tvar UCPath = path.toUpperCase().replace(chr0,'').replace(chr1,'!');\n\t\tvar w = k === true ? UCFullPaths.indexOf(UCPath) : UCPaths.indexOf(UCPath);\n\t\tif(w === -1) return null;\n\t\treturn k === true ? FileIndex[w] : files[Paths[w]];\n\t};\n}\n\n/** Chase down the rest of the DIFAT chain to build a comprehensive list\n DIFAT chains by storing the next sector number as the last 32 bytes */\nfunction sleuth_fat(idx, cnt, sectors, ssz, fat_addrs) {\n\tvar q;\n\tif(idx === ENDOFCHAIN) {\n\t\tif(cnt !== 0) throw \"DIFAT chain shorter than expected\";\n\t} else if(idx !== -1 /*FREESECT*/) {\n\t\tvar sector = sectors[idx], m = (ssz>>>2)-1;\n\t\tfor(var i = 0; i < m; ++i) {\n\t\t\tif((q = __readInt32LE(sector,i*4)) === ENDOFCHAIN) break;\n\t\t\tfat_addrs.push(q);\n\t\t}\n\t\tsleuth_fat(__readInt32LE(sector,ssz-4),cnt - 1, sectors, ssz, fat_addrs);\n\t}\n}\n\n/** Follow the linked list of sectors for a given starting point */\nfunction get_sector_list(sectors, start, fat_addrs, ssz, chkd) {\n\tvar sl = sectors.length;\n\tvar buf, buf_chain;\n\tif(!chkd) chkd = new Array(sl);\n\tvar modulus = ssz - 1, j, jj;\n\tbuf = [];\n\tbuf_chain = [];\n\tfor(j=start; j>=0;) {\n\t\tchkd[j] = true;\n\t\tbuf[buf.length] = j;\n\t\tbuf_chain.push(sectors[j]);\n\t\tvar addr = fat_addrs[Math.floor(j*4/ssz)];\n\t\tjj = ((j*4) & modulus);\n\t\tif(ssz < 4 + jj) throw \"FAT boundary crossed: \" + j + \" 4 \"+ssz;\n\t\tj = __readInt32LE(sectors[addr], jj);\n\t}\n\treturn {nodes: buf, data:__toBuffer([buf_chain])};\n}\n\n/** Chase down the sector linked lists */\nfunction make_sector_list(sectors, dir_start, fat_addrs, ssz) {\n\tvar sl = sectors.length, sector_list = new Array(sl);\n\tvar chkd = new Array(sl), buf, buf_chain;\n\tvar modulus = ssz - 1, i, j, k, jj;\n\tfor(i=0; i < sl; ++i) {\n\t\tbuf = [];\n\t\tk = (i + dir_start); if(k >= sl) k-=sl;\n\t\tif(chkd[k] === true) continue;\n\t\tbuf_chain = [];\n\t\tfor(j=k; j>=0;) {\n\t\t\tchkd[j] = true;\n\t\t\tbuf[buf.length] = j;\n\t\t\tbuf_chain.push(sectors[j]);\n\t\t\tvar addr = fat_addrs[Math.floor(j*4/ssz)];\n\t\t\tjj = ((j*4) & modulus);\n\t\t\tif(ssz < 4 + jj) throw \"FAT boundary crossed: \" + j + \" 4 \"+ssz;\n\t\t\tj = __readInt32LE(sectors[addr], jj);\n\t\t}\n\t\tsector_list[k] = {nodes: buf, data:__toBuffer([buf_chain])};\n\t}\n\treturn sector_list;\n}\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nfunction read_directory(dir_start, sector_list, sectors, Paths, nmfs, files, FileIndex) {\n\tvar blob;\n\tvar minifat_store = 0, pl = (Paths.length?2:0);\n\tvar sector = sector_list[dir_start].data;\n\tvar i = 0, namelen = 0, name, o, ctime, mtime;\n\tfor(; i < sector.length; i+= 128) {\n\t\tblob = sector.slice(i, i+128);\n\t\tprep_blob(blob, 64);\n\t\tnamelen = blob.read_shift(2);\n\t\tif(namelen === 0) continue;\n\t\tname = __utf16le(blob,0,namelen-pl);\n\t\tPaths.push(name);\n\t\to = {\n\t\t\tname: name,\n\t\t\ttype: blob.read_shift(1),\n\t\t\tcolor: blob.read_shift(1),\n\t\t\tL: blob.read_shift(4, 'i'),\n\t\t\tR: blob.read_shift(4, 'i'),\n\t\t\tC: blob.read_shift(4, 'i'),\n\t\t\tclsid: blob.read_shift(16),\n\t\t\tstate: blob.read_shift(4, 'i')\n\t\t};\n\t\tctime = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(ctime !== 0) {\n\t\t\to.ctime = ctime; o.ct = read_date(blob, blob.l-8);\n\t\t}\n\t\tmtime = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(mtime !== 0) {\n\t\t\to.mtime = mtime; o.mt = read_date(blob, blob.l-8);\n\t\t}\n\t\to.start = blob.read_shift(4, 'i');\n\t\to.size = blob.read_shift(4, 'i');\n\t\tif(o.type === 5) { /* root */\n\t\t\tminifat_store = o.start;\n\t\t\tif(nmfs > 0 && minifat_store !== ENDOFCHAIN) sector_list[minifat_store].name = \"!StreamData\";\n\t\t\t/*minifat_size = o.size;*/\n\t\t} else if(o.size >= 4096 /* MSCSZ */) {\n\t\t\to.storage = 'fat';\n\t\t\tif(sector_list[o.start] === undefined) sector_list[o.start] = get_sector_list(sectors, o.start, sector_list.fat_addrs, sector_list.ssz);\n\t\t\tsector_list[o.start].name = o.name;\n\t\t\to.content = sector_list[o.start].data.slice(0,o.size);\n\t\t\tprep_blob(o.content, 0);\n\t\t} else {\n\t\t\to.storage = 'minifat';\n\t\t\tif(minifat_store !== ENDOFCHAIN && o.start !== ENDOFCHAIN) {\n\t\t\t\to.content = sector_list[minifat_store].data.slice(o.start*MSSZ,o.start*MSSZ+o.size);\n\t\t\t\tprep_blob(o.content, 0);\n\t\t\t}\n\t\t}\n\t\tfiles[name] = o;\n\t\tFileIndex.push(o);\n\t}\n}\n\nfunction read_date(blob, offset) {\n\treturn new Date(( ( (__readUInt32LE(blob,offset+4)/1e7)*Math.pow(2,32)+__readUInt32LE(blob,offset)/1e7 ) - 11644473600)*1000);\n}\n\nvar fs;\nfunction readFileSync(filename, options) {\n\tif(fs === undefined) fs = require('fs');\n\treturn parse(fs.readFileSync(filename), options);\n}\n\nfunction readSync(blob, options) {\n\tswitch(options !== undefined && options.type !== undefined ? options.type : \"base64\") {\n\t\tcase \"file\": return readFileSync(blob, options);\n\t\tcase \"base64\": return parse(s2a(Base64.decode(blob)), options);\n\t\tcase \"binary\": return parse(s2a(blob), options);\n\t}\n\treturn parse(blob);\n}\n\n/** CFB Constants */\nvar MSSZ = 64; /* Mini Sector Size = 1<<6 */\n//var MSCSZ = 4096; /* Mini Stream Cutoff Size */\n/* 2.1 Compound File Sector Numbers and Types */\nvar ENDOFCHAIN = -2;\n/* 2.2 Compound File Header */\nvar HEADER_SIGNATURE = 'd0cf11e0a1b11ae1';\nvar HEADER_CLSID = '00000000000000000000000000000000';\nvar consts = {\n\t/* 2.1 Compund File Sector Numbers and Types */\n\tMAXREGSECT: -6,\n\tDIFSECT: -4,\n\tFATSECT: -3,\n\tENDOFCHAIN: ENDOFCHAIN,\n\tFREESECT: -1,\n\t/* 2.2 Compound File Header */\n\tHEADER_SIGNATURE: HEADER_SIGNATURE,\n\tHEADER_MINOR_VERSION: '3e00',\n\tMAXREGSID: -6,\n\tNOSTREAM: -1,\n\tHEADER_CLSID: HEADER_CLSID,\n\t/* 2.6.1 Compound File Directory Entry */\n\tEntryTypes: ['unknown','storage','stream','lockbytes','property','root']\n};\n\nexports.read = readSync;\nexports.parse = parse;\nexports.utils = {\n\tReadShift: ReadShift,\n\tCheckField: CheckField,\n\tprep_blob: prep_blob,\n\tbconcat: bconcat,\n\tconsts: consts\n};\n\nreturn exports;\n})();\n\nif(typeof require !== 'undefined' && typeof module !== 'undefined' && typeof DO_NOT_EXPORT_CFB === 'undefined') { module.exports = CFB; }\nfunction isval(x) { return x !== undefined && x !== null; }\n\nfunction keys(o) { return Object.keys(o); }\n\nfunction evert_key(obj, key) {\n\tvar o = [], K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]][key]] = K[i];\n\treturn o;\n}\n\nfunction evert(obj) {\n\tvar o = [], K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = K[i];\n\treturn o;\n}\n\nfunction evert_num(obj) {\n\tvar o = [], K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = parseInt(K[i],10);\n\treturn o;\n}\n\nfunction evert_arr(obj) {\n\tvar o = [], K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) {\n\t\tif(o[obj[K[i]]] == null) o[obj[K[i]]] = [];\n\t\to[obj[K[i]]].push(K[i]);\n\t}\n\treturn o;\n}\n\n/* TODO: date1904 logic */\nfunction datenum(v, date1904) {\n\tif(date1904) v+=1462;\n\tvar epoch = Date.parse(v);\n\treturn (epoch + 2209161600000) / (24 * 60 * 60 * 1000);\n}\n\nfunction cc2str(arr) {\n\tvar o = \"\";\n\tfor(var i = 0; i != arr.length; ++i) o += String.fromCharCode(arr[i]);\n\treturn o;\n}\n\nfunction getdata(data) {\n\tif(!data) return null;\n\tif(data.name.substr(-4) === \".bin\") {\n\t\tif(data.data) return char_codes(data.data);\n\t\tif(data.asNodeBuffer && has_buf) return data.asNodeBuffer();\n\t\tif(data._data && data._data.getContent) return Array.prototype.slice.call(data._data.getContent());\n\t} else {\n\t\tif(data.data) return data.name.substr(-4) !== \".bin\" ? debom_xml(data.data) : char_codes(data.data);\n\t\tif(data.asNodeBuffer && has_buf) return debom_xml(data.asNodeBuffer().toString('binary'));\n\t\tif(data.asBinary) return debom_xml(data.asBinary());\n\t\tif(data._data && data._data.getContent) return debom_xml(cc2str(Array.prototype.slice.call(data._data.getContent(),0)));\n\t}\n\treturn null;\n}\n\nfunction safegetzipfile(zip, file) {\n\tvar f = file; if(zip.files[f]) return zip.files[f];\n\tf = file.toLowerCase(); if(zip.files[f]) return zip.files[f];\n\tf = f.replace(/\\//g,'\\\\'); if(zip.files[f]) return zip.files[f];\n\treturn null;\n}\n\nfunction getzipfile(zip, file) {\n\tvar o = safegetzipfile(zip, file);\n\tif(o == null) throw new Error(\"Cannot find file \" + file + \" in zip\");\n\treturn o;\n}\n\nfunction getzipdata(zip, file, safe) {\n\tif(!safe) return getdata(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipdata(zip, file); } catch(e) { return null; }\n}\n\nvar _fs, jszip;\nif(typeof JSZip !== 'undefined') jszip = JSZip;\nif (typeof exports !== 'undefined') {\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tif(has_buf && typeof jszip === 'undefined') jszip = require('js'+'zip');\n\t\tif(typeof jszip === 'undefined') jszip = require('./js'+'zip').JSZip;\n\t\t_fs = require('f'+'s');\n\t}\n}\nvar attregexg=/([\\w:]+)=((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:'))/g;\nvar tagregex=/<[^>]*>/g;\nvar nsregex=/<\\w*:/, nsregex2 = /<(\\/?)\\w+:/;\nfunction parsexmltag(tag, skip_root) {\n\tvar z = [];\n\tvar eq = 0, c = 0;\n\tfor(; eq !== tag.length; ++eq) if((c = tag.charCodeAt(eq)) === 32 || c === 10 || c === 13) break;\n\tif(!skip_root) z[0] = tag.substr(0, eq);\n\tif(eq === tag.length) return z;\n\tvar m = tag.match(attregexg), j=0, w=\"\", v=\"\", i=0, q=\"\", cc=\"\";\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\tcc = m[i];\n\t\tfor(c=0; c != cc.length; ++c) if(cc.charCodeAt(c) === 61) break;\n\t\tq = cc.substr(0,c); v = cc.substring(c+2, cc.length-1);\n\t\tfor(j=0;j!=q.length;++j) if(q.charCodeAt(j) === 58) break;\n\t\tif(j===q.length) z[q] = v;\n\t\telse z[(j===5 && q.substr(0,5)===\"xmlns\"?\"xmlns\":\"\")+q.substr(j+1)] = v;\n\t}\n\treturn z;\n}\nfunction strip_ns(x) { return x.replace(nsregex2, \"<$1\"); }\n\nvar encodings = {\n\t'"': '\"',\n\t''': \"'\",\n\t'>': '>',\n\t'<': '<',\n\t'&': '&'\n};\nvar rencoding = evert(encodings);\nvar rencstr = \"&<>'\\\"\".split(\"\");\n\n// TODO: CP remap (need to read file version to determine OS)\nvar unescapexml = (function() {\n\tvar encregex = /&[a-z]*;/g, coderegex = /_x([\\da-fA-F]+)_/g;\n\treturn function unescapexml(text){\n\t\tvar s = text + '';\n\t\treturn s.replace(encregex, function($$) { return encodings[$$]; }).replace(coderegex,function(m,c) {return String.fromCharCode(parseInt(c,16));});\n\t};\n})();\n\nvar decregex=/[&<>'\"]/g, charegex = /[\\u0000-\\u0008\\u000b-\\u001f]/g;\nfunction escapexml(text){\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(charegex,function(s) { return \"_x\" + (\"000\"+s.charCodeAt(0).toString(16)).substr(-4) + \"_\";});\n}\n\n/* TODO: handle codepages */\nvar xlml_fixstr = (function() {\n\tvar entregex = /&#(\\d+);/g;\n\tfunction entrepl($$,$1) { return String.fromCharCode(parseInt($1,10)); }\n\treturn function xlml_fixstr(str) { return str.replace(entregex,entrepl); };\n})();\n\nfunction parsexmlbool(value, tag) {\n\tswitch(value) {\n\t\tcase '1': case 'true': case 'TRUE': return true;\n\t\t/* case '0': case 'false': case 'FALSE':*/\n\t\tdefault: return false;\n\t}\n}\n\nvar utf8read = function utf8reada(orig) {\n\tvar out = \"\", i = 0, c = 0, d = 0, e = 0, f = 0, w = 0;\n\twhile (i < orig.length) {\n\t\tc = orig.charCodeAt(i++);\n\t\tif (c < 128) { out += String.fromCharCode(c); continue; }\n\t\td = orig.charCodeAt(i++);\n\t\tif (c>191 && c<224) { out += String.fromCharCode(((c & 31) << 6) | (d & 63)); continue; }\n\t\te = orig.charCodeAt(i++);\n\t\tif (c < 240) { out += String.fromCharCode(((c & 15) << 12) | ((d & 63) << 6) | (e & 63)); continue; }\n\t\tf = orig.charCodeAt(i++);\n\t\tw = (((c & 7) << 18) | ((d & 63) << 12) | ((e & 63) << 6) | (f & 63))-65536;\n\t\tout += String.fromCharCode(0xD800 + ((w>>>10)&1023));\n\t\tout += String.fromCharCode(0xDC00 + (w&1023));\n\t}\n\treturn out;\n};\n\n\nif(has_buf) {\n\tvar utf8readb = function utf8readb(data) {\n\t\tvar out = new Buffer(2*data.length), w, i, j = 1, k = 0, ww=0, c;\n\t\tfor(i = 0; i < data.length; i+=j) {\n\t\t\tj = 1;\n\t\t\tif((c=data.charCodeAt(i)) < 128) w = c;\n\t\t\telse if(c < 224) { w = (c&31)*64+(data.charCodeAt(i+1)&63); j=2; }\n\t\t\telse if(c < 240) { w=(c&15)*4096+(data.charCodeAt(i+1)&63)*64+(data.charCodeAt(i+2)&63); j=3; }\n\t\t\telse { j = 4;\n\t\t\t\tw = (c & 7)*262144+(data.charCodeAt(i+1)&63)*4096+(data.charCodeAt(i+2)&63)*64+(data.charCodeAt(i+3)&63);\n\t\t\t\tw -= 65536; ww = 0xD800 + ((w>>>10)&1023); w = 0xDC00 + (w&1023);\n\t\t\t}\n\t\t\tif(ww !== 0) { out[k++] = ww&255; out[k++] = ww>>>8; ww = 0; }\n\t\t\tout[k++] = w%256; out[k++] = w>>>8;\n\t\t}\n\t\tout.length = k;\n\t\treturn out.toString('ucs2');\n\t};\n\tvar corpus = \"foo bar baz\\u00e2\\u0098\\u0083\\u00f0\\u009f\\u008d\\u00a3\";\n\tif(utf8read(corpus) == utf8readb(corpus)) utf8read = utf8readb;\n\tvar utf8readc = function utf8readc(data) { return Buffer(data, 'binary').toString('utf8'); };\n\tif(utf8read(corpus) == utf8readc(corpus)) utf8read = utf8readc;\n}\n\n// matches <foo>...</foo> extracts content\nvar matchtag = (function() {\n\tvar mtcache = {};\n\treturn function matchtag(f,g) {\n\t\tvar t = f+\"|\"+g;\n\t\tif(mtcache[t] !== undefined) return mtcache[t];\n\t\treturn (mtcache[t] = new RegExp('<(?:\\\\w+:)?'+f+'(?: xml:space=\"preserve\")?(?:[^>]*)>([^\\u2603]*)</(?:\\\\w+:)?'+f+'>',(g||\"\")));\n\t};\n})();\n\nvar vtregex = (function(){ var vt_cache = {};\n\treturn function vt_regex(bt) {\n\t\tif(vt_cache[bt] !== undefined) return vt_cache[bt];\n\t\treturn (vt_cache[bt] = new RegExp(\"<vt:\" + bt + \">(.*?)</vt:\" + bt + \">\", 'g') );\n};})();\nvar vtvregex = /<\\/?vt:variant>/g, vtmregex = /<vt:([^>]*)>(.*)</;\nfunction parseVector(data) {\n\tvar h = parsexmltag(data);\n\n\tvar matches = data.match(vtregex(h.baseType))||[];\n\tif(matches.length != h.size) throw \"unexpected vector length \" + matches.length + \" != \" + h.size;\n\tvar res = [];\n\tmatches.forEach(function(x) {\n\t\tvar v = x.replace(vtvregex,\"\").match(vtmregex);\n\t\tres.push({v:v[2], t:v[1]});\n\t});\n\treturn res;\n}\n\nvar wtregex = /(^\\s|\\s$|\\n)/;\nfunction writetag(f,g) {return '<' + f + (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f + '>';}\n\nfunction wxt_helper(h) { return keys(h).map(function(k) { return \" \" + k + '=\"' + h[k] + '\"';}).join(\"\"); }\nfunction writextag(f,g,h) { return '<' + f + (isval(h) ? wxt_helper(h) : \"\") + (isval(g) ? (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f : \"/\") + '>';}\n\nfunction write_w3cdtf(d, t) { try { return d.toISOString().replace(/\\.\\d*/,\"\"); } catch(e) { if(t) throw e; } }\n\nfunction write_vt(s) {\n\tswitch(typeof s) {\n\t\tcase 'string': return writextag('vt:lpwstr', s);\n\t\tcase 'number': return writextag((s|0)==s?'vt:i4':'vt:r8', String(s));\n\t\tcase 'boolean': return writextag('vt:bool',s?'true':'false');\n\t}\n\tif(s instanceof Date) return writextag('vt:filetime', write_w3cdtf(s));\n\tthrow new Error(\"Unable to serialize \" + s);\n}\n\nvar XML_HEADER = '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\r\\n';\nvar XMLNS = {\n\t'dc': 'http://purl.org/dc/elements/1.1/',\n\t'dcterms': 'http://purl.org/dc/terms/',\n\t'dcmitype': 'http://purl.org/dc/dcmitype/',\n\t'mx': 'http://schemas.microsoft.com/office/mac/excel/2008/main',\n\t'r': 'http://schemas.openxmlformats.org/officeDocument/2006/relationships',\n\t'sjs': 'http://schemas.openxmlformats.org/package/2006/sheetjs/core-properties',\n\t'vt': 'http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes',\n\t'xsi': 'http://www.w3.org/2001/XMLSchema-instance',\n\t'xsd': 'http://www.w3.org/2001/XMLSchema'\n};\n\nXMLNS.main = [\n\t'http://schemas.openxmlformats.org/spreadsheetml/2006/main',\n\t'http://purl.oclc.org/ooxml/spreadsheetml/main',\n\t'http://schemas.microsoft.com/office/excel/2006/main',\n\t'http://schemas.microsoft.com/office/excel/2006/2'\n];\n\nfunction readIEEE754(buf, idx, isLE, nl, ml) {\n\tif(isLE === undefined) isLE = true;\n\tif(!nl) nl = 8;\n\tif(!ml && nl === 8) ml = 52;\n\tvar e, m, el = nl * 8 - ml - 1, eMax = (1 << el) - 1, eBias = eMax >> 1;\n\tvar bits = -7, d = isLE ? -1 : 1, i = isLE ? (nl - 1) : 0, s = buf[idx + i];\n\n\ti += d;\n\te = s & ((1 << (-bits)) - 1); s >>>= (-bits); bits += el;\n\tfor (; bits > 0; e = e * 256 + buf[idx + i], i += d, bits -= 8);\n\tm = e & ((1 << (-bits)) - 1); e >>>= (-bits); bits += ml;\n\tfor (; bits > 0; m = m * 256 + buf[idx + i], i += d, bits -= 8);\n\tif (e === eMax) return m ? NaN : ((s ? -1 : 1) * Infinity);\n\telse if (e === 0) e = 1 - eBias;\n\telse { m = m + Math.pow(2, ml); e = e - eBias; }\n\treturn (s ? -1 : 1) * m * Math.pow(2, e - ml);\n}\n\nvar __toBuffer, ___toBuffer;\n__toBuffer = ___toBuffer = function toBuffer_(bufs) { var x = []; for(var i = 0; i < bufs[0].length; ++i) { x.push.apply(x, bufs[0][i]); } return x; };\nvar __utf16le, ___utf16le;\n__utf16le = ___utf16le = function utf16le_(b,s,e) { var ss=[]; for(var i=s; i<e; i+=2) ss.push(String.fromCharCode(__readUInt16LE(b,i))); return ss.join(\"\"); };\nvar __hexlify, ___hexlify;\n__hexlify = ___hexlify = function hexlify_(b,s,l) { return b.slice(s,(s+l)).map(function(x){return (x<16?\"0\":\"\") + x.toString(16);}).join(\"\"); };\nvar __utf8, ___utf8;\n__utf8 = ___utf8 = function(b,s,e) { var ss=[]; for(var i=s; i<e; i++) ss.push(String.fromCharCode(__readUInt8(b,i))); return ss.join(\"\"); };\nvar __lpstr, ___lpstr;\n__lpstr = ___lpstr = function lpstr_(b,i) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __lpwstr, ___lpwstr;\n__lpwstr = ___lpwstr = function lpwstr_(b,i) { var len = 2*__readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __double, ___double;\n__double = ___double = function(b, idx) { return readIEEE754(b, idx);};\n\nvar is_buf = function is_buf_a(a) { return Array.isArray(a); };\nif(has_buf) {\n\t__utf16le = function utf16le_b(b,s,e) { if(!Buffer.isBuffer(b)) return ___utf16le(b,s,e); return b.toString('utf16le',s,e); };\n\t__hexlify = function(b,s,l) { return Buffer.isBuffer(b) ? b.toString('hex',s,s+l) : ___hexlify(b,s,l); };\n\t__lpstr = function lpstr_b(b,i) { if(!Buffer.isBuffer(b)) return ___lpstr(b, i); var len = b.readUInt32LE(i); return len > 0 ? b.toString('utf8',i+4,i+4+len-1) : \"\";};\n\t__lpwstr = function lpwstr_b(b,i) { if(!Buffer.isBuffer(b)) return ___lpwstr(b, i); var len = 2*b.readUInt32LE(i); return b.toString('utf16le',i+4,i+4+len-1);};\n\t__utf8 = function utf8_b(s,e) { return this.toString('utf8',s,e); };\n\t__toBuffer = function(bufs) { return (bufs[0].length > 0 && Buffer.isBuffer(bufs[0][0])) ? Buffer.concat(bufs[0]) : ___toBuffer(bufs);};\n\tbconcat = function(bufs) { return Buffer.isBuffer(bufs[0]) ? Buffer.concat(bufs) : [].concat.apply([], bufs); };\n\t__double = function double_(b,i) { if(Buffer.isBuffer(b)) return b.readDoubleLE(i); return ___double(b,i); };\n\tis_buf = function is_buf_b(a) { return Buffer.isBuffer(a) || Array.isArray(a); };\n}\n\n/* from js-xls */\nif(typeof cptable !== 'undefined') {\n\t__utf16le = function(b,s,e) { return cptable.utils.decode(1200, b.slice(s,e)); };\n\t__utf8 = function(b,s,e) { return cptable.utils.decode(65001, b.slice(s,e)); };\n\t__lpstr = function(b,i) { var len = __readUInt32LE(b,i); return len > 0 ? cptable.utils.decode(current_codepage, b.slice(i+4, i+4+len-1)) : \"\";};\n\t__lpwstr = function(b,i) { var len = 2*__readUInt32LE(b,i); return len > 0 ? cptable.utils.decode(1200, b.slice(i+4,i+4+len-1)) : \"\";};\n}\n\nvar __readUInt8 = function(b, idx) { return b[idx]; };\nvar __readUInt16LE = function(b, idx) { return b[idx+1]*(1<<8)+b[idx]; };\nvar __readInt16LE = function(b, idx) { var u = b[idx+1]*(1<<8)+b[idx]; return (u < 0x8000) ? u : (0xffff - u + 1) * -1; };\nvar __readUInt32LE = function(b, idx) { return b[idx+3]*(1<<24)+(b[idx+2]<<16)+(b[idx+1]<<8)+b[idx]; };\nvar __readInt32LE = function(b, idx) { return (b[idx+3]<<24)|(b[idx+2]<<16)|(b[idx+1]<<8)|b[idx]; };\n\nvar ___unhexlify = function(s) { return s.match(/../g).map(function(x) { return parseInt(x,16);}); };\nvar __unhexlify = typeof Buffer !== \"undefined\" ? function(s) { return Buffer.isBuffer(s) ? new Buffer(s, 'hex') : ___unhexlify(s); } : ___unhexlify;\n\nfunction ReadShift(size, t) {\n\tvar o=\"\", oI, oR, oo=[], w, vv, i, loc;\n\tswitch(t) {\n\t\tcase 'dbcs':\n\t\t\tloc = this.l;\n\t\t\tif(has_buf && Buffer.isBuffer(this)) o = this.slice(this.l, this.l+2*size).toString(\"utf16le\");\n\t\t\telse for(i = 0; i != size; ++i) { o+=String.fromCharCode(__readUInt16LE(this, loc)); loc+=2; }\n\t\t\tsize *= 2;\n\t\t\tbreak;\n\n\t\tcase 'utf8': o = __utf8(this, this.l, this.l + size); break;\n\t\tcase 'utf16le': size *= 2; o = __utf16le(this, this.l, this.l + size); break;\n\n\t\t/* [MS-OLEDS] 2.1.4 LengthPrefixedAnsiString */\n\t\tcase 'lpstr': o = __lpstr(this, this.l); size = 5 + o.length; break;\n\t\t/* [MS-OLEDS] 2.1.5 LengthPrefixedUnicodeString */\n\t\tcase 'lpwstr': o = __lpwstr(this, this.l); size = 5 + o.length; if(o[o.length-1] == '\\u0000') size += 2; break;\n\n\t\tcase 'cstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt8(this, this.l + size++))!==0) oo.push(_getchar(w));\n\t\t\to = oo.join(\"\"); break;\n\t\tcase 'wstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt16LE(this,this.l +size))!==0){oo.push(_getchar(w));size+=2;}\n\t\t\tsize+=2; o = oo.join(\"\"); break;\n\n\t\t/* sbcs and dbcs support continue records in the SST way TODO codepages */\n\t\tcase 'dbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i != size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt16LE(this, loc)));\n\t\t\t\tloc+=2;\n\t\t\t} o = oo.join(\"\"); size *= 2; break;\n\n\t\tcase 'sbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i != size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt8(this, loc)));\n\t\t\t\tloc+=1;\n\t\t\t} o = oo.join(\"\"); break;\n\n\t\tdefault:\n\tswitch(size) {\n\t\tcase 1: oI = __readUInt8(this, this.l); this.l++; return oI;\n\t\tcase 2: oI = (t === 'i' ? __readInt16LE : __readUInt16LE)(this, this.l); this.l += 2; return oI;\n\t\tcase 4:\n\t\t\tif(t === 'i' || (this[this.l+3] & 0x80)===0) { oI = __readInt32LE(this, this.l); this.l += 4; return oI; }\n\t\t\telse { oR = __readUInt32LE(this, this.l); this.l += 4; return oR; } break;\n\t\tcase 8: if(t === 'f') { oR = __double(this, this.l); this.l += 8; return oR; }\n\t\t/* falls through */\n\t\tcase 16: o = __hexlify(this, this.l, size); break;\n\t}}\n\tthis.l+=size; return o;\n}\n\nfunction WriteShift(t, val, f) {\n\tvar size, i;\n\tif(f === 'dbcs') {\n\t\tfor(i = 0; i != val.length; ++i) this.writeUInt16LE(val.charCodeAt(i), this.l + 2 * i);\n\t\tsize = 2 * val.length;\n\t} else switch(t) {\n\t\tcase 1: size = 1; this[this.l] = val&255; break;\n\t\tcase 3: size = 3; this[this.l+2] = val & 255; val >>>= 8; this[this.l+1] = val&255; val >>>= 8; this[this.l] = val&255; break;\n\t\tcase 4: size = 4; this.writeUInt32LE(val, this.l); break;\n\t\tcase 8: size = 8; if(f === 'f') { this.writeDoubleLE(val, this.l); break; }\n\t\t/* falls through */\n\t\tcase 16: break;\n\t\tcase -4: size = 4; this.writeInt32LE(val, this.l); break;\n\t}\n\tthis.l += size; return this;\n}\n\nfunction CheckField(hexstr, fld) {\n\tvar m = __hexlify(this,this.l,hexstr.length>>1);\n\tif(m !== hexstr) throw fld + 'Expected ' + hexstr + ' saw ' + m;\n\tthis.l += hexstr.length>>1;\n}\n\nfunction prep_blob(blob, pos) {\n\tblob.l = pos;\n\tblob.read_shift = ReadShift;\n\tblob.chk = CheckField;\n\tblob.write_shift = WriteShift;\n}\n\nfunction parsenoop(blob, length) { blob.l += length; }\n\nfunction writenoop(blob, length) { blob.l += length; }\n\nfunction new_buf(sz) {\n\tvar o = new_raw_buf(sz);\n\tprep_blob(o, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.4 Record */\nfunction recordhopper(data, cb, opts) {\n\tvar tmpbyte, cntbyte, length;\n\tprep_blob(data, data.l || 0);\n\twhile(data.l < data.length) {\n\t\tvar RT = data.read_shift(1);\n\t\tif(RT & 0x80) RT = (RT & 0x7F) + ((data.read_shift(1) & 0x7F)<<7);\n\t\tvar R = XLSBRecordEnum[RT] || XLSBRecordEnum[0xFFFF];\n\t\ttmpbyte = data.read_shift(1);\n\t\tlength = tmpbyte & 0x7F;\n\t\tfor(cntbyte = 1; cntbyte <4 && (tmpbyte & 0x80); ++cntbyte) length += ((tmpbyte = data.read_shift(1)) & 0x7F)<<(7*cntbyte);\n\t\tvar d = R.f(data, length, opts);\n\t\tif(cb(d, R, RT)) return;\n\t}\n}\n\n/* control buffer usage for fixed-length buffers */\nfunction buf_array() {\n\tvar bufs = [], blksz = 2048;\n\tvar newblk = function ba_newblk(sz) {\n\t\tvar o = new_buf(sz);\n\t\tprep_blob(o, 0);\n\t\treturn o;\n\t};\n\n\tvar curbuf = newblk(blksz);\n\n\tvar endbuf = function ba_endbuf() {\n\t\tcurbuf.length = curbuf.l;\n\t\tif(curbuf.length > 0) bufs.push(curbuf);\n\t\tcurbuf = null;\n\t};\n\n\tvar next = function ba_next(sz) {\n\t\tif(sz < curbuf.length - curbuf.l) return curbuf;\n\t\tendbuf();\n\t\treturn (curbuf = newblk(Math.max(sz+1, blksz)));\n\t};\n\n\tvar end = function ba_end() {\n\t\tendbuf();\n\t\treturn __toBuffer([bufs]);\n\t};\n\n\tvar push = function ba_push(buf) { endbuf(); curbuf = buf; next(blksz); };\n\n\treturn { next:next, push:push, end:end, _bufs:bufs };\n}\n\nfunction write_record(ba, type, payload, length) {\n\tvar t = evert_RE[type], l;\n\tif(!length) length = XLSBRecordEnum[t].p || (payload||[]).length || 0;\n\tl = 1 + (t >= 0x80 ? 1 : 0) + 1 + length;\n\tif(length >= 0x80) ++l; if(length >= 0x4000) ++l; if(length >= 0x200000) ++l;\n\tvar o = ba.next(l);\n\tif(t <= 0x7F) o.write_shift(1, t);\n\telse {\n\t\to.write_shift(1, (t & 0x7F) + 0x80);\n\t\to.write_shift(1, (t >> 7));\n\t}\n\tfor(var i = 0; i != 4; ++i) {\n\t\tif(length >= 0x80) { o.write_shift(1, (length & 0x7F)+0x80); length >>= 7; }\n\t\telse { o.write_shift(1, length); break; }\n\t}\n\tif(length > 0 && is_buf(payload)) ba.push(payload);\n}\n/* XLS ranges enforced */\nfunction shift_cell_xls(cell, tgt) {\n\tif(tgt.s) {\n\t\tif(cell.cRel) cell.c += tgt.s.c;\n\t\tif(cell.rRel) cell.r += tgt.s.r;\n\t} else {\n\t\tcell.c += tgt.c;\n\t\tcell.r += tgt.r;\n\t}\n\tcell.cRel = cell.rRel = 0;\n\twhile(cell.c >= 0x100) cell.c -= 0x100;\n\twhile(cell.r >= 0x10000) cell.r -= 0x10000;\n\treturn cell;\n}\n\nfunction shift_range_xls(cell, range) {\n\tcell.s = shift_cell_xls(cell.s, range.s);\n\tcell.e = shift_cell_xls(cell.e, range.s);\n\treturn cell;\n}\n\nvar OFFCRYPTO = {};\nvar make_offcrypto = function(O, _crypto) {\n\tvar crypto;\n\tif(typeof _crypto !== 'undefined') crypto = _crypto;\n\telse if(typeof require !== 'undefined') {\n\t\ttry { crypto = require('cry'+'pto'); }\n\t\tcatch(e) { crypto = null; }\n\t}\n\n\tO.rc4 = function(key, data) {\n\t\tvar S = new Array(256);\n\t\tvar c = 0, i = 0, j = 0, t = 0;\n\t\tfor(i = 0; i != 256; ++i) S[i] = i;\n\t\tfor(i = 0; i != 256; ++i) {\n\t\t\tj = (j + S[i] + (key[i%key.length]).charCodeAt(0))&255;\n\t\t\tt = S[i]; S[i] = S[j]; S[j] = t;\n\t\t}\n\t\ti = j = 0; out = Buffer(data.length);\n\t\tfor(c = 0; c != data.length; ++c) {\n\t\t\ti = (i + 1)&255;\n\t\t\tj = (j + S[i])%256;\n\t\t\tt = S[i]; S[i] = S[j]; S[j] = t;\n\t\t\tout[c] = (data[c] ^ S[(S[i]+S[j])&255]);\n\t\t}\n\t\treturn out;\n\t};\n\n\tif(crypto) {\n\t\tO.md5 = function(hex) { return crypto.createHash('md5').update(hex).digest('hex'); };\n\t} else {\n\t\tO.md5 = function(hex) { throw \"unimplemented\"; };\n\t}\n};\nmake_offcrypto(OFFCRYPTO, typeof crypto !== \"undefined\" ? crypto : undefined);\n\n\n/* [MS-XLSB] 2.5.143 */\nfunction parse_StrRun(data, length) {\n\treturn { ich: data.read_shift(2), ifnt: data.read_shift(2) };\n}\n\n/* [MS-XLSB] 2.1.7.121 */\nfunction parse_RichStr(data, length) {\n\tvar start = data.l;\n\tvar flags = data.read_shift(1);\n\tvar str = parse_XLWideString(data);\n\tvar rgsStrRun = [];\n\tvar z = { t: str, h: str };\n\tif((flags & 1) !== 0) { /* fRichStr */\n\t\t/* TODO: formatted string */\n\t\tvar dwSizeStrRun = data.read_shift(4);\n\t\tfor(var i = 0; i != dwSizeStrRun; ++i) rgsStrRun.push(parse_StrRun(data));\n\t\tz.r = rgsStrRun;\n\t}\n\telse z.r = \"<t>\" + escapexml(str) + \"</t>\";\n\tif((flags & 2) !== 0) { /* fExtStr */\n\t\t/* TODO: phonetic string */\n\t}\n\tdata.l = start + length;\n\treturn z;\n}\nfunction write_RichStr(str, o) {\n\t/* TODO: formatted string */\n\tif(o == null) o = new_buf(5+2*str.t.length);\n\to.write_shift(1,0);\n\twrite_XLWideString(str.t, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.9 */\nfunction parse_XLSBCell(data) {\n\tvar col = data.read_shift(4);\n\tvar iStyleRef = data.read_shift(2);\n\tiStyleRef += data.read_shift(1) <<16;\n\tvar fPhShow = data.read_shift(1);\n\treturn { c:col, iStyleRef: iStyleRef };\n}\nfunction write_XLSBCell(cell, o) {\n\tif(o == null) o = new_buf(8);\n\to.write_shift(-4, cell.c);\n\to.write_shift(3, cell.iStyleRef === undefined ? cell.iStyleRef : cell.s);\n\to.write_shift(1, 0); /* fPhShow */\n\treturn o;\n}\n\n\n/* [MS-XLSB] 2.5.21 */\nfunction parse_XLSBCodeName (data, length) { return parse_XLWideString(data, length); }\n\n/* [MS-XLSB] 2.5.166 */\nfunction parse_XLNullableWideString(data) {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 || cchCharacters === 0xFFFFFFFF ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLNullableWideString(data, o) {\n\tif(!o) o = new_buf(127);\n\to.write_shift(4, data.length > 0 ? data.length : 0xFFFFFFFF);\n\tif(data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.168 */\nfunction parse_XLWideString(data) {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLWideString(data, o) {\n\tif(o == null) o = new_buf(4+2*data.length);\n\to.write_shift(4, data.length);\n\tif(data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.114 */\nvar parse_RelID = parse_XLNullableWideString;\nvar write_RelID = write_XLNullableWideString;\n\n\n/* [MS-XLSB] 2.5.122 */\n/* [MS-XLS] 2.5.217 */\nfunction parse_RkNumber(data) {\n\tvar b = data.slice(data.l, data.l+4);\n\tvar fX100 = b[0] & 1, fInt = b[0] & 2;\n\tdata.l+=4;\n\tb[0] &= 0xFC; // b[0] &= ~3;\n\tvar RK = fInt === 0 ? __double([0,0,0,0,b[0],b[1],b[2],b[3]],0) : __readInt32LE(b,0)>>2;\n\treturn fX100 ? RK/100 : RK;\n}\n\n/* [MS-XLSB] 2.5.153 */\nfunction parse_UncheckedRfX(data) {\n\tvar cell = {s: {}, e: {}};\n\tcell.s.r = data.read_shift(4);\n\tcell.e.r = data.read_shift(4);\n\tcell.s.c = data.read_shift(4);\n\tcell.e.c = data.read_shift(4);\n\treturn cell;\n}\n\nfunction write_UncheckedRfX(r, o) {\n\tif(!o) o = new_buf(16);\n\to.write_shift(4, r.s.r);\n\to.write_shift(4, r.e.r);\n\to.write_shift(4, r.s.c);\n\to.write_shift(4, r.e.c);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.171 */\n/* [MS-XLS] 2.5.342 */\nfunction parse_Xnum(data, length) { return data.read_shift(8, 'f'); }\nfunction write_Xnum(data, o) { return (o || new_buf(8)).write_shift(8, 'f', data); }\n\n/* [MS-XLSB] 2.5.198.2 */\nvar BErr = {\n\t0x00: \"#NULL!\",\n\t0x07: \"#DIV/0!\",\n\t0x0F: \"#VALUE!\",\n\t0x17: \"#REF!\",\n\t0x1D: \"#NAME?\",\n\t0x24: \"#NUM!\",\n\t0x2A: \"#N/A\",\n\t0x2B: \"#GETTING_DATA\",\n\t0xFF: \"#WTF?\"\n};\nvar RBErr = evert_num(BErr);\n\n/* [MS-XLSB] 2.4.321 BrtColor */\nfunction parse_BrtColor(data, length) {\n\tvar out = {};\n\tvar d = data.read_shift(1);\n\tout.fValidRGB = d & 1;\n\tout.xColorType = d >>> 1;\n\tout.index = data.read_shift(1);\n\tout.nTintAndShade = data.read_shift(2, 'i');\n\tout.bRed = data.read_shift(1);\n\tout.bGreen = data.read_shift(1);\n\tout.bBlue = data.read_shift(1);\n\tout.bAlpha = data.read_shift(1);\n}\n\n/* [MS-XLSB] 2.5.52 */\nfunction parse_FontFlags(data, length) {\n\tvar d = data.read_shift(1);\n\tdata.l++;\n\tvar out = {\n\t\tfItalic: d & 0x2,\n\t\tfStrikeout: d & 0x8,\n\t\tfOutline: d & 0x10,\n\t\tfShadow: d & 0x20,\n\t\tfCondense: d & 0x40,\n\t\tfExtend: d & 0x80\n\t};\n\treturn out;\n}\n/* [MS-OLEPS] 2.2 PropertyType */\n{\n\tvar VT_EMPTY = 0x0000;\n\tvar VT_NULL = 0x0001;\n\tvar VT_I2 = 0x0002;\n\tvar VT_I4 = 0x0003;\n\tvar VT_R4 = 0x0004;\n\tvar VT_R8 = 0x0005;\n\tvar VT_CY = 0x0006;\n\tvar VT_DATE = 0x0007;\n\tvar VT_BSTR = 0x0008;\n\tvar VT_ERROR = 0x000A;\n\tvar VT_BOOL = 0x000B;\n\tvar VT_VARIANT = 0x000C;\n\tvar VT_DECIMAL = 0x000E;\n\tvar VT_I1 = 0x0010;\n\tvar VT_UI1 = 0x0011;\n\tvar VT_UI2 = 0x0012;\n\tvar VT_UI4 = 0x0013;\n\tvar VT_I8 = 0x0014;\n\tvar VT_UI8 = 0x0015;\n\tvar VT_INT = 0x0016;\n\tvar VT_UINT = 0x0017;\n\tvar VT_LPSTR = 0x001E;\n\tvar VT_LPWSTR = 0x001F;\n\tvar VT_FILETIME = 0x0040;\n\tvar VT_BLOB = 0x0041;\n\tvar VT_STREAM = 0x0042;\n\tvar VT_STORAGE = 0x0043;\n\tvar VT_STREAMED_Object = 0x0044;\n\tvar VT_STORED_Object = 0x0045;\n\tvar VT_BLOB_Object = 0x0046;\n\tvar VT_CF = 0x0047;\n\tvar VT_CLSID = 0x0048;\n\tvar VT_VERSIONED_STREAM = 0x0049;\n\tvar VT_VECTOR = 0x1000;\n\tvar VT_ARRAY = 0x2000;\n\n\tvar VT_STRING = 0x0050; // 2.3.3.1.11 VtString\n\tvar VT_USTR = 0x0051; // 2.3.3.1.12 VtUnalignedString\n\tvar VT_CUSTOM = [VT_STRING, VT_USTR];\n}\n\n/* [MS-OSHARED] 2.3.3.2.2.1 Document Summary Information PIDDSI */\nvar DocSummaryPIDDSI = {\n\t0x01: { n: 'CodePage', t: VT_I2 },\n\t0x02: { n: 'Category', t: VT_STRING },\n\t0x03: { n: 'PresentationFormat', t: VT_STRING },\n\t0x04: { n: 'ByteCount', t: VT_I4 },\n\t0x05: { n: 'LineCount', t: VT_I4 },\n\t0x06: { n: 'ParagraphCount', t: VT_I4 },\n\t0x07: { n: 'SlideCount', t: VT_I4 },\n\t0x08: { n: 'NoteCount', t: VT_I4 },\n\t0x09: { n: 'HiddenCount', t: VT_I4 },\n\t0x0a: { n: 'MultimediaClipCount', t: VT_I4 },\n\t0x0b: { n: 'Scale', t: VT_BOOL },\n\t0x0c: { n: 'HeadingPair', t: VT_VECTOR | VT_VARIANT },\n\t0x0d: { n: 'DocParts', t: VT_VECTOR | VT_LPSTR },\n\t0x0e: { n: 'Manager', t: VT_STRING },\n\t0x0f: { n: 'Company', t: VT_STRING },\n\t0x10: { n: 'LinksDirty', t: VT_BOOL },\n\t0x11: { n: 'CharacterCount', t: VT_I4 },\n\t0x13: { n: 'SharedDoc', t: VT_BOOL },\n\t0x16: { n: 'HLinksChanged', t: VT_BOOL },\n\t0x17: { n: 'AppVersion', t: VT_I4, p: 'version' },\n\t0x1A: { n: 'ContentType', t: VT_STRING },\n\t0x1B: { n: 'ContentStatus', t: VT_STRING },\n\t0x1C: { n: 'Language', t: VT_STRING },\n\t0x1D: { n: 'Version', t: VT_STRING },\n\t0xFF: {}\n};\n\n/* [MS-OSHARED] 2.3.3.2.1.1 Summary Information Property Set PIDSI */\nvar SummaryPIDSI = {\n\t0x01: { n: 'CodePage', t: VT_I2 },\n\t0x02: { n: 'Title', t: VT_STRING },\n\t0x03: { n: 'Subject', t: VT_STRING },\n\t0x04: { n: 'Author', t: VT_STRING },\n\t0x05: { n: 'Keywords', t: VT_STRING },\n\t0x06: { n: 'Comments', t: VT_STRING },\n\t0x07: { n: 'Template', t: VT_STRING },\n\t0x08: { n: 'LastAuthor', t: VT_STRING },\n\t0x09: { n: 'RevNumber', t: VT_STRING },\n\t0x0A: { n: 'EditTime', t: VT_FILETIME },\n\t0x0B: { n: 'LastPrinted', t: VT_FILETIME },\n\t0x0C: { n: 'CreatedDate', t: VT_FILETIME },\n\t0x0D: { n: 'ModifiedDate', t: VT_FILETIME },\n\t0x0E: { n: 'PageCount', t: VT_I4 },\n\t0x0F: { n: 'WordCount', t: VT_I4 },\n\t0x10: { n: 'CharCount', t: VT_I4 },\n\t0x11: { n: 'Thumbnail', t: VT_CF },\n\t0x12: { n: 'ApplicationName', t: VT_LPSTR },\n\t0x13: { n: 'DocumentSecurity', t: VT_I4 },\n\t0xFF: {}\n};\n\n/* [MS-OLEPS] 2.18 */\nvar SpecialProperties = {\n\t0x80000000: { n: 'Locale', t: VT_UI4 },\n\t0x80000003: { n: 'Behavior', t: VT_UI4 },\n\t0x72627262: {}\n};\n\n(function() {\n\tfor(var y in SpecialProperties) if(SpecialProperties.hasOwnProperty(y))\n\tDocSummaryPIDDSI[y] = SummaryPIDSI[y] = SpecialProperties[y];\n})();\n\n/* [MS-XLS] 2.4.63 Country/Region codes */\nvar CountryEnum = {\n\t0x0001: \"US\", // United States\n\t0x0002: \"CA\", // Canada\n\t0x0003: \"\", // Latin America (except Brazil)\n\t0x0007: \"RU\", // Russia\n\t0x0014: \"EG\", // Egypt\n\t0x001E: \"GR\", // Greece\n\t0x001F: \"NL\", // Netherlands\n\t0x0020: \"BE\", // Belgium\n\t0x0021: \"FR\", // France\n\t0x0022: \"ES\", // Spain\n\t0x0024: \"HU\", // Hungary\n\t0x0027: \"IT\", // Italy\n\t0x0029: \"CH\", // Switzerland\n\t0x002B: \"AT\", // Austria\n\t0x002C: \"GB\", // United Kingdom\n\t0x002D: \"DK\", // Denmark\n\t0x002E: \"SE\", // Sweden\n\t0x002F: \"NO\", // Norway\n\t0x0030: \"PL\", // Poland\n\t0x0031: \"DE\", // Germany\n\t0x0034: \"MX\", // Mexico\n\t0x0037: \"BR\", // Brazil\n\t0x003d: \"AU\", // Australia\n\t0x0040: \"NZ\", // New Zealand\n\t0x0042: \"TH\", // Thailand\n\t0x0051: \"JP\", // Japan\n\t0x0052: \"KR\", // Korea\n\t0x0054: \"VN\", // Viet Nam\n\t0x0056: \"CN\", // China\n\t0x005A: \"TR\", // Turkey\n\t0x0069: \"JS\", // Ramastan\n\t0x00D5: \"DZ\", // Algeria\n\t0x00D8: \"MA\", // Morocco\n\t0x00DA: \"LY\", // Libya\n\t0x015F: \"PT\", // Portugal\n\t0x0162: \"IS\", // Iceland\n\t0x0166: \"FI\", // Finland\n\t0x01A4: \"CZ\", // Czech Republic\n\t0x0376: \"TW\", // Taiwan\n\t0x03C1: \"LB\", // Lebanon\n\t0x03C2: \"JO\", // Jordan\n\t0x03C3: \"SY\", // Syria\n\t0x03C4: \"IQ\", // Iraq\n\t0x03C5: \"KW\", // Kuwait\n\t0x03C6: \"SA\", // Saudi Arabia\n\t0x03CB: \"AE\", // United Arab Emirates\n\t0x03CC: \"IL\", // Israel\n\t0x03CE: \"QA\", // Qatar\n\t0x03D5: \"IR\", // Iran\n\t0xFFFF: \"US\" // United States\n};\n\n/* [MS-XLS] 2.5.127 */\nvar XLSFillPattern = [\n\tnull,\n\t'solid',\n\t'mediumGray',\n\t'darkGray',\n\t'lightGray',\n\t'darkHorizontal',\n\t'darkVertical',\n\t'darkDown',\n\t'darkUp',\n\t'darkGrid',\n\t'darkTrellis',\n\t'lightHorizontal',\n\t'lightVertical',\n\t'lightDown',\n\t'lightUp',\n\t'lightGrid',\n\t'lightTrellis',\n\t'gray125',\n\t'gray0625'\n];\n\nfunction rgbify(arr) { return arr.map(function(x) { return [(x>>16)&255,(x>>8)&255,x&255]; }); }\n\n/* [MS-XLS] 2.5.161 */\nvar XLSIcv = rgbify([\n\t/* Color Constants */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t/* Defaults */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t0x800000,\n\t0x008000,\n\t0x000080,\n\t0x808000,\n\t0x800080,\n\t0x008080,\n\t0xC0C0C0,\n\t0x808080,\n\t0x9999FF,\n\t0x993366,\n\t0xFFFFCC,\n\t0xCCFFFF,\n\t0x660066,\n\t0xFF8080,\n\t0x0066CC,\n\t0xCCCCFF,\n\n\t0x000080,\n\t0xFF00FF,\n\t0xFFFF00,\n\t0x00FFFF,\n\t0x800080,\n\t0x800000,\n\t0x008080,\n\t0x0000FF,\n\t0x00CCFF,\n\t0xCCFFFF,\n\t0xCCFFCC,\n\t0xFFFF99,\n\t0x99CCFF,\n\t0xFF99CC,\n\t0xCC99FF,\n\t0xFFCC99,\n\n\t0x3366FF,\n\t0x33CCCC,\n\t0x99CC00,\n\t0xFFCC00,\n\t0xFF9900,\n\t0xFF6600,\n\t0x666699,\n\t0x969696,\n\t0x003366,\n\t0x339966,\n\t0x003300,\n\t0x333300,\n\t0x993300,\n\t0x993366,\n\t0x333399,\n\t0x333333,\n\n\t/* Sheet */\n\t0xFFFFFF,\n\t0x000000\n]);\n\n/* Parts enumerated in OPC spec, MS-XLSB and MS-XLSX */\n/* 12.3 Part Summary <SpreadsheetML> */\n/* 14.2 Part Summary <DrawingML> */\n/* [MS-XLSX] 2.1 Part Enumerations */\n/* [MS-XLSB] 2.1.7 Part Enumeration */\nvar ct2type = {\n\t/* Workbook */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\": \"workbooks\",\n\n\t/* Worksheet */\n\t\"application/vnd.ms-excel.binIndexWs\": \"TODO\", /* Binary Index */\n\n\t/* Chartsheet */\n\t\"application/vnd.ms-excel.chartsheet\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\": \"TODO\",\n\n\t/* Dialogsheet */\n\t\"application/vnd.ms-excel.dialogsheet\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\": \"TODO\",\n\n\t/* Macrosheet */\n\t\"application/vnd.ms-excel.macrosheet\": \"TODO\",\n\t\"application/vnd.ms-excel.macrosheet+xml\": \"TODO\",\n\t\"application/vnd.ms-excel.intlmacrosheet\": \"TODO\",\n\t\"application/vnd.ms-excel.binIndexMs\": \"TODO\", /* Binary Index */\n\n\t/* File Properties */\n\t\"application/vnd.openxmlformats-package.core-properties+xml\": \"coreprops\",\n\t\"application/vnd.openxmlformats-officedocument.custom-properties+xml\": \"custprops\",\n\t\"application/vnd.openxmlformats-officedocument.extended-properties+xml\": \"extprops\",\n\n\t/* Custom Data Properties */\n\t\"application/vnd.openxmlformats-officedocument.customXmlProperties+xml\": \"TODO\",\n\n\t/* Comments */\n\t\"application/vnd.ms-excel.comments\": \"comments\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\": \"comments\",\n\n\t/* PivotTable */\n\t\"application/vnd.ms-excel.pivotTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml\": \"TODO\",\n\n\t/* Calculation Chain */\n\t\"application/vnd.ms-excel.calcChain\": \"calcchains\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.calcChain+xml\": \"calcchains\",\n\n\t/* Printer Settings */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.printerSettings\": \"TODO\",\n\n\t/* ActiveX */\n\t\"application/vnd.ms-office.activeX\": \"TODO\",\n\t\"application/vnd.ms-office.activeX+xml\": \"TODO\",\n\n\t/* Custom Toolbars */\n\t\"application/vnd.ms-excel.attachedToolbars\": \"TODO\",\n\n\t/* External Data Connections */\n\t\"application/vnd.ms-excel.connections\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml\": \"TODO\",\n\n\t/* External Links */\n\t\"application/vnd.ms-excel.externalLink\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml\": \"TODO\",\n\n\t/* Metadata */\n\t\"application/vnd.ms-excel.sheetMetadata\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml\": \"TODO\",\n\n\t/* PivotCache */\n\t\"application/vnd.ms-excel.pivotCacheDefinition\": \"TODO\",\n\t\"application/vnd.ms-excel.pivotCacheRecords\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheDefinition+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheRecords+xml\": \"TODO\",\n\n\t/* Query Table */\n\t\"application/vnd.ms-excel.queryTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.queryTable+xml\": \"TODO\",\n\n\t/* Shared Workbook */\n\t\"application/vnd.ms-excel.userNames\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionHeaders\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionLog\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionHeaders+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionLog+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.userNames+xml\": \"TODO\",\n\n\t/* Single Cell Table */\n\t\"application/vnd.ms-excel.tableSingleCells\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.tableSingleCells+xml\": \"TODO\",\n\n\t/* Slicer */\n\t\"application/vnd.ms-excel.slicer\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache\": \"TODO\",\n\t\"application/vnd.ms-excel.slicer+xml\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache+xml\": \"TODO\",\n\n\t/* Sort Map */\n\t\"application/vnd.ms-excel.wsSortMap\": \"TODO\",\n\n\t/* Table */\n\t\"application/vnd.ms-excel.table\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml\": \"TODO\",\n\n\t/* Themes */\n\t\"application/vnd.openxmlformats-officedocument.theme+xml\": \"themes\",\n\n\t/* Timeline */\n\t\"application/vnd.ms-excel.Timeline+xml\": \"TODO\", /* verify */\n\t\"application/vnd.ms-excel.TimelineCache+xml\": \"TODO\", /* verify */\n\n\t/* VBA */\n\t\"application/vnd.ms-office.vbaProject\": \"vba\",\n\t\"application/vnd.ms-office.vbaProjectSignature\": \"vba\",\n\n\t/* Volatile Dependencies */\n\t\"application/vnd.ms-office.volatileDependencies\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.volatileDependencies+xml\": \"TODO\",\n\n\t/* Control Properties */\n\t\"application/vnd.ms-excel.controlproperties+xml\": \"TODO\",\n\n\t/* Data Model */\n\t\"application/vnd.openxmlformats-officedocument.model+data\": \"TODO\",\n\n\t/* Survey */\n\t\"application/vnd.ms-excel.Survey+xml\": \"TODO\",\n\n\t/* Drawing */\n\t\"application/vnd.openxmlformats-officedocument.drawing+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chart+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramColors+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramData+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramLayout+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramStyle+xml\": \"TODO\",\n\n\t/* VML */\n\t\"application/vnd.openxmlformats-officedocument.vmlDrawing\": \"TODO\",\n\n\t\"application/vnd.openxmlformats-package.relationships+xml\": \"rels\",\n\t\"application/vnd.openxmlformats-officedocument.oleObject\": \"TODO\",\n\n\t\"sheet\": \"js\"\n};\n\nvar CT_LIST = (function(){\n\tvar o = {\n\t\tworkbooks: {\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\",\n\t\t\txlsm: \"application/vnd.ms-excel.sheet.macroEnabled.main+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sheet.binary.macroEnabled.main\",\n\t\t\txltx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\"\n\t\t},\n\t\tstrs: { /* Shared Strings */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sharedStrings\"\n\t\t},\n\t\tsheets: {\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.worksheet\"\n\t\t},\n\t\tstyles: {/* Styles */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.styles\"\n\t\t}\n\t};\n\tkeys(o).forEach(function(k) { if(!o[k].xlsm) o[k].xlsm = o[k].xlsx; });\n\tkeys(o).forEach(function(k){ keys(o[k]).forEach(function(v) { ct2type[o[k][v]] = k; }); });\n\treturn o;\n})();\n\nvar type2ct = evert_arr(ct2type);\n\nXMLNS.CT = 'http://schemas.openxmlformats.org/package/2006/content-types';\n\nfunction parse_ct(data, opts) {\n\tvar ctext = {};\n\tif(!data || !data.match) return data;\n\tvar ct = { workbooks: [], sheets: [], calcchains: [], themes: [], styles: [],\n\t\tcoreprops: [], extprops: [], custprops: [], strs:[], comments: [], vba: [],\n\t\tTODO:[], rels:[], xmlns: \"\" };\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0].replace(nsregex,\"<\")) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Types': ct.xmlns = y['xmlns' + (y[0].match(/<(\\w+):/)||[\"\",\"\"])[1] ]; break;\n\t\t\tcase '<Default': ctext[y.Extension] = y.ContentType; break;\n\t\t\tcase '<Override':\n\t\t\t\tif(ct[ct2type[y.ContentType]] !== undefined) ct[ct2type[y.ContentType]].push(y.PartName);\n\t\t\t\telse if(opts.WTF) console.error(y);\n\t\t\t\tbreak;\n\t\t}\n\t});\n\tif(ct.xmlns !== XMLNS.CT) throw new Error(\"Unknown Namespace: \" + ct.xmlns);\n\tct.calcchain = ct.calcchains.length > 0 ? ct.calcchains[0] : \"\";\n\tct.sst = ct.strs.length > 0 ? ct.strs[0] : \"\";\n\tct.style = ct.styles.length > 0 ? ct.styles[0] : \"\";\n\tct.defaults = ctext;\n\tdelete ct.calcchains;\n\treturn ct;\n}\n\nvar CTYPE_XML_ROOT = writextag('Types', null, {\n\t'xmlns': XMLNS.CT,\n\t'xmlns:xsd': XMLNS.xsd,\n\t'xmlns:xsi': XMLNS.xsi\n});\n\nvar CTYPE_DEFAULTS = [\n\t['xml', 'application/xml'],\n\t['bin', 'application/vnd.ms-excel.sheet.binary.macroEnabled.main'],\n\t['rels', type2ct.rels[0]]\n].map(function(x) {\n\treturn writextag('Default', null, {'Extension':x[0], 'ContentType': x[1]});\n});\n\nfunction write_ct(ct, opts) {\n\tvar o = [], v;\n\to[o.length] = (XML_HEADER);\n\to[o.length] = (CTYPE_XML_ROOT);\n\to = o.concat(CTYPE_DEFAULTS);\n\tvar f1 = function(w) {\n\t\tif(ct[w] && ct[w].length > 0) {\n\t\t\tv = ct[w][0];\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType || 'xlsx']\n\t\t\t}));\n\t\t}\n\t};\n\tvar f2 = function(w) {\n\t\tct[w].forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType || 'xlsx']\n\t\t\t}));\n\t\t});\n\t};\n\tvar f3 = function(t) {\n\t\t(ct[t]||[]).forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': type2ct[t][0]\n\t\t\t}));\n\t\t});\n\t};\n\tf1('workbooks');\n\tf2('sheets');\n\tf3('themes');\n\t['strs', 'styles'].forEach(f1);\n\t['coreprops', 'extprops', 'custprops'].forEach(f3);\n\tif(o.length>2){ o[o.length] = ('</Types>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 9.3.2 OPC Relationships Markup */\nvar RELS = {\n\tWB: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\",\n\tSHEET: \"http://sheetjs.openxmlformats.org/officeDocument/2006/relationships/officeDocument\"\n};\n\nfunction parse_rels(data, currentFilePath) {\n\tif (!data) return data;\n\tif (currentFilePath.charAt(0) !== '/') {\n\t\tcurrentFilePath = '/'+currentFilePath;\n\t}\n\tvar rels = {};\n\tvar hash = {};\n\tvar resolveRelativePathIntoAbsolute = function (to) {\n\t\tvar toksFrom = currentFilePath.split('/');\n\t\ttoksFrom.pop(); // folder path\n\t\tvar toksTo = to.split('/');\n\t\tvar reversed = [];\n\t\twhile (toksTo.length !== 0) {\n\t\t\tvar tokTo = toksTo.shift();\n\t\t\tif (tokTo === '..') {\n\t\t\t\ttoksFrom.pop();\n\t\t\t} else if (tokTo !== '.') {\n\t\t\t\ttoksFrom.push(tokTo);\n\t\t\t}\n\t\t}\n\t\treturn toksFrom.join('/');\n\t};\n\n\tdata.match(tagregex).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\t/* 9.3.2.2 OPC_Relationships */\n\t\tif (y[0] === '<Relationship') {\n\t\t\tvar rel = {}; rel.Type = y.Type; rel.Target = y.Target; rel.Id = y.Id; rel.TargetMode = y.TargetMode;\n\t\t\tvar canonictarget = y.TargetMode === 'External' ? y.Target : resolveRelativePathIntoAbsolute(y.Target);\n\t\t\trels[canonictarget] = rel;\n\t\t\thash[y.Id] = rel;\n\t\t}\n\t});\n\trels[\"!id\"] = hash;\n\treturn rels;\n}\n\nXMLNS.RELS = 'http://schemas.openxmlformats.org/package/2006/relationships';\n\nvar RELS_ROOT = writextag('Relationships', null, {\n\t//'xmlns:ns0': XMLNS.RELS,\n\t'xmlns': XMLNS.RELS\n});\n\n/* TODO */\nfunction write_rels(rels) {\n\tvar o = [];\n\to[o.length] = (XML_HEADER);\n\to[o.length] = (RELS_ROOT);\n\tkeys(rels['!id']).forEach(function(rid) { var rel = rels['!id'][rid];\n\t\to[o.length] = (writextag('Relationship', null, rel));\n\t});\n\tif(o.length>2){ o[o.length] = ('</Relationships>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* ECMA-376 Part II 11.1 Core Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar CORE_PROPS = [\n\t[\"cp:category\", \"Category\"],\n\t[\"cp:contentStatus\", \"ContentStatus\"],\n\t[\"cp:keywords\", \"Keywords\"],\n\t[\"cp:lastModifiedBy\", \"LastAuthor\"],\n\t[\"cp:lastPrinted\", \"LastPrinted\"],\n\t[\"cp:revision\", \"RevNumber\"],\n\t[\"cp:version\", \"Version\"],\n\t[\"dc:creator\", \"Author\"],\n\t[\"dc:description\", \"Comments\"],\n\t[\"dc:identifier\", \"Identifier\"],\n\t[\"dc:language\", \"Language\"],\n\t[\"dc:subject\", \"Subject\"],\n\t[\"dc:title\", \"Title\"],\n\t[\"dcterms:created\", \"CreatedDate\", 'date'],\n\t[\"dcterms:modified\", \"ModifiedDate\", 'date']\n];\n\nXMLNS.CORE_PROPS = \"http://schemas.openxmlformats.org/package/2006/metadata/core-properties\";\nRELS.CORE_PROPS = 'http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties';\n\nvar CORE_PROPS_REGEX = (function() {\n\tvar r = new Array(CORE_PROPS.length);\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i];\n\t\tvar g = \"(?:\"+ f[0].substr(0,f[0].indexOf(\":\")) +\":)\"+ f[0].substr(f[0].indexOf(\":\")+1);\n\t\tr[i] = new RegExp(\"<\" + g + \"[^>]*>(.*)<\\/\" + g + \">\");\n\t}\n\treturn r;\n})();\n\nfunction parse_core_props(data) {\n\tvar p = {};\n\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i], cur = data.match(CORE_PROPS_REGEX[i]);\n\t\tif(cur != null && cur.length > 0) p[f[1]] = cur[1];\n\t\tif(f[2] === 'date' && p[f[1]]) p[f[1]] = new Date(p[f[1]]);\n\t}\n\n\treturn p;\n}\n\nvar CORE_PROPS_XML_ROOT = writextag('cp:coreProperties', null, {\n\t//'xmlns': XMLNS.CORE_PROPS,\n\t'xmlns:cp': XMLNS.CORE_PROPS,\n\t'xmlns:dc': XMLNS.dc,\n\t'xmlns:dcterms': XMLNS.dcterms,\n\t'xmlns:dcmitype': XMLNS.dcmitype,\n\t'xmlns:xsi': XMLNS.xsi\n});\n\nfunction cp_doit(f, g, h, o, p) {\n\tif(p[f] != null || g == null || g === \"\") return;\n\tp[f] = g;\n\to[o.length] = (h ? writextag(f,g,h) : writetag(f,g));\n}\n\nfunction write_core_props(cp, opts) {\n\tvar o = [XML_HEADER, CORE_PROPS_XML_ROOT], p = {};\n\tif(!cp) return o.join(\"\");\n\n\n\tif(cp.CreatedDate != null) cp_doit(\"dcterms:created\", typeof cp.CreatedDate === \"string\" ? cp.CreatedDate : write_w3cdtf(cp.CreatedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\tif(cp.ModifiedDate != null) cp_doit(\"dcterms:modified\", typeof cp.ModifiedDate === \"string\" ? cp.ModifiedDate : write_w3cdtf(cp.ModifiedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\n\tfor(var i = 0; i != CORE_PROPS.length; ++i) { var f = CORE_PROPS[i]; cp_doit(f[0], cp[f[1]], null, o, p); }\n\tif(o.length>2){ o[o.length] = ('</cp:coreProperties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.3 Extended File Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar EXT_PROPS = [\n\t[\"Application\", \"Application\", \"string\"],\n\t[\"AppVersion\", \"AppVersion\", \"string\"],\n\t[\"Company\", \"Company\", \"string\"],\n\t[\"DocSecurity\", \"DocSecurity\", \"string\"],\n\t[\"Manager\", \"Manager\", \"string\"],\n\t[\"HyperlinksChanged\", \"HyperlinksChanged\", \"bool\"],\n\t[\"SharedDoc\", \"SharedDoc\", \"bool\"],\n\t[\"LinksUpToDate\", \"LinksUpToDate\", \"bool\"],\n\t[\"ScaleCrop\", \"ScaleCrop\", \"bool\"],\n\t[\"HeadingPairs\", \"HeadingPairs\", \"raw\"],\n\t[\"TitlesOfParts\", \"TitlesOfParts\", \"raw\"]\n];\n\nXMLNS.EXT_PROPS = \"http://schemas.openxmlformats.org/officeDocument/2006/extended-properties\";\nRELS.EXT_PROPS = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties';\n\nfunction parse_ext_props(data, p) {\n\tvar q = {}; if(!p) p = {};\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tswitch(f[2]) {\n\t\t\tcase \"string\": p[f[1]] = (data.match(matchtag(f[0]))||[])[1]; break;\n\t\t\tcase \"bool\": p[f[1]] = (data.match(matchtag(f[0]))||[])[1] === \"true\"; break;\n\t\t\tcase \"raw\":\n\t\t\t\tvar cur = data.match(new RegExp(\"<\" + f[0] + \"[^>]*>(.*)<\\/\" + f[0] + \">\"));\n\t\t\t\tif(cur && cur.length > 0) q[f[1]] = cur[1];\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(q.HeadingPairs && q.TitlesOfParts) {\n\t\tvar v = parseVector(q.HeadingPairs);\n\t\tvar j = 0, widx = 0;\n\t\tfor(var i = 0; i !== v.length; ++i) {\n\t\t\tswitch(v[i].v) {\n\t\t\t\tcase \"Worksheets\": widx = j; p.Worksheets = +(v[++i].v); break;\n\t\t\t\tcase \"Named Ranges\": ++i; break; // TODO: Handle Named Ranges\n\t\t\t}\n\t\t}\n\t\tvar parts = parseVector(q.TitlesOfParts).map(function(x) { return utf8read(x.v); });\n\t\tp.SheetNames = parts.slice(widx, widx + p.Worksheets);\n\t}\n\treturn p;\n}\n\nvar EXT_PROPS_XML_ROOT = writextag('Properties', null, {\n\t'xmlns': XMLNS.EXT_PROPS,\n\t'xmlns:vt': XMLNS.vt\n});\n\nfunction write_ext_props(cp, opts) {\n\tvar o = [], p = {}, W = writextag;\n\tif(!cp) cp = {};\n\tcp.Application = \"SheetJS\";\n\to[o.length] = (XML_HEADER);\n\to[o.length] = (EXT_PROPS_XML_ROOT);\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tif(cp[f[1]] === undefined) return;\n\t\tvar v;\n\t\tswitch(f[2]) {\n\t\t\tcase 'string': v = cp[f[1]]; break;\n\t\t\tcase 'bool': v = cp[f[1]] ? 'true' : 'false'; break;\n\t\t}\n\t\tif(v !== undefined) o[o.length] = (W(f[0], v));\n\t});\n\n\t/* TODO: HeadingPairs, TitlesOfParts */\n\to[o.length] = (W('HeadingPairs', W('vt:vector', W('vt:variant', '<vt:lpstr>Worksheets</vt:lpstr>')+W('vt:variant', W('vt:i4', String(cp.Worksheets))), {size:2, baseType:\"variant\"})));\n\to[o.length] = (W('TitlesOfParts', W('vt:vector', cp.SheetNames.map(function(s) { return \"<vt:lpstr>\" + s + \"</vt:lpstr>\"; }).join(\"\"), {size: cp.Worksheets, baseType:\"lpstr\"})));\n\tif(o.length>2){ o[o.length] = ('</Properties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.2 Custom File Properties Part */\nXMLNS.CUST_PROPS = \"http://schemas.openxmlformats.org/officeDocument/2006/custom-properties\";\nRELS.CUST_PROPS = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/custom-properties';\n\nvar custregex = /<[^>]+>[^<]*/g;\nfunction parse_cust_props(data, opts) {\n\tvar p = {}, name;\n\tvar m = data.match(custregex);\n\tif(m) for(var i = 0; i != m.length; ++i) {\n\t\tvar x = m[i], y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Properties':\n\t\t\t\tif(y.xmlns !== XMLNS.CUST_PROPS) throw \"unrecognized xmlns \" + y.xmlns;\n\t\t\t\tif(y.xmlnsvt && y.xmlnsvt !== XMLNS.vt) throw \"unrecognized vt \" + y.xmlnsvt;\n\t\t\t\tbreak;\n\t\t\tcase '<property': name = y.name; break;\n\t\t\tcase '</property>': name = null; break;\n\t\t\tdefault: if (x.indexOf('<vt:') === 0) {\n\t\t\t\tvar toks = x.split('>');\n\t\t\t\tvar type = toks[0].substring(4), text = toks[1];\n\t\t\t\t/* 22.4.2.32 (CT_Variant). Omit the binary types from 22.4 (Variant Types) */\n\t\t\t\tswitch(type) {\n\t\t\t\t\tcase 'lpstr': case 'lpwstr': case 'bstr': case 'lpwstr':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'bool':\n\t\t\t\t\t\tp[name] = parsexmlbool(text, '<vt:bool>');\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'i1': case 'i2': case 'i4': case 'i8': case 'int': case 'uint':\n\t\t\t\t\t\tp[name] = parseInt(text, 10);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'r4': case 'r8': case 'decimal':\n\t\t\t\t\t\tp[name] = parseFloat(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'filetime': case 'date':\n\t\t\t\t\t\tp[name] = new Date(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'cy': case 'error':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(typeof console !== 'undefined') console.warn('Unexpected', x, type, toks);\n\t\t\t\t}\n\t\t\t} else if(x.substr(0,2) === \"</\") {\n\t\t\t} else if(opts.WTF) throw new Error(x);\n\t\t}\n\t}\n\treturn p;\n}\n\nvar CUST_PROPS_XML_ROOT = writextag('Properties', null, {\n\t'xmlns': XMLNS.CUST_PROPS,\n\t'xmlns:vt': XMLNS.vt\n});\n\nfunction write_cust_props(cp, opts) {\n\tvar o = [XML_HEADER, CUST_PROPS_XML_ROOT];\n\tif(!cp) return o.join(\"\");\n\tvar pid = 1;\n\tkeys(cp).forEach(function custprop(k) { ++pid;\n\t\to[o.length] = (writextag('property', write_vt(cp[k]), {\n\t\t\t'fmtid': '{D5CDD505-2E9C-101B-9397-08002B2CF9AE}',\n\t\t\t'pid': pid,\n\t\t\t'name': k\n\t\t}));\n\t});\n\tif(o.length>2){ o[o.length] = '</Properties>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\nfunction xlml_set_prop(Props, tag, val) {\n\t/* TODO: Normalize the properties */\n\tswitch(tag) {\n\t\tcase 'Description': tag = 'Comments'; break;\n\t}\n\tProps[tag] = val;\n}\n\n/* [MS-DTYP] 2.3.3 FILETIME */\n/* [MS-OLEDS] 2.1.3 FILETIME (Packet Version) */\n/* [MS-OLEPS] 2.8 FILETIME (Packet Version) */\nfunction parse_FILETIME(blob) {\n\tvar dwLowDateTime = blob.read_shift(4), dwHighDateTime = blob.read_shift(4);\n\treturn new Date(((dwHighDateTime/1e7*Math.pow(2,32) + dwLowDateTime/1e7) - 11644473600)*1000).toISOString().replace(/\\.000/,\"\");\n}\n\n/* [MS-OSHARED] 2.3.3.1.4 Lpstr */\nfunction parse_lpstr(blob, type, pad) {\n\tvar str = blob.read_shift(0, 'lpstr');\n\tif(pad) blob.l += (4 - ((str.length+1) & 3)) & 3;\n\treturn str;\n}\n\n/* [MS-OSHARED] 2.3.3.1.6 Lpwstr */\nfunction parse_lpwstr(blob, type, pad) {\n\tvar str = blob.read_shift(0, 'lpwstr');\n\tif(pad) blob.l += (4 - ((str.length+1) & 3)) & 3;\n\treturn str;\n}\n\n\n/* [MS-OSHARED] 2.3.3.1.11 VtString */\n/* [MS-OSHARED] 2.3.3.1.12 VtUnalignedString */\nfunction parse_VtStringBase(blob, stringType, pad) {\n\tif(stringType === 0x1F /*VT_LPWSTR*/) return parse_lpwstr(blob);\n\treturn parse_lpstr(blob, stringType, pad);\n}\n\nfunction parse_VtString(blob, t, pad) { return parse_VtStringBase(blob, t, pad === false ? 0: 4); }\nfunction parse_VtUnalignedString(blob, t) { if(!t) throw new Error(\"dafuq?\"); return parse_VtStringBase(blob, t, 0); }\n\n/* [MS-OSHARED] 2.3.3.1.9 VtVecUnalignedLpstrValue */\nfunction parse_VtVecUnalignedLpstrValue(blob) {\n\tvar length = blob.read_shift(4);\n\tvar ret = [];\n\tfor(var i = 0; i != length; ++i) ret[i] = blob.read_shift(0, 'lpstr');\n\treturn ret;\n}\n\n/* [MS-OSHARED] 2.3.3.1.10 VtVecUnalignedLpstr */\nfunction parse_VtVecUnalignedLpstr(blob) {\n\treturn parse_VtVecUnalignedLpstrValue(blob);\n}\n\n/* [MS-OSHARED] 2.3.3.1.13 VtHeadingPair */\nfunction parse_VtHeadingPair(blob) {\n\tvar headingString = parse_TypedPropertyValue(blob, VT_USTR);\n\tvar headerParts = parse_TypedPropertyValue(blob, VT_I4);\n\treturn [headingString, headerParts];\n}\n\n/* [MS-OSHARED] 2.3.3.1.14 VtVecHeadingPairValue */\nfunction parse_VtVecHeadingPairValue(blob) {\n\tvar cElements = blob.read_shift(4);\n\tvar out = [];\n\tfor(var i = 0; i != cElements / 2; ++i) out.push(parse_VtHeadingPair(blob));\n\treturn out;\n}\n\n/* [MS-OSHARED] 2.3.3.1.15 VtVecHeadingPair */\nfunction parse_VtVecHeadingPair(blob) {\n\t// NOTE: When invoked, wType & padding were already consumed\n\treturn parse_VtVecHeadingPairValue(blob);\n}\n\n/* [MS-OLEPS] 2.18.1 Dictionary (uses 2.17, 2.16) */\nfunction parse_dictionary(blob,CodePage) {\n\tvar cnt = blob.read_shift(4);\n\tvar dict = {};\n\tfor(var j = 0; j != cnt; ++j) {\n\t\tvar pid = blob.read_shift(4);\n\t\tvar len = blob.read_shift(4);\n\t\tdict[pid] = blob.read_shift(len, (CodePage === 0x4B0 ?'utf16le':'utf8')).replace(chr0,'').replace(chr1,'!');\n\t}\n\tif(blob.l & 3) blob.l = (blob.l>>2+1)<<2;\n\treturn dict;\n}\n\n/* [MS-OLEPS] 2.9 BLOB */\nfunction parse_BLOB(blob) {\n\tvar size = blob.read_shift(4);\n\tvar bytes = blob.slice(blob.l,blob.l+size);\n\tif(size & 3 > 0) blob.l += (4 - (size & 3)) & 3;\n\treturn bytes;\n}\n\n/* [MS-OLEPS] 2.11 ClipboardData */\nfunction parse_ClipboardData(blob) {\n\t// TODO\n\tvar o = {};\n\to.Size = blob.read_shift(4);\n\t//o.Format = blob.read_shift(4);\n\tblob.l += o.Size;\n\treturn o;\n}\n\n/* [MS-OLEPS] 2.14 Vector and Array Property Types */\nfunction parse_VtVector(blob, cb) {\n\t/* [MS-OLEPS] 2.14.2 VectorHeader */\n/*\tvar Length = blob.read_shift(4);\n\tvar o = [];\n\tfor(var i = 0; i != Length; ++i) {\n\t\to.push(cb(blob));\n\t}\n\treturn o;*/\n}\n\n/* [MS-OLEPS] 2.15 TypedPropertyValue */\nfunction parse_TypedPropertyValue(blob, type, _opts) {\n\tvar t = blob.read_shift(2), ret, opts = _opts||{};\n\tblob.l += 2;\n\tif(type !== VT_VARIANT)\n\tif(t !== type && VT_CUSTOM.indexOf(type)===-1) throw new Error('Expected type ' + type + ' saw ' + t);\n\tswitch(type === VT_VARIANT ? t : type) {\n\t\tcase 0x02 /*VT_I2*/: ret = blob.read_shift(2, 'i'); if(!opts.raw) blob.l += 2; return ret;\n\t\tcase 0x03 /*VT_I4*/: ret = blob.read_shift(4, 'i'); return ret;\n\t\tcase 0x0B /*VT_BOOL*/: return blob.read_shift(4) !== 0x0;\n\t\tcase 0x13 /*VT_UI4*/: ret = blob.read_shift(4); return ret;\n\t\tcase 0x1E /*VT_LPSTR*/: return parse_lpstr(blob, t, 4).replace(chr0,'');\n\t\tcase 0x1F /*VT_LPWSTR*/: return parse_lpwstr(blob);\n\t\tcase 0x40 /*VT_FILETIME*/: return parse_FILETIME(blob);\n\t\tcase 0x41 /*VT_BLOB*/: return parse_BLOB(blob);\n\t\tcase 0x47 /*VT_CF*/: return parse_ClipboardData(blob);\n\t\tcase 0x50 /*VT_STRING*/: return parse_VtString(blob, t, !opts.raw && 4).replace(chr0,'');\n\t\tcase 0x51 /*VT_USTR*/: return parse_VtUnalignedString(blob, t, 4).replace(chr0,'');\n\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: return parse_VtVecHeadingPair(blob);\n\t\tcase 0x101E /*VT_LPSTR*/: return parse_VtVecUnalignedLpstr(blob);\n\t\tdefault: throw new Error(\"TypedPropertyValue unrecognized type \" + type + \" \" + t);\n\t}\n}\n/* [MS-OLEPS] 2.14.2 VectorHeader */\n/*function parse_VTVectorVariant(blob) {\n\tvar Length = blob.read_shift(4);\n\n\tif(Length & 1 !== 0) throw new Error(\"VectorHeader Length=\" + Length + \" must be even\");\n\tvar o = [];\n\tfor(var i = 0; i != Length; ++i) {\n\t\to.push(parse_TypedPropertyValue(blob, VT_VARIANT));\n\t}\n\treturn o;\n}*/\n\n/* [MS-OLEPS] 2.20 PropertySet */\nfunction parse_PropertySet(blob, PIDSI) {\n\tvar start_addr = blob.l;\n\tvar size = blob.read_shift(4);\n\tvar NumProps = blob.read_shift(4);\n\tvar Props = [], i = 0;\n\tvar CodePage = 0;\n\tvar Dictionary = -1, DictObj;\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tvar PropID = blob.read_shift(4);\n\t\tvar Offset = blob.read_shift(4);\n\t\tProps[i] = [PropID, Offset + start_addr];\n\t}\n\tvar PropH = {};\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tif(blob.l !== Props[i][1]) {\n\t\t\tvar fail = true;\n\t\t\tif(i>0 && PIDSI) switch(PIDSI[Props[i-1][0]].t) {\n\t\t\t\tcase 0x02 /*VT_I2*/: if(blob.l +2 === Props[i][1]) { blob.l+=2; fail = false; } break;\n\t\t\t\tcase 0x50 /*VT_STRING*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t}\n\t\t\tif(!PIDSI && blob.l <= Props[i][1]) { fail=false; blob.l = Props[i][1]; }\n\t\t\tif(fail) throw new Error(\"Read Error: Expected address \" + Props[i][1] + ' at ' + blob.l + ' :' + i);\n\t\t}\n\t\tif(PIDSI) {\n\t\t\tvar piddsi = PIDSI[Props[i][0]];\n\t\t\tPropH[piddsi.n] = parse_TypedPropertyValue(blob, piddsi.t, {raw:true});\n\t\t\tif(piddsi.p === 'version') PropH[piddsi.n] = String(PropH[piddsi.n] >> 16) + \".\" + String(PropH[piddsi.n] & 0xFFFF);\n\t\t\tif(piddsi.n == \"CodePage\") switch(PropH[piddsi.n]) {\n\t\t\t\tcase 0: PropH[piddsi.n] = 1252;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 10000: // OSX Roman\n\t\t\t\tcase 1252: // Windows Latin\n\n\t\t\t\tcase 874: // SB Windows Thai\n\t\t\t\tcase 1250: // SB Windows Central Europe\n\t\t\t\tcase 1251: // SB Windows Cyrillic\n\t\t\t\tcase 1253: // SB Windows Greek\n\t\t\t\tcase 1254: // SB Windows Turkish\n\t\t\t\tcase 1255: // SB Windows Hebrew\n\t\t\t\tcase 1256: // SB Windows Arabic\n\t\t\t\tcase 1257: // SB Windows Baltic\n\t\t\t\tcase 1258: // SB Windows Vietnam\n\n\t\t\t\tcase 932: // DB Windows Japanese Shift-JIS\n\t\t\t\tcase 936: // DB Windows Simplified Chinese GBK\n\t\t\t\tcase 949: // DB Windows Korean\n\t\t\t\tcase 950: // DB Windows Traditional Chinese Big5\n\n\t\t\t\tcase 1200: // UTF16LE\n\t\t\t\tcase 1201: // UTF16BE\n\t\t\t\tcase 65000: case -536: // UTF-7\n\t\t\t\tcase 65001: case -535: // UTF-8\n\t\t\t\t\tset_cp(CodePage = PropH[piddsi.n]); break;\n\t\t\t\tdefault: throw new Error(\"Unsupported CodePage: \" + PropH[piddsi.n]);\n\t\t\t}\n\t\t} else {\n\t\t\tif(Props[i][0] === 0x1) {\n\t\t\t\tCodePage = PropH.CodePage = parse_TypedPropertyValue(blob, VT_I2);\n\t\t\t\tset_cp(CodePage);\n\t\t\t\tif(Dictionary !== -1) {\n\t\t\t\t\tvar oldpos = blob.l;\n\t\t\t\t\tblob.l = Props[Dictionary][1];\n\t\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t\t\tblob.l = oldpos;\n\t\t\t\t}\n\t\t\t} else if(Props[i][0] === 0) {\n\t\t\t\tif(CodePage === 0) { Dictionary = i; blob.l = Props[i+1][1]; continue; }\n\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t} else {\n\t\t\t\tvar name = DictObj[Props[i][0]];\n\t\t\t\tvar val;\n\t\t\t\t/* [MS-OSHARED] 2.3.3.2.3.1.2 + PROPVARIANT */\n\t\t\t\tswitch(blob[blob.l]) {\n\t\t\t\t\tcase 0x41 /*VT_BLOB*/: blob.l += 4; val = parse_BLOB(blob); break;\n\t\t\t\t\tcase 0x1E /*VT_LPSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]); break;\n\t\t\t\t\tcase 0x1F /*VT_LPWSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]); break;\n\t\t\t\t\tcase 0x03 /*VT_I4*/: blob.l += 4; val = blob.read_shift(4, 'i'); break;\n\t\t\t\t\tcase 0x13 /*VT_UI4*/: blob.l += 4; val = blob.read_shift(4); break;\n\t\t\t\t\tcase 0x05 /*VT_R8*/: blob.l += 4; val = blob.read_shift(8, 'f'); break;\n\t\t\t\t\tcase 0x0B /*VT_BOOL*/: blob.l += 4; val = parsebool(blob, 4); break;\n\t\t\t\t\tcase 0x40 /*VT_FILETIME*/: blob.l += 4; val = new Date(parse_FILETIME(blob)); break;\n\t\t\t\t\tdefault: throw new Error(\"unparsed value: \" + blob[blob.l]);\n\t\t\t\t}\n\t\t\t\tPropH[name] = val;\n\t\t\t}\n\t\t}\n\t}\n\tblob.l = start_addr + size; /* step ahead to skip padding */\n\treturn PropH;\n}\n\n/* [MS-OLEPS] 2.21 PropertySetStream */\nfunction parse_PropertySetStream(file, PIDSI) {\n\tvar blob = file.content;\n\tprep_blob(blob, 0);\n\n\tvar NumSets, FMTID0, FMTID1, Offset0, Offset1;\n\tblob.chk('feff', 'Byte Order: ');\n\n\tvar vers = blob.read_shift(2); // TODO: check version\n\tvar SystemIdentifier = blob.read_shift(4);\n\tblob.chk(CFB.utils.consts.HEADER_CLSID, 'CLSID: ');\n\tNumSets = blob.read_shift(4);\n\tif(NumSets !== 1 && NumSets !== 2) throw \"Unrecognized #Sets: \" + NumSets;\n\tFMTID0 = blob.read_shift(16); Offset0 = blob.read_shift(4);\n\n\tif(NumSets === 1 && Offset0 !== blob.l) throw \"Length mismatch\";\n\telse if(NumSets === 2) { FMTID1 = blob.read_shift(16); Offset1 = blob.read_shift(4); }\n\tvar PSet0 = parse_PropertySet(blob, PIDSI);\n\n\tvar rval = { SystemIdentifier: SystemIdentifier };\n\tfor(var y in PSet0) rval[y] = PSet0[y];\n\t//rval.blob = blob;\n\trval.FMTID = FMTID0;\n\t//rval.PSet0 = PSet0;\n\tif(NumSets === 1) return rval;\n\tif(blob.l !== Offset1) throw \"Length mismatch 2: \" + blob.l + \" !== \" + Offset1;\n\tvar PSet1;\n\ttry { PSet1 = parse_PropertySet(blob, null); } catch(e) { }\n\tfor(y in PSet1) rval[y] = PSet1[y];\n\trval.FMTID = [FMTID0, FMTID1]; // TODO: verify FMTID0/1\n\treturn rval;\n}\n\n\nfunction parsenoop2(blob, length) { blob.read_shift(length); return null; }\n\nfunction parslurp(blob, length, cb) {\n\tvar arr = [], target = blob.l + length;\n\twhile(blob.l < target) arr.push(cb(blob, target - blob.l));\n\tif(target !== blob.l) throw new Error(\"Slurp error\");\n\treturn arr;\n}\n\nfunction parslurp2(blob, length, cb) {\n\tvar arr = [], target = blob.l + length, len = blob.read_shift(2);\n\twhile(len-- !== 0) arr.push(cb(blob, target - blob.l));\n\tif(target !== blob.l) throw new Error(\"Slurp error\");\n\treturn arr;\n}\n\nfunction parsebool(blob, length) { return blob.read_shift(length) === 0x1; }\n\nfunction parseuint16(blob) { return blob.read_shift(2, 'u'); }\nfunction parseuint16a(blob, length) { return parslurp(blob,length,parseuint16);}\n\n/* --- 2.5 Structures --- */\n\n/* [MS-XLS] 2.5.14 Boolean */\nvar parse_Boolean = parsebool;\n\n/* [MS-XLS] 2.5.10 Bes (boolean or error) */\nfunction parse_Bes(blob) {\n\tvar v = blob.read_shift(1), t = blob.read_shift(1);\n\treturn t === 0x01 ? v : v === 0x01;\n}\n\n/* [MS-XLS] 2.5.240 ShortXLUnicodeString */\nfunction parse_ShortXLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(1);\n\tvar width = 1, encoding = 'sbcs-cont';\n\tvar cp = current_codepage;\n\tif(opts && opts.biff >= 8) current_codepage = 1200;\n\tif(opts === undefined || opts.biff !== 5) {\n\t\tvar fHighByte = blob.read_shift(1);\n\t\tif(fHighByte) { width = 2; encoding = 'dbcs-cont'; }\n\t}\n\tvar o = cch ? blob.read_shift(cch, encoding) : \"\";\n\tcurrent_codepage = cp;\n\treturn o;\n}\n\n/* 2.5.293 XLUnicodeRichExtendedString */\nfunction parse_XLUnicodeRichExtendedString(blob) {\n\tvar cp = current_codepage;\n\tcurrent_codepage = 1200;\n\tvar cch = blob.read_shift(2), flags = blob.read_shift(1);\n\tvar fHighByte = flags & 0x1, fExtSt = flags & 0x4, fRichSt = flags & 0x8;\n\tvar width = 1 + (flags & 0x1); // 0x0 -> utf8, 0x1 -> dbcs\n\tvar cRun, cbExtRst;\n\tvar z = {};\n\tif(fRichSt) cRun = blob.read_shift(2);\n\tif(fExtSt) cbExtRst = blob.read_shift(4);\n\tvar encoding = (flags & 0x1) ? 'dbcs-cont' : 'sbcs-cont';\n\tvar msg = cch === 0 ? \"\" : blob.read_shift(cch, encoding);\n\tif(fRichSt) blob.l += 4 * cRun; //TODO: parse this\n\tif(fExtSt) blob.l += cbExtRst; //TODO: parse this\n\tz.t = msg;\n\tif(!fRichSt) { z.raw = \"<t>\" + z.t + \"</t>\"; z.r = z.t; }\n\tcurrent_codepage = cp;\n\treturn z;\n}\n\n/* 2.5.296 XLUnicodeStringNoCch */\nfunction parse_XLUnicodeStringNoCch(blob, cch, opts) {\n\tvar retval;\n\tvar fHighByte = blob.read_shift(1);\n\tif(fHighByte===0) { retval = blob.read_shift(cch, 'sbcs-cont'); }\n\telse { retval = blob.read_shift(cch, 'dbcs-cont'); }\n\treturn retval;\n}\n\n/* 2.5.294 XLUnicodeString */\nfunction parse_XLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(opts !== undefined && opts.biff > 0 && opts.biff < 8 ? 1 : 2);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn parse_XLUnicodeStringNoCch(blob, cch, opts);\n}\n/* BIFF5 override */\nfunction parse_XLUnicodeString2(blob, length, opts) {\n\tif(opts.biff !== 5 && opts.biff !== 2) return parse_XLUnicodeString(blob, length, opts);\n\tvar cch = blob.read_shift(1);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn blob.read_shift(cch, 'sbcs-cont');\n}\n\n/* [MS-XLS] 2.5.61 ControlInfo */\nvar parse_ControlInfo = parsenoop;\n\n/* [MS-OSHARED] 2.3.7.6 URLMoniker TODO: flags */\nvar parse_URLMoniker = function(blob, length) {\n\tvar len = blob.read_shift(4), start = blob.l;\n\tvar extra = false;\n\tif(len > 24) {\n\t\t/* look ahead */\n\t\tblob.l += len - 24;\n\t\tif(blob.read_shift(16) === \"795881f43b1d7f48af2c825dc4852763\") extra = true;\n\t\tblob.l = start;\n\t}\n\tvar url = blob.read_shift((extra?len-24:len)>>1, 'utf16le').replace(chr0,\"\");\n\tif(extra) blob.l += 24;\n\treturn url;\n};\n\n/* [MS-OSHARED] 2.3.7.8 FileMoniker TODO: all fields */\nvar parse_FileMoniker = function(blob, length) {\n\tvar cAnti = blob.read_shift(2);\n\tvar ansiLength = blob.read_shift(4);\n\tvar ansiPath = blob.read_shift(ansiLength, 'cstr');\n\tvar endServer = blob.read_shift(2);\n\tvar versionNumber = blob.read_shift(2);\n\tvar cbUnicodePathSize = blob.read_shift(4);\n\tif(cbUnicodePathSize === 0) return ansiPath.replace(/\\\\/g,\"/\");\n\tvar cbUnicodePathBytes = blob.read_shift(4);\n\tvar usKeyValue = blob.read_shift(2);\n\tvar unicodePath = blob.read_shift(cbUnicodePathBytes>>1, 'utf16le').replace(chr0,\"\");\n\treturn unicodePath;\n};\n\n/* [MS-OSHARED] 2.3.7.2 HyperlinkMoniker TODO: all the monikers */\nvar parse_HyperlinkMoniker = function(blob, length) {\n\tvar clsid = blob.read_shift(16); length -= 16;\n\tswitch(clsid) {\n\t\tcase \"e0c9ea79f9bace118c8200aa004ba90b\": return parse_URLMoniker(blob, length);\n\t\tcase \"0303000000000000c000000000000046\": return parse_FileMoniker(blob, length);\n\t\tdefault: throw \"unsupported moniker \" + clsid;\n\t}\n};\n\n/* [MS-OSHARED] 2.3.7.9 HyperlinkString */\nvar parse_HyperlinkString = function(blob, length) {\n\tvar len = blob.read_shift(4);\n\tvar o = blob.read_shift(len, 'utf16le').replace(chr0, \"\");\n\treturn o;\n};\n\n/* [MS-OSHARED] 2.3.7.1 Hyperlink Object TODO: unify params with XLSX */\nvar parse_Hyperlink = function(blob, length) {\n\tvar end = blob.l + length;\n\tvar sVer = blob.read_shift(4);\n\tif(sVer !== 2) throw new Error(\"Unrecognized streamVersion: \" + sVer);\n\tvar flags = blob.read_shift(2);\n\tblob.l += 2;\n\tvar displayName, targetFrameName, moniker, oleMoniker, location, guid, fileTime;\n\tif(flags & 0x0010) displayName = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0080) targetFrameName = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0101) moniker = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0001) oleMoniker = parse_HyperlinkMoniker(blob, end - blob.l);\n\tif(flags & 0x0008) location = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0020) guid = blob.read_shift(16);\n\tif(flags & 0x0040) fileTime = parse_FILETIME(blob, 8);\n\tblob.l = end;\n\tvar target = (targetFrameName||moniker||oleMoniker);\n\tif(location) target+=\"#\"+location;\n\treturn {Target: target};\n};\n\n/* 2.5.178 LongRGBA */\nfunction parse_LongRGBA(blob, length) { var r = blob.read_shift(1), g = blob.read_shift(1), b = blob.read_shift(1), a = blob.read_shift(1); return [r,g,b,a]; }\n\n/* 2.5.177 LongRGB */\nfunction parse_LongRGB(blob, length) { var x = parse_LongRGBA(blob, length); x[3] = 0; return x; }\n\n\n/* --- MS-XLS --- */\n\n/* 2.5.19 */\nfunction parse_XLSCell(blob, length) {\n\tvar rw = blob.read_shift(2); // 0-indexed\n\tvar col = blob.read_shift(2);\n\tvar ixfe = blob.read_shift(2);\n\treturn {r:rw, c:col, ixfe:ixfe};\n}\n\n/* 2.5.134 */\nfunction parse_frtHeader(blob) {\n\tvar rt = blob.read_shift(2);\n\tvar flags = blob.read_shift(2); // TODO: parse these flags\n\tblob.l += 8;\n\treturn {type: rt, flags: flags};\n}\n\n\n\nfunction parse_OptXLUnicodeString(blob, length, opts) { return length === 0 ? \"\" : parse_XLUnicodeString2(blob, length, opts); }\n\n/* 2.5.158 */\nvar HIDEOBJENUM = ['SHOWALL', 'SHOWPLACEHOLDER', 'HIDEALL'];\nvar parse_HideObjEnum = parseuint16;\n\n/* 2.5.344 */\nfunction parse_XTI(blob, length) {\n\tvar iSupBook = blob.read_shift(2), itabFirst = blob.read_shift(2,'i'), itabLast = blob.read_shift(2,'i');\n\treturn [iSupBook, itabFirst, itabLast];\n}\n\n/* 2.5.218 */\nfunction parse_RkRec(blob, length) {\n\tvar ixfe = blob.read_shift(2);\n\tvar RK = parse_RkNumber(blob);\n\t//console.log(\"::\", ixfe, RK,\";;\");\n\treturn [ixfe, RK];\n}\n\n/* 2.5.1 */\nfunction parse_AddinUdf(blob, length) {\n\tblob.l += 4; length -= 4;\n\tvar l = blob.l + length;\n\tvar udfName = parse_ShortXLUnicodeString(blob, length);\n\tvar cb = blob.read_shift(2);\n\tl -= blob.l;\n\tif(cb !== l) throw \"Malformed AddinUdf: padding = \" + l + \" != \" + cb;\n\tblob.l += cb;\n\treturn udfName;\n}\n\n/* 2.5.209 TODO: Check sizes */\nfunction parse_Ref8U(blob, length) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(2);\n\tvar colLast = blob.read_shift(2);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\n\n/* 2.5.211 */\nfunction parse_RefU(blob, length) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(1);\n\tvar colLast = blob.read_shift(1);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\n\n/* 2.5.207 */\nvar parse_Ref = parse_RefU;\n\n/* 2.5.143 */\nfunction parse_FtCmo(blob, length) {\n\tblob.l += 4;\n\tvar ot = blob.read_shift(2);\n\tvar id = blob.read_shift(2);\n\tvar flags = blob.read_shift(2);\n\tblob.l+=12;\n\treturn [id, ot, flags];\n}\n\n/* 2.5.149 */\nfunction parse_FtNts(blob, length) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.l += 16; // GUID TODO\n\tout.fSharedNote = blob.read_shift(2);\n\tblob.l += 4;\n\treturn out;\n}\n\n/* 2.5.142 */\nfunction parse_FtCf(blob, length) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.cf = blob.read_shift(2);\n\treturn out;\n}\n\n/* 2.5.140 - 2.5.154 and friends */\nvar FtTab = {\n\t0x15: parse_FtCmo,\n\t0x13: parsenoop, /* FtLbsData */\n\t0x12: function(blob, length) { blob.l += 12; }, /* FtCblsData */\n\t0x11: function(blob, length) { blob.l += 8; }, /* FtRboData */\n\t0x10: parsenoop, /* FtEdoData */\n\t0x0F: parsenoop, /* FtGboData */\n\t0x0D: parse_FtNts, /* FtNts */\n\t0x0C: function(blob, length) { blob.l += 24; }, /* FtSbs */\n\t0x0B: function(blob, length) { blob.l += 10; }, /* FtRbo */\n\t0x0A: function(blob, length) { blob.l += 16; }, /* FtCbls */\n\t0x09: parsenoop, /* FtPictFmla */\n\t0x08: function(blob, length) { blob.l += 6; }, /* FtPioGrbit */\n\t0x07: parse_FtCf, /* FtCf */\n\t0x06: function(blob, length) { blob.l += 6; }, /* FtGmo */\n\t0x04: parsenoop, /* FtMacro */\n\t0x00: function(blob, length) { blob.l += 4; } /* FtEnding */\n};\nfunction parse_FtArray(blob, length, ot) {\n\tvar s = blob.l;\n\tvar fts = [];\n\twhile(blob.l < s + length) {\n\t\tvar ft = blob.read_shift(2);\n\t\tblob.l-=2;\n\t\ttry {\n\t\t\tfts.push(FtTab[ft](blob, s + length - blob.l));\n\t\t} catch(e) { blob.l = s + length; return fts; }\n\t}\n\tif(blob.l != s + length) blob.l = s + length; //throw \"bad Object Ft-sequence\";\n\treturn fts;\n}\n\n/* 2.5.129 */\nvar parse_FontIndex = parseuint16;\n\n/* --- 2.4 Records --- */\n\n/* 2.4.21 */\nfunction parse_BOF(blob, length) {\n\tvar o = {};\n\to.BIFFVer = blob.read_shift(2); length -= 2;\n\tswitch(o.BIFFVer) {\n\t\tcase 0x0600: /* BIFF8 */\n\t\tcase 0x0500: /* BIFF5 */\n\t\tcase 0x0002: case 0x0007: /* BIFF2 */\n\t\t\tbreak;\n\t\tdefault: throw \"Unexpected BIFF Ver \" + o.BIFFVer;\n\t}\n\tblob.read_shift(length);\n\treturn o;\n}\n\n\n/* 2.4.146 */\nfunction parse_InterfaceHdr(blob, length) {\n\tif(length === 0) return 0x04b0;\n\tvar q;\n\tif((q=blob.read_shift(2))!==0x04b0) throw 'InterfaceHdr codePage ' + q;\n\treturn 0x04b0;\n}\n\n\n/* 2.4.349 */\nfunction parse_WriteAccess(blob, length, opts) {\n\tif(opts.enc) { blob.l += length; return \"\"; }\n\tvar l = blob.l;\n\t// TODO: make sure XLUnicodeString doesnt overrun\n\tvar UserName = parse_XLUnicodeString(blob, 0, opts);\n\tblob.read_shift(length + l - blob.l);\n\treturn UserName;\n}\n\n/* 2.4.28 */\nfunction parse_BoundSheet8(blob, length, opts) {\n\tvar pos = blob.read_shift(4);\n\tvar hidden = blob.read_shift(1) >> 6;\n\tvar dt = blob.read_shift(1);\n\tswitch(dt) {\n\t\tcase 0: dt = 'Worksheet'; break;\n\t\tcase 1: dt = 'Macrosheet'; break;\n\t\tcase 2: dt = 'Chartsheet'; break;\n\t\tcase 6: dt = 'VBAModule'; break;\n\t}\n\tvar name = parse_ShortXLUnicodeString(blob, 0, opts);\n\tif(name.length === 0) name = \"Sheet1\";\n\treturn { pos:pos, hs:hidden, dt:dt, name:name };\n}\n\n/* 2.4.265 TODO */\nfunction parse_SST(blob, length) {\n\tvar cnt = blob.read_shift(4);\n\tvar ucnt = blob.read_shift(4);\n\tvar strs = [];\n\tfor(var i = 0; i != ucnt; ++i) {\n\t\tstrs.push(parse_XLUnicodeRichExtendedString(blob));\n\t}\n\tstrs.Count = cnt; strs.Unique = ucnt;\n\treturn strs;\n}\n\n/* 2.4.107 */\nfunction parse_ExtSST(blob, length) {\n\tvar extsst = {};\n\textsst.dsst = blob.read_shift(2);\n\tblob.l += length-2;\n\treturn extsst;\n}\n\n\n/* 2.4.221 TODO*/\nfunction parse_Row(blob, length) {\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2), Col = blob.read_shift(2), rht = blob.read_shift(2);\n\tblob.read_shift(4); // reserved(2), unused(2)\n\tvar flags = blob.read_shift(1); // various flags\n\tblob.read_shift(1); // reserved\n\tblob.read_shift(2); //ixfe, other flags\n\treturn {r:rw, c:col, cnt:Col-col};\n}\n\n\n/* 2.4.125 */\nfunction parse_ForceFullCalculation(blob, length) {\n\tvar header = parse_frtHeader(blob);\n\tif(header.type != 0x08A3) throw \"Invalid Future Record \" + header.type;\n\tvar fullcalc = blob.read_shift(4);\n\treturn fullcalc !== 0x0;\n}\n\n\nvar parse_CompressPictures = parsenoop2; /* 2.4.55 Not interesting */\n\n\n\n/* 2.4.215 rt */\nfunction parse_RecalcId(blob, length) {\n\tblob.read_shift(2);\n\treturn blob.read_shift(4);\n}\n\n/* 2.4.87 */\nfunction parse_DefaultRowHeight (blob, length) {\n\tvar f = blob.read_shift(2), miyRw;\n\tmiyRw = blob.read_shift(2); // flags & 0x02 -> hidden, else empty\n\tvar fl = {Unsynced:f&1,DyZero:(f&2)>>1,ExAsc:(f&4)>>2,ExDsc:(f&8)>>3};\n\treturn [fl, miyRw];\n}\n\n/* 2.4.345 TODO */\nfunction parse_Window1(blob, length) {\n\tvar xWn = blob.read_shift(2), yWn = blob.read_shift(2), dxWn = blob.read_shift(2), dyWn = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), iTabCur = blob.read_shift(2), iTabFirst = blob.read_shift(2);\n\tvar ctabSel = blob.read_shift(2), wTabRatio = blob.read_shift(2);\n\treturn { Pos: [xWn, yWn], Dim: [dxWn, dyWn], Flags: flags, CurTab: iTabCur,\n\t\tFirstTab: iTabFirst, Selected: ctabSel, TabRatio: wTabRatio };\n}\n\n/* 2.4.122 TODO */\nfunction parse_Font(blob, length, opts) {\n\tblob.l += 14;\n\tvar name = parse_ShortXLUnicodeString(blob, 0, opts);\n\treturn name;\n}\n\n/* 2.4.149 */\nfunction parse_LabelSst(blob, length) {\n\tvar cell = parse_XLSCell(blob);\n\tcell.isst = blob.read_shift(4);\n\treturn cell;\n}\n\n/* 2.4.148 */\nfunction parse_Label(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar str = parse_XLUnicodeString(blob, length-6, opts);\n\tcell.val = str;\n\treturn cell;\n}\n\n/* 2.4.126 Number Formats */\nfunction parse_Format(blob, length, opts) {\n\tvar ifmt = blob.read_shift(2);\n\tvar fmtstr = parse_XLUnicodeString2(blob, 0, opts);\n\treturn [ifmt, fmtstr];\n}\n\n/* 2.4.90 */\nfunction parse_Dimensions(blob, length) {\n\tvar w = length === 10 ? 2 : 4;\n\tvar r = blob.read_shift(w), R = blob.read_shift(w),\n\t c = blob.read_shift(2), C = blob.read_shift(2);\n\tblob.l += 2;\n\treturn {s: {r:r, c:c}, e: {r:R, c:C}};\n}\n\n/* 2.4.220 */\nfunction parse_RK(blob, length) {\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrec = parse_RkRec(blob);\n\treturn {r:rw, c:col, ixfe:rkrec[0], rknum:rkrec[1]};\n}\n\n/* 2.4.175 */\nfunction parse_MulRk(blob, length) {\n\tvar target = blob.l + length - 2;\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrecs = [];\n\twhile(blob.l < target) rkrecs.push(parse_RkRec(blob));\n\tif(blob.l !== target) throw \"MulRK read error\";\n\tvar lastcol = blob.read_shift(2);\n\tif(rkrecs.length != lastcol - col + 1) throw \"MulRK length mismatch\";\n\treturn {r:rw, c:col, C:lastcol, rkrec:rkrecs};\n}\n\n/* 2.5.20 2.5.249 TODO */\nfunction parse_CellStyleXF(blob, length, style) {\n\tvar o = {};\n\tvar a = blob.read_shift(4), b = blob.read_shift(4);\n\tvar c = blob.read_shift(4), d = blob.read_shift(2);\n\to.patternType = XLSFillPattern[c >> 26];\n\to.icvFore = d & 0x7F;\n\to.icvBack = (d >> 7) & 0x7F;\n\treturn o;\n}\nfunction parse_CellXF(blob, length) {return parse_CellStyleXF(blob,length,0);}\nfunction parse_StyleXF(blob, length) {return parse_CellStyleXF(blob,length,1);}\n\n/* 2.4.353 TODO: actually do this right */\nfunction parse_XF(blob, length) {\n\tvar o = {};\n\to.ifnt = blob.read_shift(2); o.ifmt = blob.read_shift(2); o.flags = blob.read_shift(2);\n\to.fStyle = (o.flags >> 2) & 0x01;\n\tlength -= 6;\n\to.data = parse_CellStyleXF(blob, length, o.fStyle);\n\treturn o;\n}\n\n/* 2.4.134 */\nfunction parse_Guts(blob, length) {\n\tblob.l += 4;\n\tvar out = [blob.read_shift(2), blob.read_shift(2)];\n\tif(out[0] !== 0) out[0]--;\n\tif(out[1] !== 0) out[1]--;\n\tif(out[0] > 7 || out[1] > 7) throw \"Bad Gutters: \" + out;\n\treturn out;\n}\n\n/* 2.4.24 */\nfunction parse_BoolErr(blob, length) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar val = parse_Bes(blob, 2);\n\tcell.val = val;\n\tcell.t = (val === true || val === false) ? 'b' : 'e';\n\treturn cell;\n}\n\n/* 2.4.180 Number */\nfunction parse_Number(blob, length) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar xnum = parse_Xnum(blob, 8);\n\tcell.val = xnum;\n\treturn cell;\n}\n\nvar parse_XLHeaderFooter = parse_OptXLUnicodeString; // TODO: parse 2.4.136\n\n/* 2.4.271 */\nfunction parse_SupBook(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar ctab = blob.read_shift(2);\n\tvar cch = blob.read_shift(2);\n\tvar virtPath;\n\tif(cch >=0x01 && cch <=0xff) virtPath = parse_XLUnicodeStringNoCch(blob, cch);\n\tvar rgst = blob.read_shift(end - blob.l);\n\topts.sbcch = cch;\n\treturn [cch, ctab, virtPath, rgst];\n}\n\n/* 2.4.105 TODO */\nfunction parse_ExternName(blob, length, opts) {\n\tvar flags = blob.read_shift(2);\n\tvar body;\n\tvar o = {\n\t\tfBuiltIn: flags & 0x01,\n\t\tfWantAdvise: (flags >>> 1) & 0x01,\n\t\tfWantPict: (flags >>> 2) & 0x01,\n\t\tfOle: (flags >>> 3) & 0x01,\n\t\tfOleLink: (flags >>> 4) & 0x01,\n\t\tcf: (flags >>> 5) & 0x3FF,\n\t\tfIcon: flags >>> 15 & 0x01\n\t};\n\tif(opts.sbcch === 0x3A01) body = parse_AddinUdf(blob, length-2);\n\t//else throw new Error(\"unsupported SupBook cch: \" + opts.sbcch);\n\to.body = body || blob.read_shift(length-2);\n\treturn o;\n}\n\n/* 2.4.150 TODO */\nfunction parse_Lbl(blob, length, opts) {\n\tif(opts.biff < 8) return parse_Label(blob, length, opts);\n\tvar target = blob.l + length;\n\tvar flags = blob.read_shift(2);\n\tvar chKey = blob.read_shift(1);\n\tvar cch = blob.read_shift(1);\n\tvar cce = blob.read_shift(2);\n\tblob.l += 2;\n\tvar itab = blob.read_shift(2);\n\tblob.l += 4;\n\tvar name = parse_XLUnicodeStringNoCch(blob, cch, opts);\n\tvar rgce = parse_NameParsedFormula(blob, target - blob.l, opts, cce);\n\treturn {\n\t\tchKey: chKey,\n\t\tName: name,\n\t\trgce: rgce\n\t};\n}\n\n/* 2.4.106 TODO: verify supbook manipulation */\nfunction parse_ExternSheet(blob, length, opts) {\n\tif(opts.biff < 8) return parse_ShortXLUnicodeString(blob, length, opts);\n\tvar o = parslurp2(blob,length,parse_XTI);\n\tvar oo = [];\n\tif(opts.sbcch === 0x0401) {\n\t\tfor(var i = 0; i != o.length; ++i) oo.push(opts.snames[o[i][1]]);\n\t\treturn oo;\n\t}\n\telse return o;\n}\n\n/* 2.4.260 */\nfunction parse_ShrFmla(blob, length, opts) {\n\tvar ref = parse_RefU(blob, 6);\n\tblob.l++;\n\tvar cUse = blob.read_shift(1);\n\tlength -= 8;\n\treturn [parse_SharedParsedFormula(blob, length, opts), cUse];\n}\n\n/* 2.4.4 TODO */\nfunction parse_Array(blob, length, opts) {\n\tvar ref = parse_Ref(blob, 6);\n\tblob.l += 6; length -= 12; /* TODO: fAlwaysCalc */\n\treturn [ref, parse_ArrayParsedFormula(blob, length, opts, ref)];\n}\n\n/* 2.4.173 */\nfunction parse_MTRSettings(blob, length) {\n\tvar fMTREnabled = blob.read_shift(4) !== 0x00;\n\tvar fUserSetThreadCount = blob.read_shift(4) !== 0x00;\n\tvar cUserThreadCount = blob.read_shift(4);\n\treturn [fMTREnabled, fUserSetThreadCount, cUserThreadCount];\n}\n\n/* 2.5.186 TODO: BIFF5 */\nfunction parse_NoteSh(blob, length, opts) {\n\tif(opts.biff < 8) return;\n\tvar row = blob.read_shift(2), col = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), idObj = blob.read_shift(2);\n\tvar stAuthor = parse_XLUnicodeString2(blob, 0, opts);\n\tif(opts.biff < 8) blob.read_shift(1);\n\treturn [{r:row,c:col}, stAuthor, idObj, flags];\n}\n\n/* 2.4.179 */\nfunction parse_Note(blob, length, opts) {\n\t/* TODO: Support revisions */\n\treturn parse_NoteSh(blob, length, opts);\n}\n\n/* 2.4.168 */\nfunction parse_MergeCells(blob, length) {\n\tvar merges = [];\n\tvar cmcs = blob.read_shift(2);\n\twhile (cmcs--) merges.push(parse_Ref8U(blob,length));\n\treturn merges;\n}\n\n/* 2.4.181 TODO: parse all the things! */\nfunction parse_Obj(blob, length) {\n\tvar cmo = parse_FtCmo(blob, 22); // id, ot, flags\n\tvar fts = parse_FtArray(blob, length-22, cmo[1]);\n\treturn { cmo: cmo, ft:fts };\n}\n\n/* 2.4.329 TODO: parse properly */\nfunction parse_TxO(blob, length, opts) {\n\tvar s = blob.l;\ntry {\n\tblob.l += 4;\n\tvar ot = (opts.lastobj||{cmo:[0,0]}).cmo[1];\n\tvar controlInfo;\n\tif([0,5,7,11,12,14].indexOf(ot) == -1) blob.l += 6;\n\telse controlInfo = parse_ControlInfo(blob, 6, opts);\n\tvar cchText = blob.read_shift(2);\n\tvar cbRuns = blob.read_shift(2);\n\tvar ifntEmpty = parse_FontIndex(blob, 2);\n\tvar len = blob.read_shift(2);\n\tblob.l += len;\n\t//var fmla = parse_ObjFmla(blob, s + length - blob.l);\n\n\tvar texts = \"\";\n\tfor(var i = 1; i < blob.lens.length-1; ++i) {\n\t\tif(blob.l-s != blob.lens[i]) throw \"TxO: bad continue record\";\n\t\tvar hdr = blob[blob.l];\n\t\tvar t = parse_XLUnicodeStringNoCch(blob, blob.lens[i+1]-blob.lens[i]-1);\n\t\ttexts += t;\n\t\tif(texts.length >= (hdr ? cchText : 2*cchText)) break;\n\t}\n\tif(texts.length !== cchText && texts.length !== cchText*2) {\n\t\tthrow \"cchText: \" + cchText + \" != \" + texts.length;\n\t}\n\n\tblob.l = s + length;\n\t/* 2.5.272 TxORuns */\n//\tvar rgTxoRuns = [];\n//\tfor(var j = 0; j != cbRuns/8-1; ++j) blob.l += 8;\n//\tvar cchText2 = blob.read_shift(2);\n//\tif(cchText2 !== cchText) throw \"TxOLastRun mismatch: \" + cchText2 + \" \" + cchText;\n//\tblob.l += 6;\n//\tif(s + length != blob.l) throw \"TxO \" + (s + length) + \", at \" + blob.l;\n\treturn { t: texts };\n} catch(e) { blob.l = s + length; return { t: texts||\"\" }; }\n}\n\n/* 2.4.140 */\nvar parse_HLink = function(blob, length) {\n\tvar ref = parse_Ref8U(blob, 8);\n\tblob.l += 16; /* CLSID */\n\tvar hlink = parse_Hyperlink(blob, length-24);\n\treturn [ref, hlink];\n};\n\n/* 2.4.141 */\nvar parse_HLinkTooltip = function(blob, length) {\n\tvar end = blob.l + length;\n\tblob.read_shift(2);\n\tvar ref = parse_Ref8U(blob, 8);\n\tvar wzTooltip = blob.read_shift((length-10)/2, 'dbcs-cont');\n\twzTooltip = wzTooltip.replace(chr0,\"\");\n\treturn [ref, wzTooltip];\n};\n\n/* 2.4.63 */\nfunction parse_Country(blob, length) {\n\tvar o = [], d;\n\td = blob.read_shift(2); o[0] = CountryEnum[d] || d;\n\td = blob.read_shift(2); o[1] = CountryEnum[d] || d;\n\treturn o;\n}\n\n/* 2.4.50 ClrtClient */\nfunction parse_ClrtClient(blob, length) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* 2.4.188 */\nfunction parse_Palette(blob, length) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* 2.4.354 */\nfunction parse_XFCRC(blob, length) {\n\tblob.l += 2;\n\tvar o = {cxfs:0, crc:0};\n\to.cxfs = blob.read_shift(2);\n\to.crc = blob.read_shift(4);\n\treturn o;\n}\n\n\nvar parse_Style = parsenoop;\nvar parse_StyleExt = parsenoop;\n\nvar parse_ColInfo = parsenoop;\n\nvar parse_Window2 = parsenoop;\n\n\nvar parse_Backup = parsebool; /* 2.4.14 */\nvar parse_Blank = parse_XLSCell; /* 2.4.20 Just the cell */\nvar parse_BottomMargin = parse_Xnum; /* 2.4.27 */\nvar parse_BuiltInFnGroupCount = parseuint16; /* 2.4.30 0x0E or 0x10 but excel 2011 generates 0x11? */\nvar parse_CalcCount = parseuint16; /* 2.4.31 #Iterations */\nvar parse_CalcDelta = parse_Xnum; /* 2.4.32 */\nvar parse_CalcIter = parsebool; /* 2.4.33 1=iterative calc */\nvar parse_CalcMode = parseuint16; /* 2.4.34 0=manual, 1=auto (def), 2=table */\nvar parse_CalcPrecision = parsebool; /* 2.4.35 */\nvar parse_CalcRefMode = parsenoop2; /* 2.4.36 */\nvar parse_CalcSaveRecalc = parsebool; /* 2.4.37 */\nvar parse_CodePage = parseuint16; /* 2.4.52 */\nvar parse_Compat12 = parsebool; /* 2.4.54 true = no compatibility check */\nvar parse_Date1904 = parsebool; /* 2.4.77 - 1=1904,0=1900 */\nvar parse_DefColWidth = parseuint16; /* 2.4.89 */\nvar parse_DSF = parsenoop2; /* 2.4.94 -- MUST be ignored */\nvar parse_EntExU2 = parsenoop2; /* 2.4.102 -- Explicitly says to ignore */\nvar parse_EOF = parsenoop2; /* 2.4.103 */\nvar parse_Excel9File = parsenoop2; /* 2.4.104 -- Optional and unused */\nvar parse_FeatHdr = parsenoop2; /* 2.4.112 */\nvar parse_FontX = parseuint16; /* 2.4.123 */\nvar parse_Footer = parse_XLHeaderFooter; /* 2.4.124 */\nvar parse_GridSet = parseuint16; /* 2.4.132, =1 */\nvar parse_HCenter = parsebool; /* 2.4.135 sheet centered horizontal on print */\nvar parse_Header = parse_XLHeaderFooter; /* 2.4.136 */\nvar parse_HideObj = parse_HideObjEnum; /* 2.4.139 */\nvar parse_InterfaceEnd = parsenoop2; /* 2.4.145 -- noop */\nvar parse_LeftMargin = parse_Xnum; /* 2.4.151 */\nvar parse_Mms = parsenoop2; /* 2.4.169 -- Explicitly says to ignore */\nvar parse_ObjProtect = parsebool; /* 2.4.183 -- must be 1 if present */\nvar parse_Password = parseuint16; /* 2.4.191 */\nvar parse_PrintGrid = parsebool; /* 2.4.202 */\nvar parse_PrintRowCol = parsebool; /* 2.4.203 */\nvar parse_PrintSize = parseuint16; /* 2.4.204 0:3 */\nvar parse_Prot4Rev = parsebool; /* 2.4.205 */\nvar parse_Prot4RevPass = parseuint16; /* 2.4.206 */\nvar parse_Protect = parsebool; /* 2.4.207 */\nvar parse_RefreshAll = parsebool; /* 2.4.217 -- must be 0 if not template */\nvar parse_RightMargin = parse_Xnum; /* 2.4.219 */\nvar parse_RRTabId = parseuint16a; /* 2.4.241 */\nvar parse_ScenarioProtect = parsebool; /* 2.4.245 */\nvar parse_Scl = parseuint16a; /* 2.4.247 num, den */\nvar parse_String = parse_XLUnicodeString; /* 2.4.268 */\nvar parse_SxBool = parsebool; /* 2.4.274 */\nvar parse_TopMargin = parse_Xnum; /* 2.4.328 */\nvar parse_UsesELFs = parsebool; /* 2.4.337 -- should be 0 */\nvar parse_VCenter = parsebool; /* 2.4.342 */\nvar parse_WinProtect = parsebool; /* 2.4.347 */\nvar parse_WriteProtect = parsenoop; /* 2.4.350 empty record */\n\n\n/* ---- */\nvar parse_VerticalPageBreaks = parsenoop;\nvar parse_HorizontalPageBreaks = parsenoop;\nvar parse_Selection = parsenoop;\nvar parse_Continue = parsenoop;\nvar parse_Pane = parsenoop;\nvar parse_Pls = parsenoop;\nvar parse_DCon = parsenoop;\nvar parse_DConRef = parsenoop;\nvar parse_DConName = parsenoop;\nvar parse_XCT = parsenoop;\nvar parse_CRN = parsenoop;\nvar parse_FileSharing = parsenoop;\nvar parse_Uncalced = parsenoop;\nvar parse_Template = parsenoop;\nvar parse_Intl = parsenoop;\nvar parse_WsBool = parsenoop;\nvar parse_Sort = parsenoop;\nvar parse_Sync = parsenoop;\nvar parse_LPr = parsenoop;\nvar parse_DxGCol = parsenoop;\nvar parse_FnGroupName = parsenoop;\nvar parse_FilterMode = parsenoop;\nvar parse_AutoFilterInfo = parsenoop;\nvar parse_AutoFilter = parsenoop;\nvar parse_Setup = parsenoop;\nvar parse_ScenMan = parsenoop;\nvar parse_SCENARIO = parsenoop;\nvar parse_SxView = parsenoop;\nvar parse_Sxvd = parsenoop;\nvar parse_SXVI = parsenoop;\nvar parse_SxIvd = parsenoop;\nvar parse_SXLI = parsenoop;\nvar parse_SXPI = parsenoop;\nvar parse_DocRoute = parsenoop;\nvar parse_RecipName = parsenoop;\nvar parse_MulBlank = parsenoop;\nvar parse_SXDI = parsenoop;\nvar parse_SXDB = parsenoop;\nvar parse_SXFDB = parsenoop;\nvar parse_SXDBB = parsenoop;\nvar parse_SXNum = parsenoop;\nvar parse_SxErr = parsenoop;\nvar parse_SXInt = parsenoop;\nvar parse_SXString = parsenoop;\nvar parse_SXDtr = parsenoop;\nvar parse_SxNil = parsenoop;\nvar parse_SXTbl = parsenoop;\nvar parse_SXTBRGIITM = parsenoop;\nvar parse_SxTbpg = parsenoop;\nvar parse_ObProj = parsenoop;\nvar parse_SXStreamID = parsenoop;\nvar parse_DBCell = parsenoop;\nvar parse_SXRng = parsenoop;\nvar parse_SxIsxoper = parsenoop;\nvar parse_BookBool = parsenoop;\nvar parse_DbOrParamQry = parsenoop;\nvar parse_OleObjectSize = parsenoop;\nvar parse_SXVS = parsenoop;\nvar parse_BkHim = parsenoop;\nvar parse_MsoDrawingGroup = parsenoop;\nvar parse_MsoDrawing = parsenoop;\nvar parse_MsoDrawingSelection = parsenoop;\nvar parse_PhoneticInfo = parsenoop;\nvar parse_SxRule = parsenoop;\nvar parse_SXEx = parsenoop;\nvar parse_SxFilt = parsenoop;\nvar parse_SxDXF = parsenoop;\nvar parse_SxItm = parsenoop;\nvar parse_SxName = parsenoop;\nvar parse_SxSelect = parsenoop;\nvar parse_SXPair = parsenoop;\nvar parse_SxFmla = parsenoop;\nvar parse_SxFormat = parsenoop;\nvar parse_SXVDEx = parsenoop;\nvar parse_SXFormula = parsenoop;\nvar parse_SXDBEx = parsenoop;\nvar parse_RRDInsDel = parsenoop;\nvar parse_RRDHead = parsenoop;\nvar parse_RRDChgCell = parsenoop;\nvar parse_RRDRenSheet = parsenoop;\nvar parse_RRSort = parsenoop;\nvar parse_RRDMove = parsenoop;\nvar parse_RRFormat = parsenoop;\nvar parse_RRAutoFmt = parsenoop;\nvar parse_RRInsertSh = parsenoop;\nvar parse_RRDMoveBegin = parsenoop;\nvar parse_RRDMoveEnd = parsenoop;\nvar parse_RRDInsDelBegin = parsenoop;\nvar parse_RRDInsDelEnd = parsenoop;\nvar parse_RRDConflict = parsenoop;\nvar parse_RRDDefName = parsenoop;\nvar parse_RRDRstEtxp = parsenoop;\nvar parse_LRng = parsenoop;\nvar parse_CUsr = parsenoop;\nvar parse_CbUsr = parsenoop;\nvar parse_UsrInfo = parsenoop;\nvar parse_UsrExcl = parsenoop;\nvar parse_FileLock = parsenoop;\nvar parse_RRDInfo = parsenoop;\nvar parse_BCUsrs = parsenoop;\nvar parse_UsrChk = parsenoop;\nvar parse_UserBView = parsenoop;\nvar parse_UserSViewBegin = parsenoop; // overloaded\nvar parse_UserSViewEnd = parsenoop;\nvar parse_RRDUserView = parsenoop;\nvar parse_Qsi = parsenoop;\nvar parse_CondFmt = parsenoop;\nvar parse_CF = parsenoop;\nvar parse_DVal = parsenoop;\nvar parse_DConBin = parsenoop;\nvar parse_Lel = parsenoop;\nvar parse_XLSCodeName = parse_XLUnicodeString;\nvar parse_SXFDBType = parsenoop;\nvar parse_ObNoMacros = parsenoop;\nvar parse_Dv = parsenoop;\nvar parse_Index = parsenoop;\nvar parse_Table = parsenoop;\nvar parse_BigName = parsenoop;\nvar parse_ContinueBigName = parsenoop;\nvar parse_WebPub = parsenoop;\nvar parse_QsiSXTag = parsenoop;\nvar parse_DBQueryExt = parsenoop;\nvar parse_ExtString = parsenoop;\nvar parse_TxtQry = parsenoop;\nvar parse_Qsir = parsenoop;\nvar parse_Qsif = parsenoop;\nvar parse_RRDTQSIF = parsenoop;\nvar parse_OleDbConn = parsenoop;\nvar parse_WOpt = parsenoop;\nvar parse_SXViewEx = parsenoop;\nvar parse_SXTH = parsenoop;\nvar parse_SXPIEx = parsenoop;\nvar parse_SXVDTEx = parsenoop;\nvar parse_SXViewEx9 = parsenoop;\nvar parse_ContinueFrt = parsenoop;\nvar parse_RealTimeData = parsenoop;\nvar parse_ChartFrtInfo = parsenoop;\nvar parse_FrtWrapper = parsenoop;\nvar parse_StartBlock = parsenoop;\nvar parse_EndBlock = parsenoop;\nvar parse_StartObject = parsenoop;\nvar parse_EndObject = parsenoop;\nvar parse_CatLab = parsenoop;\nvar parse_YMult = parsenoop;\nvar parse_SXViewLink = parsenoop;\nvar parse_PivotChartBits = parsenoop;\nvar parse_FrtFontList = parsenoop;\nvar parse_SheetExt = parsenoop;\nvar parse_BookExt = parsenoop;\nvar parse_SXAddl = parsenoop;\nvar parse_CrErr = parsenoop;\nvar parse_HFPicture = parsenoop;\nvar parse_Feat = parsenoop;\nvar parse_DataLabExt = parsenoop;\nvar parse_DataLabExtContents = parsenoop;\nvar parse_CellWatch = parsenoop;\nvar parse_FeatHdr11 = parsenoop;\nvar parse_Feature11 = parsenoop;\nvar parse_DropDownObjIds = parsenoop;\nvar parse_ContinueFrt11 = parsenoop;\nvar parse_DConn = parsenoop;\nvar parse_List12 = parsenoop;\nvar parse_Feature12 = parsenoop;\nvar parse_CondFmt12 = parsenoop;\nvar parse_CF12 = parsenoop;\nvar parse_CFEx = parsenoop;\nvar parse_AutoFilter12 = parsenoop;\nvar parse_ContinueFrt12 = parsenoop;\nvar parse_MDTInfo = parsenoop;\nvar parse_MDXStr = parsenoop;\nvar parse_MDXTuple = parsenoop;\nvar parse_MDXSet = parsenoop;\nvar parse_MDXProp = parsenoop;\nvar parse_MDXKPI = parsenoop;\nvar parse_MDB = parsenoop;\nvar parse_PLV = parsenoop;\nvar parse_DXF = parsenoop;\nvar parse_TableStyles = parsenoop;\nvar parse_TableStyle = parsenoop;\nvar parse_TableStyleElement = parsenoop;\nvar parse_NamePublish = parsenoop;\nvar parse_NameCmt = parsenoop;\nvar parse_SortData = parsenoop;\nvar parse_GUIDTypeLib = parsenoop;\nvar parse_FnGrp12 = parsenoop;\nvar parse_NameFnGrp12 = parsenoop;\nvar parse_HeaderFooter = parsenoop;\nvar parse_CrtLayout12 = parsenoop;\nvar parse_CrtMlFrt = parsenoop;\nvar parse_CrtMlFrtContinue = parsenoop;\nvar parse_ShapePropsStream = parsenoop;\nvar parse_TextPropsStream = parsenoop;\nvar parse_RichTextStream = parsenoop;\nvar parse_CrtLayout12A = parsenoop;\nvar parse_Units = parsenoop;\nvar parse_Chart = parsenoop;\nvar parse_Series = parsenoop;\nvar parse_DataFormat = parsenoop;\nvar parse_LineFormat = parsenoop;\nvar parse_MarkerFormat = parsenoop;\nvar parse_AreaFormat = parsenoop;\nvar parse_PieFormat = parsenoop;\nvar parse_AttachedLabel = parsenoop;\nvar parse_SeriesText = parsenoop;\nvar parse_ChartFormat = parsenoop;\nvar parse_Legend = parsenoop;\nvar parse_SeriesList = parsenoop;\nvar parse_Bar = parsenoop;\nvar parse_Line = parsenoop;\nvar parse_Pie = parsenoop;\nvar parse_Area = parsenoop;\nvar parse_Scatter = parsenoop;\nvar parse_CrtLine = parsenoop;\nvar parse_Axis = parsenoop;\nvar parse_Tick = parsenoop;\nvar parse_ValueRange = parsenoop;\nvar parse_CatSerRange = parsenoop;\nvar parse_AxisLine = parsenoop;\nvar parse_CrtLink = parsenoop;\nvar parse_DefaultText = parsenoop;\nvar parse_Text = parsenoop;\nvar parse_ObjectLink = parsenoop;\nvar parse_Frame = parsenoop;\nvar parse_Begin = parsenoop;\nvar parse_End = parsenoop;\nvar parse_PlotArea = parsenoop;\nvar parse_Chart3d = parsenoop;\nvar parse_PicF = parsenoop;\nvar parse_DropBar = parsenoop;\nvar parse_Radar = parsenoop;\nvar parse_Surf = parsenoop;\nvar parse_RadarArea = parsenoop;\nvar parse_AxisParent = parsenoop;\nvar parse_LegendException = parsenoop;\nvar parse_ShtProps = parsenoop;\nvar parse_SerToCrt = parsenoop;\nvar parse_AxesUsed = parsenoop;\nvar parse_SBaseRef = parsenoop;\nvar parse_SerParent = parsenoop;\nvar parse_SerAuxTrend = parsenoop;\nvar parse_IFmtRecord = parsenoop;\nvar parse_Pos = parsenoop;\nvar parse_AlRuns = parsenoop;\nvar parse_BRAI = parsenoop;\nvar parse_SerAuxErrBar = parsenoop;\nvar parse_SerFmt = parsenoop;\nvar parse_Chart3DBarShape = parsenoop;\nvar parse_Fbi = parsenoop;\nvar parse_BopPop = parsenoop;\nvar parse_AxcExt = parsenoop;\nvar parse_Dat = parsenoop;\nvar parse_PlotGrowth = parsenoop;\nvar parse_SIIndex = parsenoop;\nvar parse_GelFrame = parsenoop;\nvar parse_BopPopCustom = parsenoop;\nvar parse_Fbi2 = parsenoop;\n\n/* --- Specific to versions before BIFF8 --- */\nfunction parse_BIFF5String(blob) {\n\tvar len = blob.read_shift(1);\n\treturn blob.read_shift(len, 'sbcs-cont');\n}\n\n/* BIFF2_??? where ??? is the name from [XLS] */\nfunction parse_BIFF2STR(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar str = parse_XLUnicodeString2(blob, length-7, opts);\n\tcell.val = str;\n\treturn cell;\n}\n\nfunction parse_BIFF2NUM(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar num = parse_Xnum(blob, 8);\n\tcell.val = num;\n\treturn cell;\n}\n\n/* 18.4.1 charset to codepage mapping */\nvar CS2CP = {\n\t0: 1252, /* ANSI */\n\t1: 65001, /* DEFAULT */\n\t2: 65001, /* SYMBOL */\n\t77: 10000, /* MAC */\n\t128: 932, /* SHIFTJIS */\n\t129: 949, /* HANGUL */\n\t130: 1361, /* JOHAB */\n\t134: 936, /* GB2312 */\n\t136: 950, /* CHINESEBIG5 */\n\t161: 1253, /* GREEK */\n\t162: 1254, /* TURKISH */\n\t163: 1258, /* VIETNAMESE */\n\t177: 1255, /* HEBREW */\n\t178: 1256, /* ARABIC */\n\t186: 1257, /* BALTIC */\n\t204: 1251, /* RUSSIAN */\n\t222: 874, /* THAI */\n\t238: 1250, /* EASTEUROPE */\n\t255: 1252, /* OEM */\n\t69: 6969 /* MISC */\n};\n\n/* Parse a list of <r> tags */\nvar parse_rs = (function parse_rs_factory() {\n\tvar tregex = matchtag(\"t\"), rpregex = matchtag(\"rPr\"), rregex = /<r>/g, rend = /<\\/r>/, nlregex = /\\r\\n/g;\n\t/* 18.4.7 rPr CT_RPrElt */\n\tvar parse_rpr = function parse_rpr(rpr, intro, outro) {\n\t\tvar font = {}, cp = 65001;\n\t\tvar m = rpr.match(tagregex), i = 0;\n\t\tif(m) for(;i!=m.length; ++i) {\n\t\t\tvar y = parsexmltag(m[i]);\n\t\t\tswitch(y[0]) {\n\t\t\t\t/* 18.8.12 condense CT_BooleanProperty */\n\t\t\t\t/* ** not required . */\n\t\t\t\tcase '<condense': break;\n\t\t\t\t/* 18.8.17 extend CT_BooleanProperty */\n\t\t\t\t/* ** not required . */\n\t\t\t\tcase '<extend': break;\n\t\t\t\t/* 18.8.36 shadow CT_BooleanProperty */\n\t\t\t\t/* ** not required . */\n\t\t\t\tcase '<shadow':\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<shadow/>': break;\n\n\t\t\t\t/* 18.4.1 charset CT_IntProperty TODO */\n\t\t\t\tcase '<charset':\n\t\t\t\t\tif(y.val == '1') break;\n\t\t\t\t\tcp = CS2CP[parseInt(y.val, 10)];\n\t\t\t\t\tbreak;\n\n\t\t\t\t/* 18.4.2 outline CT_BooleanProperty TODO */\n\t\t\t\tcase '<outline':\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<outline/>': break;\n\n\t\t\t\t/* 18.4.5 rFont CT_FontName */\n\t\t\t\tcase '<rFont': font.name = y.val; break;\n\n\t\t\t\t/* 18.4.11 sz CT_FontSize */\n\t\t\t\tcase '<sz': font.sz = y.val; break;\n\n\t\t\t\t/* 18.4.10 strike CT_BooleanProperty */\n\t\t\t\tcase '<strike':\n\t\t\t\t\tif(!y.val) break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<strike/>': font.strike = 1; break;\n\t\t\t\tcase '</strike>': break;\n\n\t\t\t\t/* 18.4.13 u CT_UnderlineProperty */\n\t\t\t\tcase '<u':\n\t\t\t\t\tif(!y.val) break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<u/>': font.u = 1; break;\n\t\t\t\tcase '</u>': break;\n\n\t\t\t\t/* 18.8.2 b */\n\t\t\t\tcase '<b':\n\t\t\t\t\tif(!y.val) break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<b/>': font.b = 1; break;\n\t\t\t\tcase '</b>': break;\n\n\t\t\t\t/* 18.8.26 i */\n\t\t\t\tcase '<i':\n\t\t\t\t\tif(!y.val) break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase '<i/>': font.i = 1; break;\n\t\t\t\tcase '</i>': break;\n\n\t\t\t\t/* 18.3.1.15 color CT_Color TODO: tint, theme, auto, indexed */\n\t\t\t\tcase '<color':\n\t\t\t\t\tif(y.rgb) font.color = y.rgb.substr(2,6);\n\t\t\t\t\tbreak;\n\n\t\t\t\t/* 18.8.18 family ST_FontFamily */\n\t\t\t\tcase '<family': font.family = y.val; break;\n\n\t\t\t\t/* 18.4.14 vertAlign CT_VerticalAlignFontProperty TODO */\n\t\t\t\tcase '<vertAlign': break;\n\n\t\t\t\t/* 18.8.35 scheme CT_FontScheme TODO */\n\t\t\t\tcase '<scheme': break;\n\n\t\t\t\tdefault:\n\t\t\t\t\tif(y[0].charCodeAt(1) !== 47) throw 'Unrecognized rich format ' + y[0];\n\t\t\t}\n\t\t}\n\t\t/* TODO: These should be generated styles, not inline */\n\t\tvar style = [];\n\t\tif(font.b) style.push(\"font-weight: bold;\");\n\t\tif(font.i) style.push(\"font-style: italic;\");\n\t\tintro.push('<span style=\"' + style.join(\"\") + '\">');\n\t\toutro.push(\"</span>\");\n\t\treturn cp;\n\t};\n\n\t/* 18.4.4 r CT_RElt */\n\tfunction parse_r(r) {\n\t\tvar terms = [[],\"\",[]];\n\t\t/* 18.4.12 t ST_Xstring */\n\t\tvar t = r.match(tregex), cp = 65001;\n\t\tif(!isval(t)) return \"\";\n\t\tterms[1] = t[1];\n\n\t\tvar rpr = r.match(rpregex);\n\t\tif(isval(rpr)) cp = parse_rpr(rpr[1], terms[0], terms[2]);\n\n\t\treturn terms[0].join(\"\") + terms[1].replace(nlregex,'<br/>') + terms[2].join(\"\");\n\t}\n\treturn function parse_rs(rs) {\n\t\treturn rs.replace(rregex,\"\").split(rend).map(parse_r).join(\"\");\n\t};\n})();\n\n/* 18.4.8 si CT_Rst */\nvar sitregex = /<t[^>]*>([^<]*)<\\/t>/g, sirregex = /<r>/;\nfunction parse_si(x, opts) {\n\tvar html = opts ? opts.cellHTML : true;\n\tvar z = {};\n\tif(!x) return null;\n\tvar y;\n\t/* 18.4.12 t ST_Xstring (Plaintext String) */\n\tif(x.charCodeAt(1) === 116) {\n\t\tz.t = utf8read(unescapexml(x.substr(x.indexOf(\">\")+1).split(/<\\/t>/)[0]));\n\t\tz.r = x;\n\t\tif(html) z.h = z.t;\n\t}\n\t/* 18.4.4 r CT_RElt (Rich Text Run) */\n\telse if((y = x.match(sirregex))) {\n\t\tz.r = x;\n\t\tz.t = utf8read(unescapexml(x.match(sitregex).join(\"\").replace(tagregex,\"\")));\n\t\tif(html) z.h = parse_rs(x);\n\t}\n\t/* 18.4.3 phoneticPr CT_PhoneticPr (TODO: needed for Asian support) */\n\t/* 18.4.6 rPh CT_PhoneticRun (TODO: needed for Asian support) */\n\treturn z;\n}\n\n/* 18.4 Shared String Table */\nvar sstr0 = /<sst([^>]*)>([\\s\\S]*)<\\/sst>/;\nvar sstr1 = /<(?:si|sstItem)>/g;\nvar sstr2 = /<\\/(?:si|sstItem)>/;\nfunction parse_sst_xml(data, opts) {\n\tvar s = [], ss;\n\t/* 18.4.9 sst CT_Sst */\n\tvar sst = data.match(sstr0);\n\tif(isval(sst)) {\n\t\tss = sst[2].replace(sstr1,\"\").split(sstr2);\n\t\tfor(var i = 0; i != ss.length; ++i) {\n\t\t\tvar o = parse_si(ss[i], opts);\n\t\t\tif(o != null) s[s.length] = o;\n\t\t}\n\t\tsst = parsexmltag(sst[1]); s.Count = sst.count; s.Unique = sst.uniqueCount;\n\t}\n\treturn s;\n}\n\nRELS.SST = \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings\";\nvar straywsregex = /^\\s|\\s$|[\\t\\n\\r]/;\nfunction write_sst_xml(sst, opts) {\n\tif(!opts.bookSST) return \"\";\n\tvar o = [XML_HEADER];\n\to[o.length] = (writextag('sst', null, {\n\t\txmlns: XMLNS.main[0],\n\t\tcount: sst.Count,\n\t\tuniqueCount: sst.Unique\n\t}));\n\tfor(var i = 0; i != sst.length; ++i) { if(sst[i] == null) continue;\n\t\tvar s = sst[i];\n\t\tvar sitag = \"<si>\";\n\t\tif(s.r) sitag += s.r;\n\t\telse {\n\t\t\tsitag += \"<t\";\n\t\t\tif(s.t.match(straywsregex)) sitag += ' xml:space=\"preserve\"';\n\t\t\tsitag += \">\" + escapexml(s.t) + \"</t>\";\n\t\t}\n\t\tsitag += \"</si>\";\n\t\to[o.length] = (sitag);\n\t}\n\tif(o.length>2){ o[o.length] = ('</sst>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.219 BrtBeginSst */\nfunction parse_BrtBeginSst(data, length) {\n\treturn [data.read_shift(4), data.read_shift(4)];\n}\n\n/* [MS-XLSB] 2.1.7.45 Shared Strings */\nfunction parse_sst_bin(data, opts) {\n\tvar s = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_sst(val, R, RT) {\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtBeginSst': s.Count = val[0]; s.Unique = val[1]; break;\n\t\t\tcase 'BrtSSTItem': s.push(val); break;\n\t\t\tcase 'BrtEndSst': return true;\n\t\t\t/* TODO: produce a test case with a future record */\n\t\t\tcase 'BrtFRTBegin': pass = true; break;\n\t\t\tcase 'BrtFRTEnd': pass = false; break;\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + RT + \" \" + R.n);\n\t\t}\n\t});\n\treturn s;\n}\n\nfunction write_BrtBeginSst(sst, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(4, sst.Count);\n\to.write_shift(4, sst.Unique);\n\treturn o;\n}\n\nvar write_BrtSSTItem = write_RichStr;\n\nfunction write_sst_bin(sst, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, \"BrtBeginSst\", write_BrtBeginSst(sst));\n\tfor(var i = 0; i < sst.length; ++i) write_record(ba, \"BrtSSTItem\", write_BrtSSTItem(sst[i]));\n\twrite_record(ba, \"BrtEndSst\");\n\treturn ba.end();\n}\nfunction _JS2ANSI(str) { if(typeof cptable !== 'undefined') return cptable.utils.encode(1252, str); return str.split(\"\").map(function(x) { return x.charCodeAt(0); }); }\n\n/* [MS-OFFCRYPTO] 2.1.4 Version */\nfunction parse_Version(blob, length) {\n\tvar o = {};\n\to.Major = blob.read_shift(2);\n\to.Minor = blob.read_shift(2);\n\treturn o;\n}\n/* [MS-OFFCRYPTO] 2.3.2 Encryption Header */\nfunction parse_EncryptionHeader(blob, length) {\n\tvar o = {};\n\to.Flags = blob.read_shift(4);\n\n\t// Check if SizeExtra is 0x00000000\n\tvar tmp = blob.read_shift(4);\n\tif(tmp !== 0) throw 'Unrecognized SizeExtra: ' + tmp;\n\n\to.AlgID = blob.read_shift(4);\n\tswitch(o.AlgID) {\n\t\tcase 0: case 0x6801: case 0x660E: case 0x660F: case 0x6610: break;\n\t\tdefault: throw 'Unrecognized encryption algorithm: ' + o.AlgID;\n\t}\n\tparsenoop(blob, length-12);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.3 Encryption Verifier */\nfunction parse_EncryptionVerifier(blob, length) {\n\treturn parsenoop(blob, length);\n}\n/* [MS-OFFCRYPTO] 2.3.5.1 RC4 CryptoAPI Encryption Header */\nfunction parse_RC4CryptoHeader(blob, length) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_Version(blob, 4); length -= 4;\n\tif(vers.Minor != 2) throw 'unrecognized minor version code: ' + vers.Minor;\n\tif(vers.Major > 4 || vers.Major < 2) throw 'unrecognized major version code: ' + vers.Major;\n\to.Flags = blob.read_shift(4); length -= 4;\n\tvar sz = blob.read_shift(4); length -= 4;\n\to.EncryptionHeader = parse_EncryptionHeader(blob, sz); length -= sz;\n\to.EncryptionVerifier = parse_EncryptionVerifier(blob, length);\n\treturn o;\n}\n/* [MS-OFFCRYPTO] 2.3.6.1 RC4 Encryption Header */\nfunction parse_RC4Header(blob, length) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_Version(blob, 4); length -= 4;\n\tif(vers.Major != 1 || vers.Minor != 1) throw 'unrecognized version code ' + vers.Major + ' : ' + vers.Minor;\n\to.Salt = blob.read_shift(16);\n\to.EncryptedVerifier = blob.read_shift(16);\n\to.EncryptedVerifierHash = blob.read_shift(16);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.1 Binary Document Password Verifier Derivation */\nfunction crypto_CreatePasswordVerifier_Method1(Password) {\n\tvar Verifier = 0x0000, PasswordArray;\n\tvar PasswordDecoded = _JS2ANSI(Password);\n\tvar len = PasswordDecoded.length + 1, i, PasswordByte;\n\tvar Intermediate1, Intermediate2, Intermediate3;\n\tPasswordArray = new_raw_buf(len);\n\tPasswordArray[0] = PasswordDecoded.length;\n\tfor(i = 1; i != len; ++i) PasswordArray[i] = PasswordDecoded[i-1];\n\tfor(i = len-1; i >= 0; --i) {\n\t\tPasswordByte = PasswordArray[i];\n\t\tIntermediate1 = ((Verifier & 0x4000) === 0x0000) ? 0 : 1;\n\t\tIntermediate2 = (Verifier << 1) & 0x7FFF;\n\t\tIntermediate3 = Intermediate1 | Intermediate2;\n\t\tVerifier = Intermediate3 ^ PasswordByte;\n\t}\n\treturn Verifier ^ 0xCE4B;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.2 Binary Document XOR Array Initialization */\nvar crypto_CreateXorArray_Method1 = (function() {\n\tvar PadArray = [0xBB, 0xFF, 0xFF, 0xBA, 0xFF, 0xFF, 0xB9, 0x80, 0x00, 0xBE, 0x0F, 0x00, 0xBF, 0x0F, 0x00];\n\tvar InitialCode = [0xE1F0, 0x1D0F, 0xCC9C, 0x84C0, 0x110C, 0x0E10, 0xF1CE, 0x313E, 0x1872, 0xE139, 0xD40F, 0x84F9, 0x280C, 0xA96A, 0x4EC3];\n\tvar XorMatrix = [0xAEFC, 0x4DD9, 0x9BB2, 0x2745, 0x4E8A, 0x9D14, 0x2A09, 0x7B61, 0xF6C2, 0xFDA5, 0xEB6B, 0xC6F7, 0x9DCF, 0x2BBF, 0x4563, 0x8AC6, 0x05AD, 0x0B5A, 0x16B4, 0x2D68, 0x5AD0, 0x0375, 0x06EA, 0x0DD4, 0x1BA8, 0x3750, 0x6EA0, 0xDD40, 0xD849, 0xA0B3, 0x5147, 0xA28E, 0x553D, 0xAA7A, 0x44D5, 0x6F45, 0xDE8A, 0xAD35, 0x4A4B, 0x9496, 0x390D, 0x721A, 0xEB23, 0xC667, 0x9CEF, 0x29FF, 0x53FE, 0xA7FC, 0x5FD9, 0x47D3, 0x8FA6, 0x0F6D, 0x1EDA, 0x3DB4, 0x7B68, 0xF6D0, 0xB861, 0x60E3, 0xC1C6, 0x93AD, 0x377B, 0x6EF6, 0xDDEC, 0x45A0, 0x8B40, 0x06A1, 0x0D42, 0x1A84, 0x3508, 0x6A10, 0xAA51, 0x4483, 0x8906, 0x022D, 0x045A, 0x08B4, 0x1168, 0x76B4, 0xED68, 0xCAF1, 0x85C3, 0x1BA7, 0x374E, 0x6E9C, 0x3730, 0x6E60, 0xDCC0, 0xA9A1, 0x4363, 0x86C6, 0x1DAD, 0x3331, 0x6662, 0xCCC4, 0x89A9, 0x0373, 0x06E6, 0x0DCC, 0x1021, 0x2042, 0x4084, 0x8108, 0x1231, 0x2462, 0x48C4];\n\tvar Ror = function(Byte) { return ((Byte/2) | (Byte*128)) & 0xFF; };\n\tvar XorRor = function(byte1, byte2) { return Ror(byte1 ^ byte2); };\n\tvar CreateXorKey_Method1 = function(Password) {\n\t\tvar XorKey = InitialCode[Password.length - 1];\n\t\tvar CurrentElement = 0x68;\n\t\tfor(var i = Password.length-1; i >= 0; --i) {\n\t\t\tvar Char = Password[i];\n\t\t\tfor(var j = 0; j != 7; ++j) {\n\t\t\t\tif(Char & 0x40) XorKey ^= XorMatrix[CurrentElement];\n\t\t\t\tChar *= 2; --CurrentElement;\n\t\t\t}\n\t\t}\n\t\treturn XorKey;\n\t};\n\treturn function(password) {\n\t\tvar Password = _JS2ANSI(password);\n\t\tvar XorKey = CreateXorKey_Method1(Password);\n\t\tvar Index = Password.length;\n\t\tvar ObfuscationArray = new_raw_buf(16);\n\t\tfor(var i = 0; i != 16; ++i) ObfuscationArray[i] = 0x00;\n\t\tvar Temp, PasswordLastChar, PadIndex;\n\t\tif((Index & 1) === 1) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[0], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tPasswordLastChar = Password[Password.length - 1];\n\t\t\tObfuscationArray[Index] = XorRor(PasswordLastChar, Temp);\n\t\t}\n\t\twhile(Index > 0) {\n\t\t\t--Index;\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t}\n\t\tIndex = 15;\n\t\tPadIndex = 15 - Password.length;\n\t\twhile(PadIndex > 0) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[PadIndex], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t}\n\t\treturn ObfuscationArray;\n\t};\n})();\n\n/* [MS-OFFCRYPTO] 2.3.7.3 Binary Document XOR Data Transformation Method 1 */\nvar crypto_DecryptData_Method1 = function(password, Data, XorArrayIndex, XorArray, O) {\n\t/* If XorArray is set, use it; if O is not set, make changes in-place */\n\tif(!O) O = Data;\n\tif(!XorArray) XorArray = crypto_CreateXorArray_Method1(password);\n\tvar Index, Value;\n\tfor(Index = 0; Index != Data.length; ++Index) {\n\t\tValue = Data[Index];\n\t\tValue ^= XorArray[XorArrayIndex];\n\t\tValue = ((Value>>5) | (Value<<3)) & 0xFF;\n\t\tO[Index] = Value;\n\t\t++XorArrayIndex;\n\t}\n\treturn [O, XorArrayIndex, XorArray];\n};\n\nvar crypto_MakeXorDecryptor = function(password) {\n\tvar XorArrayIndex = 0, XorArray = crypto_CreateXorArray_Method1(password);\n\treturn function(Data) {\n\t\tvar O = crypto_DecryptData_Method1(null, Data, XorArrayIndex, XorArray);\n\t\tXorArrayIndex = O[1];\n\t\treturn O[0];\n\t};\n};\n\n/* 2.5.343 */\nfunction parse_XORObfuscation(blob, length, opts, out) {\n\tvar o = { key: parseuint16(blob), verificationBytes: parseuint16(blob) };\n\tif(opts.password) o.verifier = crypto_CreatePasswordVerifier_Method1(opts.password);\n\tout.valid = o.verificationBytes === o.verifier;\n\tif(out.valid) out.insitu_decrypt = crypto_MakeXorDecryptor(opts.password);\n\treturn o;\n}\n\n/* 2.4.117 */\nfunction parse_FilePassHeader(blob, length, oo) {\n\tvar o = oo || {}; o.Info = blob.read_shift(2); blob.l -= 2;\n\tif(o.Info === 1) o.Data = parse_RC4Header(blob, length);\n\telse o.Data = parse_RC4CryptoHeader(blob, length);\n\treturn o;\n}\nfunction parse_FilePass(blob, length, opts) {\n\tvar o = { Type: blob.read_shift(2) }; /* wEncryptionType */\n\tif(o.Type) parse_FilePassHeader(blob, length-2, o);\n\telse parse_XORObfuscation(blob, length-2, opts, o);\n\treturn o;\n}\n\n\nfunction hex2RGB(h) {\n\tvar o = h.substr(h[0]===\"#\"?1:0,6);\n\treturn [parseInt(o.substr(0,2),16),parseInt(o.substr(0,2),16),parseInt(o.substr(0,2),16)];\n}\nfunction rgb2Hex(rgb) {\n\tfor(var i=0,o=1; i!=3; ++i) o = o*256 + (rgb[i]>255?255:rgb[i]<0?0:rgb[i]);\n\treturn o.toString(16).toUpperCase().substr(1);\n}\n\nfunction rgb2HSL(rgb) {\n\tvar R = rgb[0]/255, G = rgb[1]/255, B=rgb[2]/255;\n\tvar M = Math.max(R, G, B), m = Math.min(R, G, B), C = M - m;\n\tif(C === 0) return [0, 0, R];\n\n\tvar H6 = 0, S = 0, L2 = (M + m);\n\tS = C / (L2 > 1 ? 2 - L2 : L2);\n\tswitch(M){\n\t\tcase R: H6 = ((G - B) / C + 6)%6; break;\n\t\tcase G: H6 = ((B - R) / C + 2); break;\n\t\tcase B: H6 = ((R - G) / C + 4); break;\n\t}\n\treturn [H6 / 6, S, L2 / 2];\n}\n\nfunction hsl2RGB(hsl){\n\tvar H = hsl[0], S = hsl[1], L = hsl[2];\n\tvar C = S * 2 * (L < 0.5 ? L : 1 - L), m = L - C/2;\n\tvar rgb = [m,m,m], h6 = 6*H;\n\n\tvar X;\n\tif(S !== 0) switch(h6|0) {\n\t\tcase 0: case 6: X = C * h6; rgb[0] += C; rgb[1] += X; break;\n\t\tcase 1: X = C * (2 - h6); rgb[0] += X; rgb[1] += C; break;\n\t\tcase 2: X = C * (h6 - 2); rgb[1] += C; rgb[2] += X; break;\n\t\tcase 3: X = C * (4 - h6); rgb[1] += X; rgb[2] += C; break;\n\t\tcase 4: X = C * (h6 - 4); rgb[2] += C; rgb[0] += X; break;\n\t\tcase 5: X = C * (6 - h6); rgb[2] += X; rgb[0] += C; break;\n\t}\n\tfor(var i = 0; i != 3; ++i) rgb[i] = Math.round(rgb[i]*255);\n\treturn rgb;\n}\n\n/* 18.8.3 bgColor tint algorithm */\nfunction rgb_tint(hex, tint) {\n\tif(tint === 0) return hex;\n\tvar hsl = rgb2HSL(hex2RGB(hex));\n\tif (tint < 0) hsl[2] = hsl[2] * (1 + tint);\n\telse hsl[2] = 1 - (1 - hsl[2]) * (1 - tint);\n\treturn rgb2Hex(hsl2RGB(hsl));\n}\n\n/* 18.3.1.13 width calculations */\nvar DEF_MDW = 7, MAX_MDW = 15, MIN_MDW = 1, MDW = DEF_MDW;\nfunction width2px(width) { return (( width + ((128/MDW)|0)/256 )* MDW )|0; }\nfunction px2char(px) { return (((px - 5)/MDW * 100 + 0.5)|0)/100; }\nfunction char2width(chr) { return (((chr * MDW + 5)/MDW*256)|0)/256; }\nfunction cycle_width(collw) { return char2width(px2char(width2px(collw))); }\nfunction find_mdw(collw, coll) {\n\tif(cycle_width(collw) != collw) {\n\t\tfor(MDW=DEF_MDW; MDW>MIN_MDW; --MDW) if(cycle_width(collw) === collw) break;\n\t\tif(MDW === MIN_MDW) for(MDW=DEF_MDW+1; MDW<MAX_MDW; ++MDW) if(cycle_width(collw) === collw) break;\n\t\tif(MDW === MAX_MDW) MDW = DEF_MDW;\n\t}\n}\n\n/* [MS-EXSPXML3] 2.4.54 ST_enmPattern */\nvar XLMLPatternTypeMap = {\n\t\"None\": \"none\",\n\t\"Solid\": \"solid\",\n\t\"Gray50\": \"mediumGray\",\n\t\"Gray75\": \"darkGray\",\n\t\"Gray25\": \"lightGray\",\n\t\"HorzStripe\": \"darkHorizontal\",\n\t\"VertStripe\": \"darkVertical\",\n\t\"ReverseDiagStripe\": \"darkDown\",\n\t\"DiagStripe\": \"darkUp\",\n\t\"DiagCross\": \"darkGrid\",\n\t\"ThickDiagCross\": \"darkTrellis\",\n\t\"ThinHorzStripe\": \"lightHorizontal\",\n\t\"ThinVertStripe\": \"lightVertical\",\n\t\"ThinReverseDiagStripe\": \"lightDown\",\n\t\"ThinHorzCross\": \"lightGrid\"\n};\n\nvar styles = {}; // shared styles\n\nvar themes = {}; // shared themes\n\n/* 18.8.21 fills CT_Fills */\nfunction parse_fills(t, opts) {\n\tstyles.Fills = [];\n\tvar fill = {};\n\tt[0].match(tagregex).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<fills': case '<fills>': case '</fills>': break;\n\n\t\t\t/* 18.8.20 fill CT_Fill */\n\t\t\tcase '<fill>': break;\n\t\t\tcase '</fill>': styles.Fills.push(fill); fill = {}; break;\n\n\t\t\t/* 18.8.32 patternFill CT_PatternFill */\n\t\t\tcase '<patternFill':\n\t\t\t\tif(y.patternType) fill.patternType = y.patternType;\n\t\t\t\tbreak;\n\t\t\tcase '<patternFill/>': case '</patternFill>': break;\n\n\t\t\t/* 18.8.3 bgColor CT_Color */\n\t\t\tcase '<bgColor':\n\t\t\t\tif(!fill.bgColor) fill.bgColor = {};\n\t\t\t\tif(y.indexed) fill.bgColor.indexed = parseInt(y.indexed, 10);\n\t\t\t\tif(y.theme) fill.bgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.bgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb) fill.bgColor.rgb = y.rgb.substring(y.rgb.length - 6);\n\t\t\t\tbreak;\n\t\t\tcase '<bgColor/>': case '</bgColor>': break;\n\n\t\t\t/* 18.8.19 fgColor CT_Color */\n\t\t\tcase '<fgColor':\n\t\t\t\tif(!fill.fgColor) fill.fgColor = {};\n\t\t\t\tif(y.theme) fill.fgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.fgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb) fill.fgColor.rgb = y.rgb.substring(y.rgb.length - 6);\n\t\t\t\tbreak;\n\t\t\tcase '<fgColor/>': case '</fgColor>': break;\n\n\t\t\tdefault: if(opts.WTF) throw 'unrecognized ' + y[0] + ' in fills';\n\t\t}\n\t});\n}\n\n/* 18.8.31 numFmts CT_NumFmts */\nfunction parse_numFmts(t, opts) {\n\tstyles.NumberFmt = [];\n\tvar k = keys(SSF._table);\n\tfor(var i=0; i < k.length; ++i) styles.NumberFmt[k[i]] = SSF._table[k[i]];\n\tvar m = t[0].match(tagregex);\n\tfor(i=0; i < m.length; ++i) {\n\t\tvar y = parsexmltag(m[i]);\n\t\tswitch(y[0]) {\n\t\t\tcase '<numFmts': case '</numFmts>': case '<numFmts/>': case '<numFmts>': break;\n\t\t\tcase '<numFmt': {\n\t\t\t\tvar f=unescapexml(utf8read(y.formatCode)), j=parseInt(y.numFmtId,10);\n\t\t\t\tstyles.NumberFmt[j] = f; if(j>0) SSF.load(f,j);\n\t\t\t} break;\n\t\t\tdefault: if(opts.WTF) throw 'unrecognized ' + y[0] + ' in numFmts';\n\t\t}\n\t}\n}\n\nfunction write_numFmts(NF, opts) {\n\tvar o = [\"<numFmts>\"];\n\t[[5,8],[23,26],[41,44],[63,66],[164,392]].forEach(function(r) {\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] !== undefined) o[o.length] = (writextag('numFmt',null,{numFmtId:i,formatCode:escapexml(NF[i])}));\n\t});\n\tif(o.length === 1) return \"\";\n\to[o.length] = (\"</numFmts>\");\n\to[0] = writextag('numFmts', null, { count:o.length-2 }).replace(\"/>\", \">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8.10 cellXfs CT_CellXfs */\nfunction parse_cellXfs(t, opts) {\n\tstyles.CellXf = [];\n\tt[0].match(tagregex).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<cellXfs': case '<cellXfs>': case '<cellXfs/>': case '</cellXfs>': break;\n\n\t\t\t/* 18.8.45 xf CT_Xf */\n\t\t\tcase '<xf': delete y[0];\n\t\t\t\tif(y.numFmtId) y.numFmtId = parseInt(y.numFmtId, 10);\n\t\t\t\tif(y.fillId) y.fillId = parseInt(y.fillId, 10);\n\t\t\t\tstyles.CellXf.push(y); break;\n\t\t\tcase '</xf>': break;\n\n\t\t\t/* 18.8.1 alignment CT_CellAlignment */\n\t\t\tcase '<alignment': case '<alignment/>': break;\n\n\t\t\t/* 18.8.33 protection CT_CellProtection */\n\t\t\tcase '<protection': case '</protection>': case '<protection/>': break;\n\n\t\t\tcase '<extLst': case '</extLst>': break;\n\t\t\tcase '<ext': break;\n\t\t\tdefault: if(opts.WTF) throw 'unrecognized ' + y[0] + ' in cellXfs';\n\t\t}\n\t});\n}\n\nfunction write_cellXfs(cellXfs) {\n\tvar o = [];\n\to[o.length] = (writextag('cellXfs',null));\n\tcellXfs.forEach(function(c) { o[o.length] = (writextag('xf', null, c)); });\n\to[o.length] = (\"</cellXfs>\");\n\tif(o.length === 2) return \"\";\n\to[0] = writextag('cellXfs',null, {count:o.length-2}).replace(\"/>\",\">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8 Styles CT_Stylesheet*/\nvar parse_sty_xml= (function make_pstyx() {\nvar numFmtRegex = /<numFmts([^>]*)>.*<\\/numFmts>/;\nvar cellXfRegex = /<cellXfs([^>]*)>.*<\\/cellXfs>/;\nvar fillsRegex = /<fills([^>]*)>.*<\\/fills>/;\n\nreturn function parse_sty_xml(data, opts) {\n\t/* 18.8.39 styleSheet CT_Stylesheet */\n\tvar t;\n\n\t/* numFmts CT_NumFmts ? */\n\tif((t=data.match(numFmtRegex))) parse_numFmts(t, opts);\n\n\t/* fonts CT_Fonts ? */\n\t/*if((t=data.match(/<fonts([^>]*)>.*<\\/fonts>/))) parse_fonts(t, opts);*/\n\n\t/* fills CT_Fills */\n\tif((t=data.match(fillsRegex))) parse_fills(t, opts);\n\n\t/* borders CT_Borders ? */\n\t/* cellStyleXfs CT_CellStyleXfs ? */\n\n\t/* cellXfs CT_CellXfs ? */\n\tif((t=data.match(cellXfRegex))) parse_cellXfs(t, opts);\n\n\t/* dxfs CT_Dxfs ? */\n\t/* tableStyles CT_TableStyles ? */\n\t/* colors CT_Colors ? */\n\t/* extLst CT_ExtensionList ? */\n\n\treturn styles;\n};\n})();\n\nvar STYLES_XML_ROOT = writextag('styleSheet', null, {\n\t'xmlns': XMLNS.main[0],\n\t'xmlns:vt': XMLNS.vt\n});\n\nRELS.STY = \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles\";\n\nfunction write_sty_xml(wb, opts) {\n\tvar o = [XML_HEADER, STYLES_XML_ROOT], w;\n\tif((w = write_numFmts(wb.SSF)) != null) o[o.length] = w;\n\to[o.length] = ('<fonts count=\"1\"><font><sz val=\"12\"/><color theme=\"1\"/><name val=\"Calibri\"/><family val=\"2\"/><scheme val=\"minor\"/></font></fonts>');\n\to[o.length] = ('<fills count=\"2\"><fill><patternFill patternType=\"none\"/></fill><fill><patternFill patternType=\"gray125\"/></fill></fills>');\n\to[o.length] = ('<borders count=\"1\"><border><left/><right/><top/><bottom/><diagonal/></border></borders>');\n\to[o.length] = ('<cellStyleXfs count=\"1\"><xf numFmtId=\"0\" fontId=\"0\" fillId=\"0\" borderId=\"0\"/></cellStyleXfs>');\n\tif((w = write_cellXfs(opts.cellXfs))) o[o.length] = (w);\n\to[o.length] = ('<cellStyles count=\"1\"><cellStyle name=\"Normal\" xfId=\"0\" builtinId=\"0\"/></cellStyles>');\n\to[o.length] = ('<dxfs count=\"0\"/>');\n\to[o.length] = ('<tableStyles count=\"0\" defaultTableStyle=\"TableStyleMedium9\" defaultPivotStyle=\"PivotStyleMedium4\"/>');\n\n\tif(o.length>2){ o[o.length] = ('</styleSheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.651 BrtFmt */\nfunction parse_BrtFmt(data, length) {\n\tvar ifmt = data.read_shift(2);\n\tvar stFmtCode = parse_XLWideString(data,length-2);\n\treturn [ifmt, stFmtCode];\n}\n\n/* [MS-XLSB] 2.4.653 BrtFont TODO */\nfunction parse_BrtFont(data, length) {\n\tvar out = {flags:{}};\n\tout.dyHeight = data.read_shift(2);\n\tout.grbit = parse_FontFlags(data, 2);\n\tout.bls = data.read_shift(2);\n\tout.sss = data.read_shift(2);\n\tout.uls = data.read_shift(1);\n\tout.bFamily = data.read_shift(1);\n\tout.bCharSet = data.read_shift(1);\n\tdata.l++;\n\tout.brtColor = parse_BrtColor(data, 8);\n\tout.bFontScheme = data.read_shift(1);\n\tout.name = parse_XLWideString(data, length - 21);\n\n\tout.flags.Bold = out.bls === 0x02BC;\n\tout.flags.Italic = out.grbit.fItalic;\n\tout.flags.Strikeout = out.grbit.fStrikeout;\n\tout.flags.Outline = out.grbit.fOutline;\n\tout.flags.Shadow = out.grbit.fShadow;\n\tout.flags.Condense = out.grbit.fCondense;\n\tout.flags.Extend = out.grbit.fExtend;\n\tout.flags.Sub = out.sss & 0x2;\n\tout.flags.Sup = out.sss & 0x1;\n\treturn out;\n}\n\n/* [MS-XLSB] 2.4.816 BrtXF */\nfunction parse_BrtXF(data, length) {\n\tvar ixfeParent = data.read_shift(2);\n\tvar ifmt = data.read_shift(2);\n\tparsenoop(data, length-4);\n\treturn {ixfe:ixfeParent, ifmt:ifmt };\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction parse_sty_bin(data, opts) {\n\tstyles.NumberFmt = [];\n\tfor(var y in SSF._table) styles.NumberFmt[y] = SSF._table[y];\n\n\tstyles.CellXf = [];\n\tvar state = \"\"; /* TODO: this should be a stack */\n\tvar pass = false;\n\trecordhopper(data, function hopper_sty(val, R, RT) {\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtFmt':\n\t\t\t\tstyles.NumberFmt[val[0]] = val[1]; SSF.load(val[1], val[0]);\n\t\t\t\tbreak;\n\t\t\tcase 'BrtFont': break; /* TODO */\n\t\t\tcase 'BrtKnownFonts': break; /* TODO */\n\t\t\tcase 'BrtFill': break; /* TODO */\n\t\t\tcase 'BrtBorder': break; /* TODO */\n\t\t\tcase 'BrtXF':\n\t\t\t\tif(state === \"CELLXFS\") {\n\t\t\t\t\tstyles.CellXf.push(val);\n\t\t\t\t}\n\t\t\t\tbreak; /* TODO */\n\t\t\tcase 'BrtStyle': break; /* TODO */\n\t\t\tcase 'BrtDXF': break; /* TODO */\n\t\t\tcase 'BrtMRUColor': break; /* TODO */\n\t\t\tcase 'BrtIndexedColor': break; /* TODO */\n\t\t\tcase 'BrtBeginStyleSheet': break;\n\t\t\tcase 'BrtEndStyleSheet': break;\n\t\t\tcase 'BrtBeginTableStyle': break;\n\t\t\tcase 'BrtTableStyleElement': break;\n\t\t\tcase 'BrtEndTableStyle': break;\n\t\t\tcase 'BrtBeginFmts': state = \"FMTS\"; break;\n\t\t\tcase 'BrtEndFmts': state = \"\"; break;\n\t\t\tcase 'BrtBeginFonts': state = \"FONTS\"; break;\n\t\t\tcase 'BrtEndFonts': state = \"\"; break;\n\t\t\tcase 'BrtACBegin': state = \"ACFONTS\"; break;\n\t\t\tcase 'BrtACEnd': state = \"\"; break;\n\t\t\tcase 'BrtBeginFills': state = \"FILLS\"; break;\n\t\t\tcase 'BrtEndFills': state = \"\"; break;\n\t\t\tcase 'BrtBeginBorders': state = \"BORDERS\"; break;\n\t\t\tcase 'BrtEndBorders': state = \"\"; break;\n\t\t\tcase 'BrtBeginCellStyleXFs': state = \"CELLSTYLEXFS\"; break;\n\t\t\tcase 'BrtEndCellStyleXFs': state = \"\"; break;\n\t\t\tcase 'BrtBeginCellXFs': state = \"CELLXFS\"; break;\n\t\t\tcase 'BrtEndCellXFs': state = \"\"; break;\n\t\t\tcase 'BrtBeginStyles': state = \"STYLES\"; break;\n\t\t\tcase 'BrtEndStyles': state = \"\"; break;\n\t\t\tcase 'BrtBeginDXFs': state = \"DXFS\"; break;\n\t\t\tcase 'BrtEndDXFs': state = \"\"; break;\n\t\t\tcase 'BrtBeginTableStyles': state = \"TABLESTYLES\"; break;\n\t\t\tcase 'BrtEndTableStyles': state = \"\"; break;\n\t\t\tcase 'BrtBeginColorPalette': state = \"COLORPALETTE\"; break;\n\t\t\tcase 'BrtEndColorPalette': state = \"\"; break;\n\t\t\tcase 'BrtBeginIndexedColors': state = \"INDEXEDCOLORS\"; break;\n\t\t\tcase 'BrtEndIndexedColors': state = \"\"; break;\n\t\t\tcase 'BrtBeginMRUColors': state = \"MRUCOLORS\"; break;\n\t\t\tcase 'BrtEndMRUColors': state = \"\"; break;\n\t\t\tcase 'BrtFRTBegin': pass = true; break;\n\t\t\tcase 'BrtFRTEnd': pass = false; break;\n\t\t\tcase 'BrtBeginStyleSheetExt14': break;\n\t\t\tcase 'BrtBeginSlicerStyles': break;\n\t\t\tcase 'BrtEndSlicerStyles': break;\n\t\t\tcase 'BrtBeginTimelineStylesheetExt15': break;\n\t\t\tcase 'BrtEndTimelineStylesheetExt15': break;\n\t\t\tcase 'BrtBeginTimelineStyles': break;\n\t\t\tcase 'BrtEndTimelineStyles': break;\n\t\t\tcase 'BrtEndStyleSheetExt14': break;\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + RT + \" \" + R.n);\n\t\t}\n\t});\n\treturn styles;\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction write_sty_bin(data, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, \"BrtBeginStyleSheet\");\n\t/* [FMTS] */\n\t/* [FONTS] */\n\t/* [FILLS] */\n\t/* [BORDERS] */\n\t/* CELLSTYLEXFS */\n\t/* CELLXFS*/\n\t/* STYLES */\n\t/* DXFS */\n\t/* TABLESTYLES */\n\t/* [COLORPALETTE] */\n\t/* FRTSTYLESHEET*/\n\twrite_record(ba, \"BrtEndStyleSheet\");\n\treturn ba.end();\n}\nRELS.THEME = \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme\";\n\n/* 20.1.6.2 clrScheme CT_ColorScheme */\nfunction parse_clrScheme(t, opts) {\n\tthemes.themeElements.clrScheme = [];\n\tvar color = {};\n\tt[0].match(tagregex).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<a:clrScheme': case '</a:clrScheme>': break;\n\n\t\t\t/* 20.1.2.3.32 srgbClr CT_SRgbColor */\n\t\t\tcase '<a:srgbClr': color.rgb = y.val; break;\n\n\t\t\t/* 20.1.2.3.33 sysClr CT_SystemColor */\n\t\t\tcase '<a:sysClr': color.rgb = y.lastClr; break;\n\n\t\t\t/* 20.1.4.1.9 dk1 (Dark 1) */\n\t\t\tcase '<a:dk1>':\n\t\t\tcase '</a:dk1>':\n\t\t\t/* 20.1.4.1.10 dk2 (Dark 2) */\n\t\t\tcase '<a:dk2>':\n\t\t\tcase '</a:dk2>':\n\t\t\t/* 20.1.4.1.22 lt1 (Light 1) */\n\t\t\tcase '<a:lt1>':\n\t\t\tcase '</a:lt1>':\n\t\t\t/* 20.1.4.1.23 lt2 (Light 2) */\n\t\t\tcase '<a:lt2>':\n\t\t\tcase '</a:lt2>':\n\t\t\t/* 20.1.4.1.1 accent1 (Accent 1) */\n\t\t\tcase '<a:accent1>':\n\t\t\tcase '</a:accent1>':\n\t\t\t/* 20.1.4.1.2 accent2 (Accent 2) */\n\t\t\tcase '<a:accent2>':\n\t\t\tcase '</a:accent2>':\n\t\t\t/* 20.1.4.1.3 accent3 (Accent 3) */\n\t\t\tcase '<a:accent3>':\n\t\t\tcase '</a:accent3>':\n\t\t\t/* 20.1.4.1.4 accent4 (Accent 4) */\n\t\t\tcase '<a:accent4>':\n\t\t\tcase '</a:accent4>':\n\t\t\t/* 20.1.4.1.5 accent5 (Accent 5) */\n\t\t\tcase '<a:accent5>':\n\t\t\tcase '</a:accent5>':\n\t\t\t/* 20.1.4.1.6 accent6 (Accent 6) */\n\t\t\tcase '<a:accent6>':\n\t\t\tcase '</a:accent6>':\n\t\t\t/* 20.1.4.1.19 hlink (Hyperlink) */\n\t\t\tcase '<a:hlink>':\n\t\t\tcase '</a:hlink>':\n\t\t\t/* 20.1.4.1.15 folHlink (Followed Hyperlink) */\n\t\t\tcase '<a:folHlink>':\n\t\t\tcase '</a:folHlink>':\n\t\t\t\tif (y[0][1] === '/') {\n\t\t\t\t\tthemes.themeElements.clrScheme.push(color);\n\t\t\t\t\tcolor = {};\n\t\t\t\t} else {\n\t\t\t\t\tcolor.name = y[0].substring(3, y[0].length - 1);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tdefault: if(opts.WTF) throw 'unrecognized ' + y[0] + ' in clrScheme';\n\t\t}\n\t});\n}\n\n/* 20.1.4.1.18 fontScheme CT_FontScheme */\nfunction parse_fontScheme(t, opts) { }\n\n/* 20.1.4.1.15 fmtScheme CT_StyleMatrix */\nfunction parse_fmtScheme(t, opts) { }\n\nvar clrsregex = /<a:clrScheme([^>]*)>[^\\u2603]*<\\/a:clrScheme>/;\nvar fntsregex = /<a:fontScheme([^>]*)>[^\\u2603]*<\\/a:fontScheme>/;\nvar fmtsregex = /<a:fmtScheme([^>]*)>[^\\u2603]*<\\/a:fmtScheme>/;\n\n/* 20.1.6.10 themeElements CT_BaseStyles */\nfunction parse_themeElements(data, opts) {\n\tthemes.themeElements = {};\n\n\tvar t;\n\n\t[\n\t\t/* clrScheme CT_ColorScheme */\n\t\t['clrScheme', clrsregex, parse_clrScheme],\n\t\t/* fontScheme CT_FontScheme */\n\t\t['fontScheme', fntsregex, parse_fontScheme],\n\t\t/* fmtScheme CT_StyleMatrix */\n\t\t['fmtScheme', fmtsregex, parse_fmtScheme]\n\t].forEach(function(m) {\n\t\tif(!(t=data.match(m[1]))) throw m[0] + ' not found in themeElements';\n\t\tm[2](t, opts);\n\t});\n}\n\nvar themeltregex = /<a:themeElements([^>]*)>[^\\u2603]*<\\/a:themeElements>/;\n\n/* 14.2.7 Theme Part */\nfunction parse_theme_xml(data, opts) {\n\t/* 20.1.6.9 theme CT_OfficeStyleSheet */\n\tif(!data || data.length === 0) return themes;\n\n\tvar t;\n\n\t/* themeElements CT_BaseStyles */\n\tif(!(t=data.match(themeltregex))) throw 'themeElements not found in theme';\n\tparse_themeElements(t[0], opts);\n\n\treturn themes;\n}\n\nfunction write_theme() { return '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\n<a:theme xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\" name=\"Office Theme\"><a:themeElements><a:clrScheme name=\"Office\"><a:dk1><a:sysClr val=\"windowText\" lastClr=\"000000\"/></a:dk1><a:lt1><a:sysClr val=\"window\" lastClr=\"FFFFFF\"/></a:lt1><a:dk2><a:srgbClr val=\"1F497D\"/></a:dk2><a:lt2><a:srgbClr val=\"EEECE1\"/></a:lt2><a:accent1><a:srgbClr val=\"4F81BD\"/></a:accent1><a:accent2><a:srgbClr val=\"C0504D\"/></a:accent2><a:accent3><a:srgbClr val=\"9BBB59\"/></a:accent3><a:accent4><a:srgbClr val=\"8064A2\"/></a:accent4><a:accent5><a:srgbClr val=\"4BACC6\"/></a:accent5><a:accent6><a:srgbClr val=\"F79646\"/></a:accent6><a:hlink><a:srgbClr val=\"0000FF\"/></a:hlink><a:folHlink><a:srgbClr val=\"800080\"/></a:folHlink></a:clrScheme><a:fontScheme name=\"Office\"><a:majorFont><a:latin typeface=\"Cambria\"/><a:ea typeface=\"\"/><a:cs typeface=\"\"/><a:font script=\"Jpan\" typeface=\"MS Pゴシック\"/><a:font script=\"Hang\" typeface=\"맑은 고딕\"/><a:font script=\"Hans\" typeface=\"宋体\"/><a:font script=\"Hant\" typeface=\"新細明體\"/><a:font script=\"Arab\" typeface=\"Times New Roman\"/><a:font script=\"Hebr\" typeface=\"Times New Roman\"/><a:font script=\"Thai\" typeface=\"Tahoma\"/><a:font script=\"Ethi\" typeface=\"Nyala\"/><a:font script=\"Beng\" typeface=\"Vrinda\"/><a:font script=\"Gujr\" typeface=\"Shruti\"/><a:font script=\"Khmr\" typeface=\"MoolBoran\"/><a:font script=\"Knda\" typeface=\"Tunga\"/><a:font script=\"Guru\" typeface=\"Raavi\"/><a:font script=\"Cans\" typeface=\"Euphemia\"/><a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/><a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/><a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/><a:font script=\"Thaa\" typeface=\"MV Boli\"/><a:font script=\"Deva\" typeface=\"Mangal\"/><a:font script=\"Telu\" typeface=\"Gautami\"/><a:font script=\"Taml\" typeface=\"Latha\"/><a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/><a:font script=\"Orya\" typeface=\"Kalinga\"/><a:font script=\"Mlym\" typeface=\"Kartika\"/><a:font script=\"Laoo\" typeface=\"DokChampa\"/><a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/><a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/><a:font script=\"Viet\" typeface=\"Times New Roman\"/><a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/><a:font script=\"Geor\" typeface=\"Sylfaen\"/></a:majorFont><a:minorFont><a:latin typeface=\"Calibri\"/><a:ea typeface=\"\"/><a:cs typeface=\"\"/><a:font script=\"Jpan\" typeface=\"MS Pゴシック\"/><a:font script=\"Hang\" typeface=\"맑은 고딕\"/><a:font script=\"Hans\" typeface=\"宋体\"/><a:font script=\"Hant\" typeface=\"新細明體\"/><a:font script=\"Arab\" typeface=\"Arial\"/><a:font script=\"Hebr\" typeface=\"Arial\"/><a:font script=\"Thai\" typeface=\"Tahoma\"/><a:font script=\"Ethi\" typeface=\"Nyala\"/><a:font script=\"Beng\" typeface=\"Vrinda\"/><a:font script=\"Gujr\" typeface=\"Shruti\"/><a:font script=\"Khmr\" typeface=\"DaunPenh\"/><a:font script=\"Knda\" typeface=\"Tunga\"/><a:font script=\"Guru\" typeface=\"Raavi\"/><a:font script=\"Cans\" typeface=\"Euphemia\"/><a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/><a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/><a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/><a:font script=\"Thaa\" typeface=\"MV Boli\"/><a:font script=\"Deva\" typeface=\"Mangal\"/><a:font script=\"Telu\" typeface=\"Gautami\"/><a:font script=\"Taml\" typeface=\"Latha\"/><a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/><a:font script=\"Orya\" typeface=\"Kalinga\"/><a:font script=\"Mlym\" typeface=\"Kartika\"/><a:font script=\"Laoo\" typeface=\"DokChampa\"/><a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/><a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/><a:font script=\"Viet\" typeface=\"Arial\"/><a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/><a:font script=\"Geor\" typeface=\"Sylfaen\"/></a:minorFont></a:fontScheme><a:fmtScheme name=\"Office\"><a:fillStyleLst><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:gradFill rotWithShape=\"1\"><a:gsLst><a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs><a:gs pos=\"35000\"><a:schemeClr val=\"phClr\"><a:tint val=\"37000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs><a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"15000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs></a:gsLst><a:lin ang=\"16200000\" scaled=\"1\"/></a:gradFill><a:gradFill rotWithShape=\"1\"><a:gsLst><a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"100000\"/><a:shade val=\"100000\"/><a:satMod val=\"130000\"/></a:schemeClr></a:gs><a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:shade val=\"100000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs></a:gsLst><a:lin ang=\"16200000\" scaled=\"0\"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w=\"9525\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"><a:shade val=\"95000\"/><a:satMod val=\"105000\"/></a:schemeClr></a:solidFill><a:prstDash val=\"solid\"/></a:ln><a:ln w=\"25400\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln><a:ln w=\"38100\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst><a:outerShdw blurRad=\"40000\" dist=\"20000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"38000\"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw></a:effectLst><a:scene3d><a:camera prst=\"orthographicFront\"><a:rot lat=\"0\" lon=\"0\" rev=\"0\"/></a:camera><a:lightRig rig=\"threePt\" dir=\"t\"><a:rot lat=\"0\" lon=\"0\" rev=\"1200000\"/></a:lightRig></a:scene3d><a:sp3d><a:bevelT w=\"63500\" h=\"25400\"/></a:sp3d></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:gradFill rotWithShape=\"1\"><a:gsLst><a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"40000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs><a:gs pos=\"40000\"><a:schemeClr val=\"phClr\"><a:tint val=\"45000\"/><a:shade val=\"99000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs><a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"20000\"/><a:satMod val=\"255000\"/></a:schemeClr></a:gs></a:gsLst><a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"-80000\" r=\"50000\" b=\"180000\"/></a:path></a:gradFill><a:gradFill rotWithShape=\"1\"><a:gsLst><a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"80000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs><a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"30000\"/><a:satMod val=\"200000\"/></a:schemeClr></a:gs></a:gsLst><a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"50000\" r=\"50000\" b=\"50000\"/></a:path></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults><a:spDef><a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"3\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"lt1\"/></a:fontRef></a:style></a:spDef><a:lnDef><a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"0\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"tx1\"/></a:fontRef></a:style></a:lnDef></a:objectDefaults><a:extraClrSchemeLst/></a:theme>'; }\n/* [MS-XLS] 2.4.326 TODO: payload is a zip file */\nfunction parse_Theme(blob, length) {\n\tvar dwThemeVersion = blob.read_shift(4);\n\tif(dwThemeVersion === 124226) return;\n\tblob.l += length-4;\n}\n\n/* 2.5.49 */\nfunction parse_ColorTheme(blob, length) { return blob.read_shift(4); }\n\n/* 2.5.155 */\nfunction parse_FullColorExt(blob, length) {\n\tvar o = {};\n\to.xclrType = blob.read_shift(2);\n\to.nTintShade = blob.read_shift(2);\n\tswitch(o.xclrType) {\n\t\tcase 0: blob.l += 4; break;\n\t\tcase 1: o.xclrValue = parse_IcvXF(blob, 4); break;\n\t\tcase 2: o.xclrValue = parse_LongRGBA(blob, 4); break;\n\t\tcase 3: o.xclrValue = parse_ColorTheme(blob, 4); break;\n\t\tcase 4: blob.l += 4; break;\n\t}\n\tblob.l += 8;\n\treturn o;\n}\n\n/* 2.5.164 TODO: read 7 bits*/\nfunction parse_IcvXF(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* 2.5.280 */\nfunction parse_XFExtGradient(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* 2.5.108 */\nfunction parse_ExtProp(blob, length) {\n\tvar extType = blob.read_shift(2);\n\tvar cb = blob.read_shift(2);\n\tvar o = [extType];\n\tswitch(extType) {\n\t\tcase 0x04: case 0x05: case 0x07: case 0x08:\n\t\tcase 0x09: case 0x0A: case 0x0B: case 0x0D:\n\t\t\to[1] = parse_FullColorExt(blob, cb); break;\n\t\tcase 0x06: o[1] = parse_XFExtGradient(blob, cb); break;\n\t\tcase 0x0E: case 0x0F: o[1] = blob.read_shift(cb === 5 ? 1 : 2); break;\n\t\tdefault: throw new Error(\"Unrecognized ExtProp type: \" + extType + \" \" + cb);\n\t}\n\treturn o;\n}\n\n/* 2.4.355 */\nfunction parse_XFExt(blob, length) {\n\tvar end = blob.l + length;\n\tblob.l += 2;\n\tvar ixfe = blob.read_shift(2);\n\tblob.l += 2;\n\tvar cexts = blob.read_shift(2);\n\tvar ext = [];\n\twhile(cexts-- > 0) ext.push(parse_ExtProp(blob, end-blob.l));\n\treturn {ixfe:ixfe, ext:ext};\n}\n\n/* xf is an XF, see parse_XFExt for xfext */\nfunction update_xfext(xf, xfext) {\n\txfext.forEach(function(xfe) {\n\t\tswitch(xfe[0]) { /* 2.5.108 extPropData */\n\t\t\tcase 0x04: break; /* foreground color */\n\t\t\tcase 0x05: break; /* background color */\n\t\t\tcase 0x07: case 0x08: case 0x09: case 0x0a: break;\n\t\t\tcase 0x0d: break; /* text color */\n\t\t\tcase 0x0e: break; /* font scheme */\n\t\t\tdefault: throw \"bafuq\" + xfe[0].toString(16);\n\t\t}\n\t});\n}\n\n/* 18.6 Calculation Chain */\nfunction parse_cc_xml(data, opts) {\n\tvar d = [];\n\tvar l = 0, i = 1;\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\t/* 18.6.2 calcChain CT_CalcChain 1 */\n\t\t\tcase '<calcChain': case '<calcChain>': case '</calcChain>': break;\n\t\t\t/* 18.6.1 c CT_CalcCell 1 */\n\t\t\tcase '<c': delete y[0]; if(y.i) i = y.i; else y.i = i; d.push(y); break;\n\t\t}\n\t});\n\treturn d;\n}\n\nfunction write_cc_xml(data, opts) { }\n/* [MS-XLSB] 2.6.4.1 */\nfunction parse_BrtCalcChainItem$(data, length) {\n\tvar out = {};\n\tout.i = data.read_shift(4);\n\tvar cell = {};\n\tcell.r = data.read_shift(4);\n\tcell.c = data.read_shift(4);\n\tout.r = encode_cell(cell);\n\tvar flags = data.read_shift(1);\n\tif(flags & 0x2) out.l = '1';\n\tif(flags & 0x8) out.a = '1';\n\treturn out;\n}\n\n/* 18.6 Calculation Chain */\nfunction parse_cc_bin(data, opts) {\n\tvar out = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_cc(val, R, RT) {\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtCalcChainItem$': out.push(val); break;\n\t\t\tcase 'BrtBeginCalcChain$': break;\n\t\t\tcase 'BrtEndCalcChain$': break;\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + RT + \" \" + R.n);\n\t\t}\n\t});\n\treturn out;\n}\n\nfunction write_cc_bin(data, opts) { }\n\nfunction parse_comments(zip, dirComments, sheets, sheetRels, opts) {\n\tfor(var i = 0; i != dirComments.length; ++i) {\n\t\tvar canonicalpath=dirComments[i];\n\t\tvar comments=parse_cmnt(getzipdata(zip, canonicalpath.replace(/^\\//,''), true), canonicalpath, opts);\n\t\tif(!comments || !comments.length) continue;\n\t\t// find the sheets targeted by these comments\n\t\tvar sheetNames = keys(sheets);\n\t\tfor(var j = 0; j != sheetNames.length; ++j) {\n\t\t\tvar sheetName = sheetNames[j];\n\t\t\tvar rels = sheetRels[sheetName];\n\t\t\tif(rels) {\n\t\t\t\tvar rel = rels[canonicalpath];\n\t\t\t\tif(rel) insertCommentsIntoSheet(sheetName, sheets[sheetName], comments);\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction insertCommentsIntoSheet(sheetName, sheet, comments) {\n\tcomments.forEach(function(comment) {\n\t\tvar cell = sheet[comment.ref];\n\t\tif (!cell) {\n\t\t\tcell = {};\n\t\t\tsheet[comment.ref] = cell;\n\t\t\tvar range = safe_decode_range(sheet[\"!ref\"]||\"BDWGO1000001:A1\");\n\t\t\tvar thisCell = decode_cell(comment.ref);\n\t\t\tif(range.s.r > thisCell.r) range.s.r = thisCell.r;\n\t\t\tif(range.e.r < thisCell.r) range.e.r = thisCell.r;\n\t\t\tif(range.s.c > thisCell.c) range.s.c = thisCell.c;\n\t\t\tif(range.e.c < thisCell.c) range.e.c = thisCell.c;\n\t\t\tvar encoded = encode_range(range);\n\t\t\tif (encoded !== sheet[\"!ref\"]) sheet[\"!ref\"] = encoded;\n\t\t}\n\n\t\tif (!cell.c) cell.c = [];\n\t\tvar o = {a: comment.author, t: comment.t, r: comment.r};\n\t\tif(comment.h) o.h = comment.h;\n\t\tcell.c.push(o);\n\t});\n}\n\n/* 18.7.3 CT_Comment */\nfunction parse_comments_xml(data, opts) {\n\tif(data.match(/<(?:\\w+:)?comments *\\/>/)) return [];\n\tvar authors = [];\n\tvar commentList = [];\n\tdata.match(/<(?:\\w+:)?authors>([^\\u2603]*)<\\/(?:\\w+:)?authors>/)[1].split(/<\\/\\w*:?author>/).forEach(function(x) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tauthors.push(x.match(/<(?:\\w+:)?author[^>]*>(.*)/)[1]);\n\t});\n\t(data.match(/<(?:\\w+:)?commentList>([^\\u2603]*)<\\/(?:\\w+:)?commentList>/)||[\"\",\"\"])[1].split(/<\\/\\w*:?comment>/).forEach(function(x, index) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tvar y = parsexmltag(x.match(/<(?:\\w+:)?comment[^>]*>/)[0]);\n\t\tvar comment = { author: y.authorId && authors[y.authorId] ? authors[y.authorId] : undefined, ref: y.ref, guid: y.guid };\n\t\tvar cell = decode_cell(y.ref);\n\t\tif(opts.sheetRows && opts.sheetRows <= cell.r) return;\n\t\tvar textMatch = x.match(/<text>([^\\u2603]*)<\\/text>/);\n\t\tif (!textMatch || !textMatch[1]) return; // a comment may contain an empty text tag.\n\t\tvar rt = parse_si(textMatch[1]);\n\t\tcomment.r = rt.r;\n\t\tcomment.t = rt.t;\n\t\tif(opts.cellHTML) comment.h = rt.h;\n\t\tcommentList.push(comment);\n\t});\n\treturn commentList;\n}\n\nfunction write_comments_xml(data, opts) { }\n/* [MS-XLSB] 2.4.28 BrtBeginComment */\nfunction parse_BrtBeginComment(data, length) {\n\tvar out = {};\n\tout.iauthor = data.read_shift(4);\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tout.rfx = rfx.s;\n\tout.ref = encode_cell(rfx.s);\n\tdata.l += 16; /*var guid = parse_GUID(data); */\n\treturn out;\n}\n\n/* [MS-XLSB] 2.4.324 BrtCommentAuthor */\nvar parse_BrtCommentAuthor = parse_XLWideString;\n\n/* [MS-XLSB] 2.4.325 BrtCommentText */\nvar parse_BrtCommentText = parse_RichStr;\n\n/* [MS-XLSB] 2.1.7.8 Comments */\nfunction parse_comments_bin(data, opts) {\n\tvar out = [];\n\tvar authors = [];\n\tvar c = {};\n\tvar pass = false;\n\trecordhopper(data, function hopper_cmnt(val, R, RT) {\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtCommentAuthor': authors.push(val); break;\n\t\t\tcase 'BrtBeginComment': c = val; break;\n\t\t\tcase 'BrtCommentText': c.t = val.t; c.h = val.h; c.r = val.r; break;\n\t\t\tcase 'BrtEndComment':\n\t\t\t\tc.author = authors[c.iauthor];\n\t\t\t\tdelete c.iauthor;\n\t\t\t\tif(opts.sheetRows && opts.sheetRows <= c.rfx.r) break;\n\t\t\t\tdelete c.rfx; out.push(c); break;\n\t\t\tcase 'BrtBeginComments': break;\n\t\t\tcase 'BrtEndComments': break;\n\t\t\tcase 'BrtBeginCommentAuthors': break;\n\t\t\tcase 'BrtEndCommentAuthors': break;\n\t\t\tcase 'BrtBeginCommentList': break;\n\t\t\tcase 'BrtEndCommentList': break;\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + RT + \" \" + R.n);\n\t\t}\n\t});\n\treturn out;\n}\n\nfunction write_comments_bin(data, opts) { }\n/* TODO: it will be useful to parse the function str */\nvar rc_to_a1 = (function(){\n\tvar rcregex = /(^|[^A-Za-z])R(\\[?)(-?\\d+|)\\]?C(\\[?)(-?\\d+|)\\]?/g;\n\tvar rcbase;\n\tfunction rcfunc($$,$1,$2,$3,$4,$5) {\n\t\tvar R = $3.length>0?parseInt($3,10)|0:0, C = $5.length>0?parseInt($5,10)|0:0;\n\t\tif(C<0 && $4.length === 0) C=0;\n\t\tif($4.length > 0) C += rcbase.c;\n\t\tif($2.length > 0) R += rcbase.r;\n\t\treturn $1 + encode_col(C) + encode_row(R);\n\t}\n\treturn function rc_to_a1(fstr, base) {\n\t\trcbase = base;\n\t\treturn fstr.replace(rcregex, rcfunc);\n\t};\n})();\n\n/* --- formula references point to MS-XLS --- */\n/* Small helpers */\nfunction parseread(l) { return function(blob, length) { blob.l+=l; return; }; }\nfunction parseread1(blob, length) { blob.l+=1; return; }\n\n/* Rgce Helpers */\n\n/* 2.5.51 */\nfunction parse_ColRelU(blob, length) {\n\tvar c = blob.read_shift(2);\n\treturn [c & 0x3FFF, (c >> 14) & 1, (c >> 15) & 1];\n}\n\n/* 2.5.198.105 */\nfunction parse_RgceArea(blob, length) {\n\tvar r=blob.read_shift(2), R=blob.read_shift(2);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n\n/* 2.5.198.105 TODO */\nfunction parse_RgceAreaRel(blob, length) {\n\tvar r=blob.read_shift(2), R=blob.read_shift(2);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n\n/* 2.5.198.109 */\nfunction parse_RgceLoc(blob, length) {\n\tvar r = blob.read_shift(2);\n\tvar c = parse_ColRelU(blob, 2);\n\treturn {r:r, c:c[0], cRel:c[1], rRel:c[2]};\n}\n\n/* 2.5.198.111 */\nfunction parse_RgceLocRel(blob, length) {\n\tvar r = blob.read_shift(2);\n\tvar cl = blob.read_shift(2);\n\tvar cRel = (cl & 0x8000) >> 15, rRel = (cl & 0x4000) >> 14;\n\tcl &= 0x3FFF;\n\tif(cRel !== 0) while(cl >= 0x100) cl -= 0x100;\n\treturn {r:r,c:cl,cRel:cRel,rRel:rRel};\n}\n\n/* Ptg Tokens */\n\n/* 2.5.198.27 */\nfunction parse_PtgArea(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceArea(blob, 8);\n\treturn [type, area];\n}\n\n/* 2.5.198.28 */\nfunction parse_PtgArea3d(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tvar area = parse_RgceArea(blob, 8);\n\treturn [type, ixti, area];\n}\n\n/* 2.5.198.29 */\nfunction parse_PtgAreaErr(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += 8;\n\treturn [type];\n}\n/* 2.5.198.30 */\nfunction parse_PtgAreaErr3d(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tblob.l += 8;\n\treturn [type, ixti];\n}\n\n/* 2.5.198.31 */\nfunction parse_PtgAreaN(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceAreaRel(blob, 8);\n\treturn [type, area];\n}\n\n/* 2.5.198.32 -- ignore this and look in PtgExtraArray for shape + values */\nfunction parse_PtgArray(blob, length) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += 7;\n\treturn [type];\n}\n\n/* 2.5.198.33 */\nfunction parse_PtgAttrBaxcel(blob, length) {\n\tvar bitSemi = blob[blob.l+1] & 0x01; /* 1 = volatile */\n\tvar bitBaxcel = 1;\n\tblob.l += 4;\n\treturn [bitSemi, bitBaxcel];\n}\n\n/* 2.5.198.34 */\nfunction parse_PtgAttrChoose(blob, length) {\n\tblob.l +=2;\n\tvar offset = blob.read_shift(2);\n\tvar o = [];\n\t/* offset is 1 less than the number of elements */\n\tfor(var i = 0; i <= offset; ++i) o.push(blob.read_shift(2));\n\treturn o;\n}\n\n/* 2.5.198.35 */\nfunction parse_PtgAttrGoto(blob, length) {\n\tvar bitGoto = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitGoto, blob.read_shift(2)];\n}\n\n/* 2.5.198.36 */\nfunction parse_PtgAttrIf(blob, length) {\n\tvar bitIf = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitIf, blob.read_shift(2)];\n}\n\n/* 2.5.198.37 */\nfunction parse_PtgAttrSemi(blob, length) {\n\tvar bitSemi = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 4;\n\treturn [bitSemi];\n}\n\n/* 2.5.198.40 (used by PtgAttrSpace and PtgAttrSpaceSemi) */\nfunction parse_PtgAttrSpaceType(blob, length) {\n\tvar type = blob.read_shift(1), cch = blob.read_shift(1);\n\treturn [type, cch];\n}\n\n/* 2.5.198.38 */\nfunction parse_PtgAttrSpace(blob, length) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* 2.5.198.39 */\nfunction parse_PtgAttrSpaceSemi(blob, length) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* 2.5.198.84 TODO */\nfunction parse_PtgRef(blob, length) {\n\tvar ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLoc(blob,4);\n\treturn [type, loc];\n}\n\n/* 2.5.198.88 TODO */\nfunction parse_PtgRefN(blob, length) {\n\tvar ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLocRel(blob,4);\n\treturn [type, loc];\n}\n\n/* 2.5.198.85 TODO */\nfunction parse_PtgRef3d(blob, length) {\n\tvar ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tvar loc = parse_RgceLoc(blob,4);\n\treturn [type, ixti, loc];\n}\n\n\n/* 2.5.198.62 TODO */\nfunction parse_PtgFunc(blob, length) {\n\tvar ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar iftab = blob.read_shift(2);\n\treturn [FtabArgc[iftab], Ftab[iftab]];\n}\n/* 2.5.198.63 TODO */\nfunction parse_PtgFuncVar(blob, length) {\n\tblob.l++;\n\tvar cparams = blob.read_shift(1), tab = parsetab(blob);\n\treturn [cparams, (tab[0] === 0 ? Ftab : Cetab)[tab[1]]];\n}\n\nfunction parsetab(blob, length) {\n\treturn [blob[blob.l+1]>>7, blob.read_shift(2) & 0x7FFF];\n}\n\n/* 2.5.198.41 */\nvar parse_PtgAttrSum = parseread(4);\n/* 2.5.198.43 */\nvar parse_PtgConcat = parseread1;\n\n/* 2.5.198.58 */\nfunction parse_PtgExp(blob, length) {\n\tblob.l++;\n\tvar row = blob.read_shift(2);\n\tvar col = blob.read_shift(2);\n\treturn [row, col];\n}\n\n/* 2.5.198.57 */\nfunction parse_PtgErr(blob, length) { blob.l++; return BErr[blob.read_shift(1)]; }\n\n/* 2.5.198.66 TODO */\nfunction parse_PtgInt(blob, length) { blob.l++; return blob.read_shift(2); }\n\n/* 2.5.198.42 */\nfunction parse_PtgBool(blob, length) { blob.l++; return blob.read_shift(1)!==0;}\n\n/* 2.5.198.79 */\nfunction parse_PtgNum(blob, length) { blob.l++; return parse_Xnum(blob, 8); }\n\n/* 2.5.198.89 */\nfunction parse_PtgStr(blob, length) { blob.l++; return parse_ShortXLUnicodeString(blob); }\n\n/* 2.5.192.112 + 2.5.192.11{3,4,5,6,7} */\nfunction parse_SerAr(blob) {\n\tvar val = [];\n\tswitch((val[0] = blob.read_shift(1))) {\n\t\t/* 2.5.192.113 */\n\t\tcase 0x04: /* SerBool -- boolean */\n\t\t\tval[1] = parsebool(blob, 1) ? 'TRUE' : 'FALSE';\n\t\t\tblob.l += 7; break;\n\t\t/* 2.5.192.114 */\n\t\tcase 0x10: /* SerErr -- error */\n\t\t\tval[1] = BErr[blob[blob.l]];\n\t\t\tblob.l += 8; break;\n\t\t/* 2.5.192.115 */\n\t\tcase 0x00: /* SerNil -- honestly, I'm not sure how to reproduce this */\n\t\t\tblob.l += 8; break;\n\t\t/* 2.5.192.116 */\n\t\tcase 0x01: /* SerNum -- Xnum */\n\t\t\tval[1] = parse_Xnum(blob, 8); break;\n\t\t/* 2.5.192.117 */\n\t\tcase 0x02: /* SerStr -- XLUnicodeString (<256 chars) */\n\t\t\tval[1] = parse_XLUnicodeString(blob); break;\n\t\t// default: throw \"Bad SerAr: \" + val[0]; /* Unreachable */\n\t}\n\treturn val;\n}\n\n/* 2.5.198.61 */\nfunction parse_PtgExtraMem(blob, cce) {\n\tvar count = blob.read_shift(2);\n\tvar out = [];\n\tfor(var i = 0; i != count; ++i) out.push(parse_Ref8U(blob, 8));\n\treturn out;\n}\n\n/* 2.5.198.59 */\nfunction parse_PtgExtraArray(blob) {\n\tvar cols = 1 + blob.read_shift(1); //DColByteU\n\tvar rows = 1 + blob.read_shift(2); //DRw\n\tfor(var i = 0, o=[]; i != rows && (o[i] = []); ++i)\n\t\tfor(var j = 0; j != cols; ++j) o[i][j] = parse_SerAr(blob);\n\treturn o;\n}\n\n/* 2.5.198.76 */\nfunction parse_PtgName(blob, length) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar nameindex = blob.read_shift(4);\n\treturn [type, 0, nameindex];\n}\n\n/* 2.5.198.77 */\nfunction parse_PtgNameX(blob, length) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tvar nameindex = blob.read_shift(4);\n\treturn [type, ixti, nameindex];\n}\n\n/* 2.5.198.70 */\nfunction parse_PtgMemArea(blob, length) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += 4;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\n\n/* 2.5.198.72 */\nfunction parse_PtgMemFunc(blob, length) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\n\n\n/* 2.5.198.86 */\nfunction parse_PtgRefErr(blob, length) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += 4;\n\treturn [type];\n}\n\n/* 2.5.198.26 */\nvar parse_PtgAdd = parseread1;\n/* 2.5.198.45 */\nvar parse_PtgDiv = parseread1;\n/* 2.5.198.56 */\nvar parse_PtgEq = parseread1;\n/* 2.5.198.64 */\nvar parse_PtgGe = parseread1;\n/* 2.5.198.65 */\nvar parse_PtgGt = parseread1;\n/* 2.5.198.67 */\nvar parse_PtgIsect = parseread1;\n/* 2.5.198.68 */\nvar parse_PtgLe = parseread1;\n/* 2.5.198.69 */\nvar parse_PtgLt = parseread1;\n/* 2.5.198.74 */\nvar parse_PtgMissArg = parseread1;\n/* 2.5.198.75 */\nvar parse_PtgMul = parseread1;\n/* 2.5.198.78 */\nvar parse_PtgNe = parseread1;\n/* 2.5.198.80 */\nvar parse_PtgParen = parseread1;\n/* 2.5.198.81 */\nvar parse_PtgPercent = parseread1;\n/* 2.5.198.82 */\nvar parse_PtgPower = parseread1;\n/* 2.5.198.83 */\nvar parse_PtgRange = parseread1;\n/* 2.5.198.90 */\nvar parse_PtgSub = parseread1;\n/* 2.5.198.93 */\nvar parse_PtgUminus = parseread1;\n/* 2.5.198.94 */\nvar parse_PtgUnion = parseread1;\n/* 2.5.198.95 */\nvar parse_PtgUplus = parseread1;\n\n/* 2.5.198.71 */\nvar parse_PtgMemErr = parsenoop;\n/* 2.5.198.73 */\nvar parse_PtgMemNoMem = parsenoop;\n/* 2.5.198.87 */\nvar parse_PtgRefErr3d = parsenoop;\n/* 2.5.198.92 */\nvar parse_PtgTbl = parsenoop;\n\n/* 2.5.198.25 */\nvar PtgTypes = {\n\t0x01: { n:'PtgExp', f:parse_PtgExp },\n\t0x02: { n:'PtgTbl', f:parse_PtgTbl },\n\t0x03: { n:'PtgAdd', f:parse_PtgAdd },\n\t0x04: { n:'PtgSub', f:parse_PtgSub },\n\t0x05: { n:'PtgMul', f:parse_PtgMul },\n\t0x06: { n:'PtgDiv', f:parse_PtgDiv },\n\t0x07: { n:'PtgPower', f:parse_PtgPower },\n\t0x08: { n:'PtgConcat', f:parse_PtgConcat },\n\t0x09: { n:'PtgLt', f:parse_PtgLt },\n\t0x0A: { n:'PtgLe', f:parse_PtgLe },\n\t0x0B: { n:'PtgEq', f:parse_PtgEq },\n\t0x0C: { n:'PtgGe', f:parse_PtgGe },\n\t0x0D: { n:'PtgGt', f:parse_PtgGt },\n\t0x0E: { n:'PtgNe', f:parse_PtgNe },\n\t0x0F: { n:'PtgIsect', f:parse_PtgIsect },\n\t0x10: { n:'PtgUnion', f:parse_PtgUnion },\n\t0x11: { n:'PtgRange', f:parse_PtgRange },\n\t0x12: { n:'PtgUplus', f:parse_PtgUplus },\n\t0x13: { n:'PtgUminus', f:parse_PtgUminus },\n\t0x14: { n:'PtgPercent', f:parse_PtgPercent },\n\t0x15: { n:'PtgParen', f:parse_PtgParen },\n\t0x16: { n:'PtgMissArg', f:parse_PtgMissArg },\n\t0x17: { n:'PtgStr', f:parse_PtgStr },\n\t0x1C: { n:'PtgErr', f:parse_PtgErr },\n\t0x1D: { n:'PtgBool', f:parse_PtgBool },\n\t0x1E: { n:'PtgInt', f:parse_PtgInt },\n\t0x1F: { n:'PtgNum', f:parse_PtgNum },\n\t0x20: { n:'PtgArray', f:parse_PtgArray },\n\t0x21: { n:'PtgFunc', f:parse_PtgFunc },\n\t0x22: { n:'PtgFuncVar', f:parse_PtgFuncVar },\n\t0x23: { n:'PtgName', f:parse_PtgName },\n\t0x24: { n:'PtgRef', f:parse_PtgRef },\n\t0x25: { n:'PtgArea', f:parse_PtgArea },\n\t0x26: { n:'PtgMemArea', f:parse_PtgMemArea },\n\t0x27: { n:'PtgMemErr', f:parse_PtgMemErr },\n\t0x28: { n:'PtgMemNoMem', f:parse_PtgMemNoMem },\n\t0x29: { n:'PtgMemFunc', f:parse_PtgMemFunc },\n\t0x2A: { n:'PtgRefErr', f:parse_PtgRefErr },\n\t0x2B: { n:'PtgAreaErr', f:parse_PtgAreaErr },\n\t0x2C: { n:'PtgRefN', f:parse_PtgRefN },\n\t0x2D: { n:'PtgAreaN', f:parse_PtgAreaN },\n\t0x39: { n:'PtgNameX', f:parse_PtgNameX },\n\t0x3A: { n:'PtgRef3d', f:parse_PtgRef3d },\n\t0x3B: { n:'PtgArea3d', f:parse_PtgArea3d },\n\t0x3C: { n:'PtgRefErr3d', f:parse_PtgRefErr3d },\n\t0x3D: { n:'PtgAreaErr3d', f:parse_PtgAreaErr3d },\n\t0xFF: {}\n};\n/* These are duplicated in the PtgTypes table */\nvar PtgDupes = {\n\t0x40: 0x20, 0x60: 0x20,\n\t0x41: 0x21, 0x61: 0x21,\n\t0x42: 0x22, 0x62: 0x22,\n\t0x43: 0x23, 0x63: 0x23,\n\t0x44: 0x24, 0x64: 0x24,\n\t0x45: 0x25, 0x65: 0x25,\n\t0x46: 0x26, 0x66: 0x26,\n\t0x47: 0x27, 0x67: 0x27,\n\t0x48: 0x28, 0x68: 0x28,\n\t0x49: 0x29, 0x69: 0x29,\n\t0x4A: 0x2A, 0x6A: 0x2A,\n\t0x4B: 0x2B, 0x6B: 0x2B,\n\t0x4C: 0x2C, 0x6C: 0x2C,\n\t0x4D: 0x2D, 0x6D: 0x2D,\n\t0x59: 0x39, 0x79: 0x39,\n\t0x5A: 0x3A, 0x7A: 0x3A,\n\t0x5B: 0x3B, 0x7B: 0x3B,\n\t0x5C: 0x3C, 0x7C: 0x3C,\n\t0x5D: 0x3D, 0x7D: 0x3D\n};\n(function(){for(var y in PtgDupes) PtgTypes[y] = PtgTypes[PtgDupes[y]];})();\n\nvar Ptg18 = {};\nvar Ptg19 = {\n\t0x01: { n:'PtgAttrSemi', f:parse_PtgAttrSemi },\n\t0x02: { n:'PtgAttrIf', f:parse_PtgAttrIf },\n\t0x04: { n:'PtgAttrChoose', f:parse_PtgAttrChoose },\n\t0x08: { n:'PtgAttrGoto', f:parse_PtgAttrGoto },\n\t0x10: { n:'PtgAttrSum', f:parse_PtgAttrSum },\n\t0x20: { n:'PtgAttrBaxcel', f:parse_PtgAttrBaxcel },\n\t0x40: { n:'PtgAttrSpace', f:parse_PtgAttrSpace },\n\t0x41: { n:'PtgAttrSpaceSemi', f:parse_PtgAttrSpaceSemi },\n\t0xFF: {}\n};\n\n/* 2.4.127 TODO */\nfunction parse_Formula(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar val = parse_FormulaValue(blob,8);\n\tvar flags = blob.read_shift(1);\n\tblob.read_shift(1);\n\tvar chn = blob.read_shift(4);\n\tvar cbf = \"\";\n\tif(opts.biff === 5) blob.l += length-20;\n\telse cbf = parse_XLSCellParsedFormula(blob, length-20, opts);\n\treturn {cell:cell, val:val[0], formula:cbf, shared: (flags >> 3) & 1, tt:val[1]};\n}\n\n/* 2.5.133 TODO: how to emit empty strings? */\nfunction parse_FormulaValue(blob) {\n\tvar b;\n\tif(__readUInt16LE(blob,blob.l + 6) !== 0xFFFF) return [parse_Xnum(blob),'n'];\n\tswitch(blob[blob.l]) {\n\t\tcase 0x00: blob.l += 8; return [\"String\", 's'];\n\t\tcase 0x01: b = blob[blob.l+2] === 0x1; blob.l += 8; return [b,'b'];\n\t\tcase 0x02: b = blob[blob.l+2]; blob.l += 8; return [b,'e'];\n\t\tcase 0x03: blob.l += 8; return [\"\",'s'];\n\t}\n}\n\n/* 2.5.198.103 */\nfunction parse_RgbExtra(blob, length, rgce, opts) {\n\tif(opts.biff < 8) return parsenoop(blob, length);\n\tvar target = blob.l + length;\n\tvar o = [];\n\tfor(var i = 0; i !== rgce.length; ++i) {\n\t\tswitch(rgce[i][0]) {\n\t\t\tcase 'PtgArray': /* PtgArray -> PtgExtraArray */\n\t\t\t\trgce[i][1] = parse_PtgExtraArray(blob);\n\t\t\t\to.push(rgce[i][1]);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgMemArea': /* PtgMemArea -> PtgExtraMem */\n\t\t\t\trgce[i][2] = parse_PtgExtraMem(blob, rgce[i][1]);\n\t\t\t\to.push(rgce[i][2]);\n\t\t\t\tbreak;\n\t\t\tdefault: break;\n\t\t}\n\t}\n\tlength = target - blob.l;\n\tif(length !== 0) o.push(parsenoop(blob, length));\n\treturn o;\n}\n\n/* 2.5.198.21 */\nfunction parse_NameParsedFormula(blob, length, opts, cce) {\n\tvar target = blob.l + length;\n\tvar rgce = parse_Rgce(blob, cce);\n\tvar rgcb;\n\tif(target !== blob.l) rgcb = parse_RgbExtra(blob, target - blob.l, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* 2.5.198.3 TODO */\nfunction parse_XLSCellParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar rgcb, cce = blob.read_shift(2); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce);\n\tif(length !== cce + 2) rgcb = parse_RgbExtra(blob, length - cce - 2, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* 2.5.198.118 TODO */\nfunction parse_SharedParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar rgcb, cce = blob.read_shift(2); // length of rgce\n\tvar rgce = parse_Rgce(blob, cce);\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tif(length !== cce + 2) rgcb = parse_RgbExtra(blob, target - cce - 2, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* 2.5.198.1 TODO */\nfunction parse_ArrayParsedFormula(blob, length, opts, ref) {\n\tvar target = blob.l + length;\n\tvar rgcb, cce = blob.read_shift(2); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce);\n\tif(length !== cce + 2) rgcb = parse_RgbExtra(blob, target - cce - 2, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* 2.5.198.104 */\nfunction parse_Rgce(blob, length) {\n\tvar target = blob.l + length;\n\tvar R, id, ptgs = [];\n\twhile(target != blob.l) {\n\t\tlength = target - blob.l;\n\t\tid = blob[blob.l];\n\t\tR = PtgTypes[id];\n\t\t//console.log(\"ptg\", id, R)\n\t\tif(id === 0x18 || id === 0x19) {\n\t\t\tid = blob[blob.l + 1];\n\t\t\tR = (id === 0x18 ? Ptg18 : Ptg19)[id];\n\t\t}\n\t\tif(!R || !R.f) { ptgs.push(parsenoop(blob, length)); }\n\t\telse { ptgs.push([R.n, R.f(blob, length)]); }\n\t}\n\treturn ptgs;\n}\n\nfunction mapper(x) { return x.map(function f2(y) { return y[1];}).join(\",\");}\n\n/* 2.2.2 + Magic TODO */\nfunction stringify_formula(formula, range, cell, supbooks, opts) {\n\tif(opts !== undefined && opts.biff === 5) return \"BIFF5??\";\n\tvar _range = range !== undefined ? range : {s:{c:0, r:0}};\n\tvar stack = [], e1, e2, type, c, ixti, nameidx, r;\n\tif(!formula[0] || !formula[0][0]) return \"\";\n\t//console.log(\"--\",cell,formula[0])\n\tfor(var ff = 0, fflen = formula[0].length; ff < fflen; ++ff) {\n\t\tvar f = formula[0][ff];\n\t\t//console.log(\"++\",f, stack)\n\t\tswitch(f[0]) {\n\t\t/* 2.2.2.1 Unary Operator Tokens */\n\t\t\t/* 2.5.198.93 */\n\t\t\tcase 'PtgUminus': stack.push(\"-\" + stack.pop()); break;\n\t\t\t/* 2.5.198.95 */\n\t\t\tcase 'PtgUplus': stack.push(\"+\" + stack.pop()); break;\n\t\t\t/* 2.5.198.81 */\n\t\t\tcase 'PtgPercent': stack.push(stack.pop() + \"%\"); break;\n\n\t\t/* 2.2.2.1 Binary Value Operator Token */\n\t\t\t/* 2.5.198.26 */\n\t\t\tcase 'PtgAdd':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"+\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.90 */\n\t\t\tcase 'PtgSub':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"-\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.75 */\n\t\t\tcase 'PtgMul':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"*\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.45 */\n\t\t\tcase 'PtgDiv':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"/\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.82 */\n\t\t\tcase 'PtgPower':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"^\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.43 */\n\t\t\tcase 'PtgConcat':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"&\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.69 */\n\t\t\tcase 'PtgLt':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"<\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.68 */\n\t\t\tcase 'PtgLe':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"<=\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.56 */\n\t\t\tcase 'PtgEq':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"=\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.64 */\n\t\t\tcase 'PtgGe':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\">=\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.65 */\n\t\t\tcase 'PtgGt':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\">\"+e1);\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.78 */\n\t\t\tcase 'PtgNe':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\"<>\"+e1);\n\t\t\t\tbreak;\n\n\t\t/* 2.2.2.1 Binary Reference Operator Token */\n\t\t\t/* 2.5.198.67 */\n\t\t\tcase 'PtgIsect':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\" \"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgUnion':\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\",\"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRange': break;\n\n\t\t/* 2.2.2.3 Control Tokens \"can be ignored\" */\n\t\t\t/* 2.5.198.34 */\n\t\t\tcase 'PtgAttrChoose': break;\n\t\t\t/* 2.5.198.35 */\n\t\t\tcase 'PtgAttrGoto': break;\n\t\t\t/* 2.5.198.36 */\n\t\t\tcase 'PtgAttrIf': break;\n\n\n\t\t\t/* 2.5.198.84 */\n\t\t\tcase 'PtgRef':\n\t\t\t\ttype = f[1][0]; c = shift_cell_xls(decode_cell(encode_cell(f[1][1])), _range);\n\t\t\t\tstack.push(encode_cell(c));\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.88 */\n\t\t\tcase 'PtgRefN':\n\t\t\t\ttype = f[1][0]; c = shift_cell_xls(decode_cell(encode_cell(f[1][1])), cell);\n\t\t\t\tstack.push(encode_cell(c));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRef3d': // TODO: lots of stuff\n\t\t\t\ttype = f[1][0]; ixti = f[1][1]; c = shift_cell_xls(f[1][2], _range);\n\t\t\t\tstack.push(supbooks[1][ixti+1]+\"!\"+encode_cell(c));\n\t\t\t\tbreak;\n\n\t\t/* Function Call */\n\t\t\t/* 2.5.198.62 */\n\t\t\tcase 'PtgFunc':\n\t\t\t/* 2.5.198.63 */\n\t\t\tcase 'PtgFuncVar':\n\t\t\t\t/* f[1] = [argc, func] */\n\t\t\t\tvar argc = f[1][0], func = f[1][1];\n\t\t\t\tif(!argc) argc = 0;\n\t\t\t\tvar args = stack.slice(-argc);\n\t\t\t\tstack.length -= argc;\n\t\t\t\tif(func === 'User') func = args.shift();\n\t\t\t\tstack.push(func + \"(\" + args.join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\t/* 2.5.198.42 */\n\t\t\tcase 'PtgBool': stack.push(f[1] ? \"TRUE\" : \"FALSE\"); break;\n\t\t\t/* 2.5.198.66 */\n\t\t\tcase 'PtgInt': stack.push(f[1]); break;\n\t\t\t/* 2.5.198.79 TODO: precision? */\n\t\t\tcase 'PtgNum': stack.push(String(f[1])); break;\n\t\t\t/* 2.5.198.89 */\n\t\t\tcase 'PtgStr': stack.push('\"' + f[1] + '\"'); break;\n\t\t\t/* 2.5.198.57 */\n\t\t\tcase 'PtgErr': stack.push(f[1]); break;\n\t\t\t/* 2.5.198.27 TODO: fixed points */\n\t\t\tcase 'PtgArea':\n\t\t\t\ttype = f[1][0]; r = shift_range_xls(f[1][1], _range);\n\t\t\t\tstack.push(encode_range(r));\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.28 */\n\t\t\tcase 'PtgArea3d': // TODO: lots of stuff\n\t\t\t\ttype = f[1][0]; ixti = f[1][1]; r = f[1][2];\n\t\t\t\tstack.push(supbooks[1][ixti+1]+\"!\"+encode_range(r));\n\t\t\t\tbreak;\n\t\t\t/* 2.5.198.41 */\n\t\t\tcase 'PtgAttrSum':\n\t\t\t\tstack.push(\"SUM(\" + stack.pop() + \")\");\n\t\t\t\tbreak;\n\n\t\t/* Expression Prefixes */\n\t\t\t/* 2.5.198.37 */\n\t\t\tcase 'PtgAttrSemi': break;\n\n\t\t\t/* 2.5.97.60 TODO: do something different for revisions */\n\t\t\tcase 'PtgName':\n\t\t\t\t/* f[1] = type, 0, nameindex */\n\t\t\t\tnameidx = f[1][2];\n\t\t\t\tvar lbl = supbooks[0][nameidx];\n\t\t\t\tvar name = lbl.Name;\n\t\t\t\tif(name in XLSXFutureFunctions) name = XLSXFutureFunctions[name];\n\t\t\t\tstack.push(name);\n\t\t\t\tbreak;\n\n\t\t\t/* 2.5.97.61 TODO: do something different for revisions */\n\t\t\tcase 'PtgNameX':\n\t\t\t\t/* f[1] = type, ixti, nameindex */\n\t\t\t\tvar bookidx = f[1][1]; nameidx = f[1][2]; var externbook;\n\t\t\t\t/* TODO: Properly handle missing values */\n\t\t\t\tif(supbooks[bookidx+1]) externbook = supbooks[bookidx+1][nameidx];\n\t\t\t\telse if(supbooks[bookidx-1]) externbook = supbooks[bookidx-1][nameidx];\n\t\t\t\tif(!externbook) externbook = {body: \"??NAMEX??\"};\n\t\t\t\tstack.push(externbook.body);\n\t\t\t\tbreak;\n\n\t\t/* 2.2.2.4 Display Tokens */\n\t\t\t/* 2.5.198.80 */\n\t\t\tcase 'PtgParen': stack.push('(' + stack.pop() + ')'); break;\n\n\t\t\t/* 2.5.198.86 */\n\t\t\tcase 'PtgRefErr': stack.push('#REF!'); break;\n\n\t\t/* */\n\t\t\t/* 2.5.198.58 TODO */\n\t\t\tcase 'PtgExp':\n\t\t\t\tc = {c:f[1][1],r:f[1][0]};\n\t\t\t\tvar q = {c: cell.c, r:cell.r};\n\t\t\t\tif(supbooks.sharedf[encode_cell(c)]) {\n\t\t\t\t\tvar parsedf = (supbooks.sharedf[encode_cell(c)]);\n\t\t\t\t\tstack.push(stringify_formula(parsedf, _range, q, supbooks, opts));\n\t\t\t\t}\n\t\t\t\telse {\n\t\t\t\t\tvar fnd = false;\n\t\t\t\t\tfor(e1=0;e1!=supbooks.arrayf.length; ++e1) {\n\t\t\t\t\t\t/* TODO: should be something like range_has */\n\t\t\t\t\t\te2 = supbooks.arrayf[e1];\n\t\t\t\t\t\tif(c.c < e2[0].s.c || c.c > e2[0].e.c) continue;\n\t\t\t\t\t\tif(c.r < e2[0].s.r || c.r > e2[0].e.r) continue;\n\t\t\t\t\t\tstack.push(stringify_formula(e2[1], _range, q, supbooks, opts));\n\t\t\t\t\t}\n\t\t\t\t\tif(!fnd) stack.push(f[1]);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\t/* 2.5.198.32 TODO */\n\t\t\tcase 'PtgArray':\n\t\t\t\tstack.push(\"{\" + f[1].map(mapper).join(\";\") + \"}\");\n\t\t\t\tbreak;\n\n\t\t/* 2.2.2.5 Mem Tokens */\n\t\t\t/* 2.5.198.70 TODO: confirm this is a non-display */\n\t\t\tcase 'PtgMemArea':\n\t\t\t\t//stack.push(\"(\" + f[2].map(encode_range).join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\t/* 2.5.198.38 TODO */\n\t\t\tcase 'PtgAttrSpace': break;\n\n\t\t\t/* 2.5.198.92 TODO */\n\t\t\tcase 'PtgTbl': break;\n\n\t\t\t/* 2.5.198.71 */\n\t\t\tcase 'PtgMemErr': break;\n\n\t\t\t/* 2.5.198.74 */\n\t\t\tcase 'PtgMissArg':\n\t\t\t\tstack.push(\"\");\n\t\t\t\tbreak;\n\n\t\t\t/* 2.5.198.29 TODO */\n\t\t\tcase 'PtgAreaErr': break;\n\n\t\t\t/* 2.5.198.31 TODO */\n\t\t\tcase 'PtgAreaN': stack.push(\"\"); break;\n\n\t\t\t/* 2.5.198.87 TODO */\n\t\t\tcase 'PtgRefErr3d': break;\n\n\t\t\t/* 2.5.198.72 TODO */\n\t\t\tcase 'PtgMemFunc': break;\n\n\t\t\tdefault: throw 'Unrecognized Formula Token: ' + f;\n\t\t}\n\t\t//console.log(\"::\",f, stack)\n\t}\n\t//console.log(\"--\",stack);\n\treturn stack[0];\n}\n\n/* [MS-XLSB] 2.5.97.4 CellParsedFormula TODO: use similar logic to js-xls */\nfunction parse_XLSBCellParsedFormula(data, length) {\n\tvar cce = data.read_shift(4);\n\treturn parsenoop(data, length-4);\n}\n/* [MS-XLS] 2.5.198.44 */\nvar PtgDataType = {\n\t0x1: \"REFERENCE\", // reference to range\n\t0x2: \"VALUE\", // single value\n\t0x3: \"ARRAY\" // array of values\n};\n\n/* [MS-XLS] 2.5.198.4 */\nvar Cetab = {\n\t0x0000: 'BEEP',\n\t0x0001: 'OPEN',\n\t0x0002: 'OPEN.LINKS',\n\t0x0003: 'CLOSE.ALL',\n\t0x0004: 'SAVE',\n\t0x0005: 'SAVE.AS',\n\t0x0006: 'FILE.DELETE',\n\t0x0007: 'PAGE.SETUP',\n\t0x0008: 'PRINT',\n\t0x0009: 'PRINTER.SETUP',\n\t0x000A: 'QUIT',\n\t0x000B: 'NEW.WINDOW',\n\t0x000C: 'ARRANGE.ALL',\n\t0x000D: 'WINDOW.SIZE',\n\t0x000E: 'WINDOW.MOVE',\n\t0x000F: 'FULL',\n\t0x0010: 'CLOSE',\n\t0x0011: 'RUN',\n\t0x0016: 'SET.PRINT.AREA',\n\t0x0017: 'SET.PRINT.TITLES',\n\t0x0018: 'SET.PAGE.BREAK',\n\t0x0019: 'REMOVE.PAGE.BREAK',\n\t0x001A: 'FONT',\n\t0x001B: 'DISPLAY',\n\t0x001C: 'PROTECT.DOCUMENT',\n\t0x001D: 'PRECISION',\n\t0x001E: 'A1.R1C1',\n\t0x001F: 'CALCULATE.NOW',\n\t0x0020: 'CALCULATION',\n\t0x0022: 'DATA.FIND',\n\t0x0023: 'EXTRACT',\n\t0x0024: 'DATA.DELETE',\n\t0x0025: 'SET.DATABASE',\n\t0x0026: 'SET.CRITERIA',\n\t0x0027: 'SORT',\n\t0x0028: 'DATA.SERIES',\n\t0x0029: 'TABLE',\n\t0x002A: 'FORMAT.NUMBER',\n\t0x002B: 'ALIGNMENT',\n\t0x002C: 'STYLE',\n\t0x002D: 'BORDER',\n\t0x002E: 'CELL.PROTECTION',\n\t0x002F: 'COLUMN.WIDTH',\n\t0x0030: 'UNDO',\n\t0x0031: 'CUT',\n\t0x0032: 'COPY',\n\t0x0033: 'PASTE',\n\t0x0034: 'CLEAR',\n\t0x0035: 'PASTE.SPECIAL',\n\t0x0036: 'EDIT.DELETE',\n\t0x0037: 'INSERT',\n\t0x0038: 'FILL.RIGHT',\n\t0x0039: 'FILL.DOWN',\n\t0x003D: 'DEFINE.NAME',\n\t0x003E: 'CREATE.NAMES',\n\t0x003F: 'FORMULA.GOTO',\n\t0x0040: 'FORMULA.FIND',\n\t0x0041: 'SELECT.LAST.CELL',\n\t0x0042: 'SHOW.ACTIVE.CELL',\n\t0x0043: 'GALLERY.AREA',\n\t0x0044: 'GALLERY.BAR',\n\t0x0045: 'GALLERY.COLUMN',\n\t0x0046: 'GALLERY.LINE',\n\t0x0047: 'GALLERY.PIE',\n\t0x0048: 'GALLERY.SCATTER',\n\t0x0049: 'COMBINATION',\n\t0x004A: 'PREFERRED',\n\t0x004B: 'ADD.OVERLAY',\n\t0x004C: 'GRIDLINES',\n\t0x004D: 'SET.PREFERRED',\n\t0x004E: 'AXES',\n\t0x004F: 'LEGEND',\n\t0x0050: 'ATTACH.TEXT',\n\t0x0051: 'ADD.ARROW',\n\t0x0052: 'SELECT.CHART',\n\t0x0053: 'SELECT.PLOT.AREA',\n\t0x0054: 'PATTERNS',\n\t0x0055: 'MAIN.CHART',\n\t0x0056: 'OVERLAY',\n\t0x0057: 'SCALE',\n\t0x0058: 'FORMAT.LEGEND',\n\t0x0059: 'FORMAT.TEXT',\n\t0x005A: 'EDIT.REPEAT',\n\t0x005B: 'PARSE',\n\t0x005C: 'JUSTIFY',\n\t0x005D: 'HIDE',\n\t0x005E: 'UNHIDE',\n\t0x005F: 'WORKSPACE',\n\t0x0060: 'FORMULA',\n\t0x0061: 'FORMULA.FILL',\n\t0x0062: 'FORMULA.ARRAY',\n\t0x0063: 'DATA.FIND.NEXT',\n\t0x0064: 'DATA.FIND.PREV',\n\t0x0065: 'FORMULA.FIND.NEXT',\n\t0x0066: 'FORMULA.FIND.PREV',\n\t0x0067: 'ACTIVATE',\n\t0x0068: 'ACTIVATE.NEXT',\n\t0x0069: 'ACTIVATE.PREV',\n\t0x006A: 'UNLOCKED.NEXT',\n\t0x006B: 'UNLOCKED.PREV',\n\t0x006C: 'COPY.PICTURE',\n\t0x006D: 'SELECT',\n\t0x006E: 'DELETE.NAME',\n\t0x006F: 'DELETE.FORMAT',\n\t0x0070: 'VLINE',\n\t0x0071: 'HLINE',\n\t0x0072: 'VPAGE',\n\t0x0073: 'HPAGE',\n\t0x0074: 'VSCROLL',\n\t0x0075: 'HSCROLL',\n\t0x0076: 'ALERT',\n\t0x0077: 'NEW',\n\t0x0078: 'CANCEL.COPY',\n\t0x0079: 'SHOW.CLIPBOARD',\n\t0x007A: 'MESSAGE',\n\t0x007C: 'PASTE.LINK',\n\t0x007D: 'APP.ACTIVATE',\n\t0x007E: 'DELETE.ARROW',\n\t0x007F: 'ROW.HEIGHT',\n\t0x0080: 'FORMAT.MOVE',\n\t0x0081: 'FORMAT.SIZE',\n\t0x0082: 'FORMULA.REPLACE',\n\t0x0083: 'SEND.KEYS',\n\t0x0084: 'SELECT.SPECIAL',\n\t0x0085: 'APPLY.NAMES',\n\t0x0086: 'REPLACE.FONT',\n\t0x0087: 'FREEZE.PANES',\n\t0x0088: 'SHOW.INFO',\n\t0x0089: 'SPLIT',\n\t0x008A: 'ON.WINDOW',\n\t0x008B: 'ON.DATA',\n\t0x008C: 'DISABLE.INPUT',\n\t0x008E: 'OUTLINE',\n\t0x008F: 'LIST.NAMES',\n\t0x0090: 'FILE.CLOSE',\n\t0x0091: 'SAVE.WORKBOOK',\n\t0x0092: 'DATA.FORM',\n\t0x0093: 'COPY.CHART',\n\t0x0094: 'ON.TIME',\n\t0x0095: 'WAIT',\n\t0x0096: 'FORMAT.FONT',\n\t0x0097: 'FILL.UP',\n\t0x0098: 'FILL.LEFT',\n\t0x0099: 'DELETE.OVERLAY',\n\t0x009B: 'SHORT.MENUS',\n\t0x009F: 'SET.UPDATE.STATUS',\n\t0x00A1: 'COLOR.PALETTE',\n\t0x00A2: 'DELETE.STYLE',\n\t0x00A3: 'WINDOW.RESTORE',\n\t0x00A4: 'WINDOW.MAXIMIZE',\n\t0x00A6: 'CHANGE.LINK',\n\t0x00A7: 'CALCULATE.DOCUMENT',\n\t0x00A8: 'ON.KEY',\n\t0x00A9: 'APP.RESTORE',\n\t0x00AA: 'APP.MOVE',\n\t0x00AB: 'APP.SIZE',\n\t0x00AC: 'APP.MINIMIZE',\n\t0x00AD: 'APP.MAXIMIZE',\n\t0x00AE: 'BRING.TO.FRONT',\n\t0x00AF: 'SEND.TO.BACK',\n\t0x00B9: 'MAIN.CHART.TYPE',\n\t0x00BA: 'OVERLAY.CHART.TYPE',\n\t0x00BB: 'SELECT.END',\n\t0x00BC: 'OPEN.MAIL',\n\t0x00BD: 'SEND.MAIL',\n\t0x00BE: 'STANDARD.FONT',\n\t0x00BF: 'CONSOLIDATE',\n\t0x00C0: 'SORT.SPECIAL',\n\t0x00C1: 'GALLERY.3D.AREA',\n\t0x00C2: 'GALLERY.3D.COLUMN',\n\t0x00C3: 'GALLERY.3D.LINE',\n\t0x00C4: 'GALLERY.3D.PIE',\n\t0x00C5: 'VIEW.3D',\n\t0x00C6: 'GOAL.SEEK',\n\t0x00C7: 'WORKGROUP',\n\t0x00C8: 'FILL.GROUP',\n\t0x00C9: 'UPDATE.LINK',\n\t0x00CA: 'PROMOTE',\n\t0x00CB: 'DEMOTE',\n\t0x00CC: 'SHOW.DETAIL',\n\t0x00CE: 'UNGROUP',\n\t0x00CF: 'OBJECT.PROPERTIES',\n\t0x00D0: 'SAVE.NEW.OBJECT',\n\t0x00D1: 'SHARE',\n\t0x00D2: 'SHARE.NAME',\n\t0x00D3: 'DUPLICATE',\n\t0x00D4: 'APPLY.STYLE',\n\t0x00D5: 'ASSIGN.TO.OBJECT',\n\t0x00D6: 'OBJECT.PROTECTION',\n\t0x00D7: 'HIDE.OBJECT',\n\t0x00D8: 'SET.EXTRACT',\n\t0x00D9: 'CREATE.PUBLISHER',\n\t0x00DA: 'SUBSCRIBE.TO',\n\t0x00DB: 'ATTRIBUTES',\n\t0x00DC: 'SHOW.TOOLBAR',\n\t0x00DE: 'PRINT.PREVIEW',\n\t0x00DF: 'EDIT.COLOR',\n\t0x00E0: 'SHOW.LEVELS',\n\t0x00E1: 'FORMAT.MAIN',\n\t0x00E2: 'FORMAT.OVERLAY',\n\t0x00E3: 'ON.RECALC',\n\t0x00E4: 'EDIT.SERIES',\n\t0x00E5: 'DEFINE.STYLE',\n\t0x00F0: 'LINE.PRINT',\n\t0x00F3: 'ENTER.DATA',\n\t0x00F9: 'GALLERY.RADAR',\n\t0x00FA: 'MERGE.STYLES',\n\t0x00FB: 'EDITION.OPTIONS',\n\t0x00FC: 'PASTE.PICTURE',\n\t0x00FD: 'PASTE.PICTURE.LINK',\n\t0x00FE: 'SPELLING',\n\t0x0100: 'ZOOM',\n\t0x0103: 'INSERT.OBJECT',\n\t0x0104: 'WINDOW.MINIMIZE',\n\t0x0109: 'SOUND.NOTE',\n\t0x010A: 'SOUND.PLAY',\n\t0x010B: 'FORMAT.SHAPE',\n\t0x010C: 'EXTEND.POLYGON',\n\t0x010D: 'FORMAT.AUTO',\n\t0x0110: 'GALLERY.3D.BAR',\n\t0x0111: 'GALLERY.3D.SURFACE',\n\t0x0112: 'FILL.AUTO',\n\t0x0114: 'CUSTOMIZE.TOOLBAR',\n\t0x0115: 'ADD.TOOL',\n\t0x0116: 'EDIT.OBJECT',\n\t0x0117: 'ON.DOUBLECLICK',\n\t0x0118: 'ON.ENTRY',\n\t0x0119: 'WORKBOOK.ADD',\n\t0x011A: 'WORKBOOK.MOVE',\n\t0x011B: 'WORKBOOK.COPY',\n\t0x011C: 'WORKBOOK.OPTIONS',\n\t0x011D: 'SAVE.WORKSPACE',\n\t0x0120: 'CHART.WIZARD',\n\t0x0121: 'DELETE.TOOL',\n\t0x0122: 'MOVE.TOOL',\n\t0x0123: 'WORKBOOK.SELECT',\n\t0x0124: 'WORKBOOK.ACTIVATE',\n\t0x0125: 'ASSIGN.TO.TOOL',\n\t0x0127: 'COPY.TOOL',\n\t0x0128: 'RESET.TOOL',\n\t0x0129: 'CONSTRAIN.NUMERIC',\n\t0x012A: 'PASTE.TOOL',\n\t0x012E: 'WORKBOOK.NEW',\n\t0x0131: 'SCENARIO.CELLS',\n\t0x0132: 'SCENARIO.DELETE',\n\t0x0133: 'SCENARIO.ADD',\n\t0x0134: 'SCENARIO.EDIT',\n\t0x0135: 'SCENARIO.SHOW',\n\t0x0136: 'SCENARIO.SHOW.NEXT',\n\t0x0137: 'SCENARIO.SUMMARY',\n\t0x0138: 'PIVOT.TABLE.WIZARD',\n\t0x0139: 'PIVOT.FIELD.PROPERTIES',\n\t0x013A: 'PIVOT.FIELD',\n\t0x013B: 'PIVOT.ITEM',\n\t0x013C: 'PIVOT.ADD.FIELDS',\n\t0x013E: 'OPTIONS.CALCULATION',\n\t0x013F: 'OPTIONS.EDIT',\n\t0x0140: 'OPTIONS.VIEW',\n\t0x0141: 'ADDIN.MANAGER',\n\t0x0142: 'MENU.EDITOR',\n\t0x0143: 'ATTACH.TOOLBARS',\n\t0x0144: 'VBAActivate',\n\t0x0145: 'OPTIONS.CHART',\n\t0x0148: 'VBA.INSERT.FILE',\n\t0x014A: 'VBA.PROCEDURE.DEFINITION',\n\t0x0150: 'ROUTING.SLIP',\n\t0x0152: 'ROUTE.DOCUMENT',\n\t0x0153: 'MAIL.LOGON',\n\t0x0156: 'INSERT.PICTURE',\n\t0x0157: 'EDIT.TOOL',\n\t0x0158: 'GALLERY.DOUGHNUT',\n\t0x015E: 'CHART.TREND',\n\t0x0160: 'PIVOT.ITEM.PROPERTIES',\n\t0x0162: 'WORKBOOK.INSERT',\n\t0x0163: 'OPTIONS.TRANSITION',\n\t0x0164: 'OPTIONS.GENERAL',\n\t0x0172: 'FILTER.ADVANCED',\n\t0x0175: 'MAIL.ADD.MAILER',\n\t0x0176: 'MAIL.DELETE.MAILER',\n\t0x0177: 'MAIL.REPLY',\n\t0x0178: 'MAIL.REPLY.ALL',\n\t0x0179: 'MAIL.FORWARD',\n\t0x017A: 'MAIL.NEXT.LETTER',\n\t0x017B: 'DATA.LABEL',\n\t0x017C: 'INSERT.TITLE',\n\t0x017D: 'FONT.PROPERTIES',\n\t0x017E: 'MACRO.OPTIONS',\n\t0x017F: 'WORKBOOK.HIDE',\n\t0x0180: 'WORKBOOK.UNHIDE',\n\t0x0181: 'WORKBOOK.DELETE',\n\t0x0182: 'WORKBOOK.NAME',\n\t0x0184: 'GALLERY.CUSTOM',\n\t0x0186: 'ADD.CHART.AUTOFORMAT',\n\t0x0187: 'DELETE.CHART.AUTOFORMAT',\n\t0x0188: 'CHART.ADD.DATA',\n\t0x0189: 'AUTO.OUTLINE',\n\t0x018A: 'TAB.ORDER',\n\t0x018B: 'SHOW.DIALOG',\n\t0x018C: 'SELECT.ALL',\n\t0x018D: 'UNGROUP.SHEETS',\n\t0x018E: 'SUBTOTAL.CREATE',\n\t0x018F: 'SUBTOTAL.REMOVE',\n\t0x0190: 'RENAME.OBJECT',\n\t0x019C: 'WORKBOOK.SCROLL',\n\t0x019D: 'WORKBOOK.NEXT',\n\t0x019E: 'WORKBOOK.PREV',\n\t0x019F: 'WORKBOOK.TAB.SPLIT',\n\t0x01A0: 'FULL.SCREEN',\n\t0x01A1: 'WORKBOOK.PROTECT',\n\t0x01A4: 'SCROLLBAR.PROPERTIES',\n\t0x01A5: 'PIVOT.SHOW.PAGES',\n\t0x01A6: 'TEXT.TO.COLUMNS',\n\t0x01A7: 'FORMAT.CHARTTYPE',\n\t0x01A8: 'LINK.FORMAT',\n\t0x01A9: 'TRACER.DISPLAY',\n\t0x01AE: 'TRACER.NAVIGATE',\n\t0x01AF: 'TRACER.CLEAR',\n\t0x01B0: 'TRACER.ERROR',\n\t0x01B1: 'PIVOT.FIELD.GROUP',\n\t0x01B2: 'PIVOT.FIELD.UNGROUP',\n\t0x01B3: 'CHECKBOX.PROPERTIES',\n\t0x01B4: 'LABEL.PROPERTIES',\n\t0x01B5: 'LISTBOX.PROPERTIES',\n\t0x01B6: 'EDITBOX.PROPERTIES',\n\t0x01B7: 'PIVOT.REFRESH',\n\t0x01B8: 'LINK.COMBO',\n\t0x01B9: 'OPEN.TEXT',\n\t0x01BA: 'HIDE.DIALOG',\n\t0x01BB: 'SET.DIALOG.FOCUS',\n\t0x01BC: 'ENABLE.OBJECT',\n\t0x01BD: 'PUSHBUTTON.PROPERTIES',\n\t0x01BE: 'SET.DIALOG.DEFAULT',\n\t0x01BF: 'FILTER',\n\t0x01C0: 'FILTER.SHOW.ALL',\n\t0x01C1: 'CLEAR.OUTLINE',\n\t0x01C2: 'FUNCTION.WIZARD',\n\t0x01C3: 'ADD.LIST.ITEM',\n\t0x01C4: 'SET.LIST.ITEM',\n\t0x01C5: 'REMOVE.LIST.ITEM',\n\t0x01C6: 'SELECT.LIST.ITEM',\n\t0x01C7: 'SET.CONTROL.VALUE',\n\t0x01C8: 'SAVE.COPY.AS',\n\t0x01CA: 'OPTIONS.LISTS.ADD',\n\t0x01CB: 'OPTIONS.LISTS.DELETE',\n\t0x01CC: 'SERIES.AXES',\n\t0x01CD: 'SERIES.X',\n\t0x01CE: 'SERIES.Y',\n\t0x01CF: 'ERRORBAR.X',\n\t0x01D0: 'ERRORBAR.Y',\n\t0x01D1: 'FORMAT.CHART',\n\t0x01D2: 'SERIES.ORDER',\n\t0x01D3: 'MAIL.LOGOFF',\n\t0x01D4: 'CLEAR.ROUTING.SLIP',\n\t0x01D5: 'APP.ACTIVATE.MICROSOFT',\n\t0x01D6: 'MAIL.EDIT.MAILER',\n\t0x01D7: 'ON.SHEET',\n\t0x01D8: 'STANDARD.WIDTH',\n\t0x01D9: 'SCENARIO.MERGE',\n\t0x01DA: 'SUMMARY.INFO',\n\t0x01DB: 'FIND.FILE',\n\t0x01DC: 'ACTIVE.CELL.FONT',\n\t0x01DD: 'ENABLE.TIPWIZARD',\n\t0x01DE: 'VBA.MAKE.ADDIN',\n\t0x01E0: 'INSERTDATATABLE',\n\t0x01E1: 'WORKGROUP.OPTIONS',\n\t0x01E2: 'MAIL.SEND.MAILER',\n\t0x01E5: 'AUTOCORRECT',\n\t0x01E9: 'POST.DOCUMENT',\n\t0x01EB: 'PICKLIST',\n\t0x01ED: 'VIEW.SHOW',\n\t0x01EE: 'VIEW.DEFINE',\n\t0x01EF: 'VIEW.DELETE',\n\t0x01FD: 'SHEET.BACKGROUND',\n\t0x01FE: 'INSERT.MAP.OBJECT',\n\t0x01FF: 'OPTIONS.MENONO',\n\t0x0205: 'MSOCHECKS',\n\t0x0206: 'NORMAL',\n\t0x0207: 'LAYOUT',\n\t0x0208: 'RM.PRINT.AREA',\n\t0x0209: 'CLEAR.PRINT.AREA',\n\t0x020A: 'ADD.PRINT.AREA',\n\t0x020B: 'MOVE.BRK',\n\t0x0221: 'HIDECURR.NOTE',\n\t0x0222: 'HIDEALL.NOTES',\n\t0x0223: 'DELETE.NOTE',\n\t0x0224: 'TRAVERSE.NOTES',\n\t0x0225: 'ACTIVATE.NOTES',\n\t0x026C: 'PROTECT.REVISIONS',\n\t0x026D: 'UNPROTECT.REVISIONS',\n\t0x0287: 'OPTIONS.ME',\n\t0x028D: 'WEB.PUBLISH',\n\t0x029B: 'NEWWEBQUERY',\n\t0x02A1: 'PIVOT.TABLE.CHART',\n\t0x02F1: 'OPTIONS.SAVE',\n\t0x02F3: 'OPTIONS.SPELL',\n\t0x0328: 'HIDEALL.INKANNOTS'\n};\n\n/* [MS-XLS] 2.5.198.17 */\nvar Ftab = {\n\t0x0000: 'COUNT',\n\t0x0001: 'IF',\n\t0x0002: 'ISNA',\n\t0x0003: 'ISERROR',\n\t0x0004: 'SUM',\n\t0x0005: 'AVERAGE',\n\t0x0006: 'MIN',\n\t0x0007: 'MAX',\n\t0x0008: 'ROW',\n\t0x0009: 'COLUMN',\n\t0x000A: 'NA',\n\t0x000B: 'NPV',\n\t0x000C: 'STDEV',\n\t0x000D: 'DOLLAR',\n\t0x000E: 'FIXED',\n\t0x000F: 'SIN',\n\t0x0010: 'COS',\n\t0x0011: 'TAN',\n\t0x0012: 'ATAN',\n\t0x0013: 'PI',\n\t0x0014: 'SQRT',\n\t0x0015: 'EXP',\n\t0x0016: 'LN',\n\t0x0017: 'LOG10',\n\t0x0018: 'ABS',\n\t0x0019: 'INT',\n\t0x001A: 'SIGN',\n\t0x001B: 'ROUND',\n\t0x001C: 'LOOKUP',\n\t0x001D: 'INDEX',\n\t0x001E: 'REPT',\n\t0x001F: 'MID',\n\t0x0020: 'LEN',\n\t0x0021: 'VALUE',\n\t0x0022: 'TRUE',\n\t0x0023: 'FALSE',\n\t0x0024: 'AND',\n\t0x0025: 'OR',\n\t0x0026: 'NOT',\n\t0x0027: 'MOD',\n\t0x0028: 'DCOUNT',\n\t0x0029: 'DSUM',\n\t0x002A: 'DAVERAGE',\n\t0x002B: 'DMIN',\n\t0x002C: 'DMAX',\n\t0x002D: 'DSTDEV',\n\t0x002E: 'VAR',\n\t0x002F: 'DVAR',\n\t0x0030: 'TEXT',\n\t0x0031: 'LINEST',\n\t0x0032: 'TREND',\n\t0x0033: 'LOGEST',\n\t0x0034: 'GROWTH',\n\t0x0035: 'GOTO',\n\t0x0036: 'HALT',\n\t0x0037: 'RETURN',\n\t0x0038: 'PV',\n\t0x0039: 'FV',\n\t0x003A: 'NPER',\n\t0x003B: 'PMT',\n\t0x003C: 'RATE',\n\t0x003D: 'MIRR',\n\t0x003E: 'IRR',\n\t0x003F: 'RAND',\n\t0x0040: 'MATCH',\n\t0x0041: 'DATE',\n\t0x0042: 'TIME',\n\t0x0043: 'DAY',\n\t0x0044: 'MONTH',\n\t0x0045: 'YEAR',\n\t0x0046: 'WEEKDAY',\n\t0x0047: 'HOUR',\n\t0x0048: 'MINUTE',\n\t0x0049: 'SECOND',\n\t0x004A: 'NOW',\n\t0x004B: 'AREAS',\n\t0x004C: 'ROWS',\n\t0x004D: 'COLUMNS',\n\t0x004E: 'OFFSET',\n\t0x004F: 'ABSREF',\n\t0x0050: 'RELREF',\n\t0x0051: 'ARGUMENT',\n\t0x0052: 'SEARCH',\n\t0x0053: 'TRANSPOSE',\n\t0x0054: 'ERROR',\n\t0x0055: 'STEP',\n\t0x0056: 'TYPE',\n\t0x0057: 'ECHO',\n\t0x0058: 'SET.NAME',\n\t0x0059: 'CALLER',\n\t0x005A: 'DEREF',\n\t0x005B: 'WINDOWS',\n\t0x005C: 'SERIES',\n\t0x005D: 'DOCUMENTS',\n\t0x005E: 'ACTIVE.CELL',\n\t0x005F: 'SELECTION',\n\t0x0060: 'RESULT',\n\t0x0061: 'ATAN2',\n\t0x0062: 'ASIN',\n\t0x0063: 'ACOS',\n\t0x0064: 'CHOOSE',\n\t0x0065: 'HLOOKUP',\n\t0x0066: 'VLOOKUP',\n\t0x0067: 'LINKS',\n\t0x0068: 'INPUT',\n\t0x0069: 'ISREF',\n\t0x006A: 'GET.FORMULA',\n\t0x006B: 'GET.NAME',\n\t0x006C: 'SET.VALUE',\n\t0x006D: 'LOG',\n\t0x006E: 'EXEC',\n\t0x006F: 'CHAR',\n\t0x0070: 'LOWER',\n\t0x0071: 'UPPER',\n\t0x0072: 'PROPER',\n\t0x0073: 'LEFT',\n\t0x0074: 'RIGHT',\n\t0x0075: 'EXACT',\n\t0x0076: 'TRIM',\n\t0x0077: 'REPLACE',\n\t0x0078: 'SUBSTITUTE',\n\t0x0079: 'CODE',\n\t0x007A: 'NAMES',\n\t0x007B: 'DIRECTORY',\n\t0x007C: 'FIND',\n\t0x007D: 'CELL',\n\t0x007E: 'ISERR',\n\t0x007F: 'ISTEXT',\n\t0x0080: 'ISNUMBER',\n\t0x0081: 'ISBLANK',\n\t0x0082: 'T',\n\t0x0083: 'N',\n\t0x0084: 'FOPEN',\n\t0x0085: 'FCLOSE',\n\t0x0086: 'FSIZE',\n\t0x0087: 'FREADLN',\n\t0x0088: 'FREAD',\n\t0x0089: 'FWRITELN',\n\t0x008A: 'FWRITE',\n\t0x008B: 'FPOS',\n\t0x008C: 'DATEVALUE',\n\t0x008D: 'TIMEVALUE',\n\t0x008E: 'SLN',\n\t0x008F: 'SYD',\n\t0x0090: 'DDB',\n\t0x0091: 'GET.DEF',\n\t0x0092: 'REFTEXT',\n\t0x0093: 'TEXTREF',\n\t0x0094: 'INDIRECT',\n\t0x0095: 'REGISTER',\n\t0x0096: 'CALL',\n\t0x0097: 'ADD.BAR',\n\t0x0098: 'ADD.MENU',\n\t0x0099: 'ADD.COMMAND',\n\t0x009A: 'ENABLE.COMMAND',\n\t0x009B: 'CHECK.COMMAND',\n\t0x009C: 'RENAME.COMMAND',\n\t0x009D: 'SHOW.BAR',\n\t0x009E: 'DELETE.MENU',\n\t0x009F: 'DELETE.COMMAND',\n\t0x00A0: 'GET.CHART.ITEM',\n\t0x00A1: 'DIALOG.BOX',\n\t0x00A2: 'CLEAN',\n\t0x00A3: 'MDETERM',\n\t0x00A4: 'MINVERSE',\n\t0x00A5: 'MMULT',\n\t0x00A6: 'FILES',\n\t0x00A7: 'IPMT',\n\t0x00A8: 'PPMT',\n\t0x00A9: 'COUNTA',\n\t0x00AA: 'CANCEL.KEY',\n\t0x00AB: 'FOR',\n\t0x00AC: 'WHILE',\n\t0x00AD: 'BREAK',\n\t0x00AE: 'NEXT',\n\t0x00AF: 'INITIATE',\n\t0x00B0: 'REQUEST',\n\t0x00B1: 'POKE',\n\t0x00B2: 'EXECUTE',\n\t0x00B3: 'TERMINATE',\n\t0x00B4: 'RESTART',\n\t0x00B5: 'HELP',\n\t0x00B6: 'GET.BAR',\n\t0x00B7: 'PRODUCT',\n\t0x00B8: 'FACT',\n\t0x00B9: 'GET.CELL',\n\t0x00BA: 'GET.WORKSPACE',\n\t0x00BB: 'GET.WINDOW',\n\t0x00BC: 'GET.DOCUMENT',\n\t0x00BD: 'DPRODUCT',\n\t0x00BE: 'ISNONTEXT',\n\t0x00BF: 'GET.NOTE',\n\t0x00C0: 'NOTE',\n\t0x00C1: 'STDEVP',\n\t0x00C2: 'VARP',\n\t0x00C3: 'DSTDEVP',\n\t0x00C4: 'DVARP',\n\t0x00C5: 'TRUNC',\n\t0x00C6: 'ISLOGICAL',\n\t0x00C7: 'DCOUNTA',\n\t0x00C8: 'DELETE.BAR',\n\t0x00C9: 'UNREGISTER',\n\t0x00CC: 'USDOLLAR',\n\t0x00CD: 'FINDB',\n\t0x00CE: 'SEARCHB',\n\t0x00CF: 'REPLACEB',\n\t0x00D0: 'LEFTB',\n\t0x00D1: 'RIGHTB',\n\t0x00D2: 'MIDB',\n\t0x00D3: 'LENB',\n\t0x00D4: 'ROUNDUP',\n\t0x00D5: 'ROUNDDOWN',\n\t0x00D6: 'ASC',\n\t0x00D7: 'DBCS',\n\t0x00D8: 'RANK',\n\t0x00DB: 'ADDRESS',\n\t0x00DC: 'DAYS360',\n\t0x00DD: 'TODAY',\n\t0x00DE: 'VDB',\n\t0x00DF: 'ELSE',\n\t0x00E0: 'ELSE.IF',\n\t0x00E1: 'END.IF',\n\t0x00E2: 'FOR.CELL',\n\t0x00E3: 'MEDIAN',\n\t0x00E4: 'SUMPRODUCT',\n\t0x00E5: 'SINH',\n\t0x00E6: 'COSH',\n\t0x00E7: 'TANH',\n\t0x00E8: 'ASINH',\n\t0x00E9: 'ACOSH',\n\t0x00EA: 'ATANH',\n\t0x00EB: 'DGET',\n\t0x00EC: 'CREATE.OBJECT',\n\t0x00ED: 'VOLATILE',\n\t0x00EE: 'LAST.ERROR',\n\t0x00EF: 'CUSTOM.UNDO',\n\t0x00F0: 'CUSTOM.REPEAT',\n\t0x00F1: 'FORMULA.CONVERT',\n\t0x00F2: 'GET.LINK.INFO',\n\t0x00F3: 'TEXT.BOX',\n\t0x00F4: 'INFO',\n\t0x00F5: 'GROUP',\n\t0x00F6: 'GET.OBJECT',\n\t0x00F7: 'DB',\n\t0x00F8: 'PAUSE',\n\t0x00FB: 'RESUME',\n\t0x00FC: 'FREQUENCY',\n\t0x00FD: 'ADD.TOOLBAR',\n\t0x00FE: 'DELETE.TOOLBAR',\n\t0x00FF: 'User',\n\t0x0100: 'RESET.TOOLBAR',\n\t0x0101: 'EVALUATE',\n\t0x0102: 'GET.TOOLBAR',\n\t0x0103: 'GET.TOOL',\n\t0x0104: 'SPELLING.CHECK',\n\t0x0105: 'ERROR.TYPE',\n\t0x0106: 'APP.TITLE',\n\t0x0107: 'WINDOW.TITLE',\n\t0x0108: 'SAVE.TOOLBAR',\n\t0x0109: 'ENABLE.TOOL',\n\t0x010A: 'PRESS.TOOL',\n\t0x010B: 'REGISTER.ID',\n\t0x010C: 'GET.WORKBOOK',\n\t0x010D: 'AVEDEV',\n\t0x010E: 'BETADIST',\n\t0x010F: 'GAMMALN',\n\t0x0110: 'BETAINV',\n\t0x0111: 'BINOMDIST',\n\t0x0112: 'CHIDIST',\n\t0x0113: 'CHIINV',\n\t0x0114: 'COMBIN',\n\t0x0115: 'CONFIDENCE',\n\t0x0116: 'CRITBINOM',\n\t0x0117: 'EVEN',\n\t0x0118: 'EXPONDIST',\n\t0x0119: 'FDIST',\n\t0x011A: 'FINV',\n\t0x011B: 'FISHER',\n\t0x011C: 'FISHERINV',\n\t0x011D: 'FLOOR',\n\t0x011E: 'GAMMADIST',\n\t0x011F: 'GAMMAINV',\n\t0x0120: 'CEILING',\n\t0x0121: 'HYPGEOMDIST',\n\t0x0122: 'LOGNORMDIST',\n\t0x0123: 'LOGINV',\n\t0x0124: 'NEGBINOMDIST',\n\t0x0125: 'NORMDIST',\n\t0x0126: 'NORMSDIST',\n\t0x0127: 'NORMINV',\n\t0x0128: 'NORMSINV',\n\t0x0129: 'STANDARDIZE',\n\t0x012A: 'ODD',\n\t0x012B: 'PERMUT',\n\t0x012C: 'POISSON',\n\t0x012D: 'TDIST',\n\t0x012E: 'WEIBULL',\n\t0x012F: 'SUMXMY2',\n\t0x0130: 'SUMX2MY2',\n\t0x0131: 'SUMX2PY2',\n\t0x0132: 'CHITEST',\n\t0x0133: 'CORREL',\n\t0x0134: 'COVAR',\n\t0x0135: 'FORECAST',\n\t0x0136: 'FTEST',\n\t0x0137: 'INTERCEPT',\n\t0x0138: 'PEARSON',\n\t0x0139: 'RSQ',\n\t0x013A: 'STEYX',\n\t0x013B: 'SLOPE',\n\t0x013C: 'TTEST',\n\t0x013D: 'PROB',\n\t0x013E: 'DEVSQ',\n\t0x013F: 'GEOMEAN',\n\t0x0140: 'HARMEAN',\n\t0x0141: 'SUMSQ',\n\t0x0142: 'KURT',\n\t0x0143: 'SKEW',\n\t0x0144: 'ZTEST',\n\t0x0145: 'LARGE',\n\t0x0146: 'SMALL',\n\t0x0147: 'QUARTILE',\n\t0x0148: 'PERCENTILE',\n\t0x0149: 'PERCENTRANK',\n\t0x014A: 'MODE',\n\t0x014B: 'TRIMMEAN',\n\t0x014C: 'TINV',\n\t0x014E: 'MOVIE.COMMAND',\n\t0x014F: 'GET.MOVIE',\n\t0x0150: 'CONCATENATE',\n\t0x0151: 'POWER',\n\t0x0152: 'PIVOT.ADD.DATA',\n\t0x0153: 'GET.PIVOT.TABLE',\n\t0x0154: 'GET.PIVOT.FIELD',\n\t0x0155: 'GET.PIVOT.ITEM',\n\t0x0156: 'RADIANS',\n\t0x0157: 'DEGREES',\n\t0x0158: 'SUBTOTAL',\n\t0x0159: 'SUMIF',\n\t0x015A: 'COUNTIF',\n\t0x015B: 'COUNTBLANK',\n\t0x015C: 'SCENARIO.GET',\n\t0x015D: 'OPTIONS.LISTS.GET',\n\t0x015E: 'ISPMT',\n\t0x015F: 'DATEDIF',\n\t0x0160: 'DATESTRING',\n\t0x0161: 'NUMBERSTRING',\n\t0x0162: 'ROMAN',\n\t0x0163: 'OPEN.DIALOG',\n\t0x0164: 'SAVE.DIALOG',\n\t0x0165: 'VIEW.GET',\n\t0x0166: 'GETPIVOTDATA',\n\t0x0167: 'HYPERLINK',\n\t0x0168: 'PHONETIC',\n\t0x0169: 'AVERAGEA',\n\t0x016A: 'MAXA',\n\t0x016B: 'MINA',\n\t0x016C: 'STDEVPA',\n\t0x016D: 'VARPA',\n\t0x016E: 'STDEVA',\n\t0x016F: 'VARA',\n\t0x0170: 'BAHTTEXT',\n\t0x0171: 'THAIDAYOFWEEK',\n\t0x0172: 'THAIDIGIT',\n\t0x0173: 'THAIMONTHOFYEAR',\n\t0x0174: 'THAINUMSOUND',\n\t0x0175: 'THAINUMSTRING',\n\t0x0176: 'THAISTRINGLENGTH',\n\t0x0177: 'ISTHAIDIGIT',\n\t0x0178: 'ROUNDBAHTDOWN',\n\t0x0179: 'ROUNDBAHTUP',\n\t0x017A: 'THAIYEAR',\n\t0x017B: 'RTD'\n};\nvar FtabArgc = {\n\t0x0002: 1, /* ISNA */\n\t0x0003: 1, /* ISERROR */\n\t0x000F: 1, /* SIN */\n\t0x0010: 1, /* COS */\n\t0x0011: 1, /* TAN */\n\t0x0012: 1, /* ATAN */\n\t0x0014: 1, /* SQRT */\n\t0x0015: 1, /* EXP */\n\t0x0016: 1, /* LN */\n\t0x0017: 1, /* LOG10 */\n\t0x0018: 1, /* ABS */\n\t0x0019: 1, /* INT */\n\t0x001A: 1, /* SIGN */\n\t0x001B: 2, /* ROUND */\n\t0x001E: 2, /* REPT */\n\t0x001F: 3, /* MID */\n\t0x0020: 1, /* LEN */\n\t0x0021: 1, /* VALUE */\n\t0x0026: 1, /* NOT */\n\t0x0027: 2, /* MOD */\n\t0x0028: 3, /* DCOUNT */\n\t0x0029: 3, /* DSUM */\n\t0x002A: 3, /* DAVERAGE */\n\t0x002B: 3, /* DMIN */\n\t0x002C: 3, /* DMAX */\n\t0x002D: 3, /* DSTDEV */\n\t0x002F: 3, /* DVAR */\n\t0x0030: 2, /* TEXT */\n\t0x0035: 1, /* GOTO */\n\t0x003D: 3, /* MIRR */\n\t0x0041: 3, /* DATE */\n\t0x0042: 3, /* TIME */\n\t0x0043: 1, /* DAY */\n\t0x0044: 1, /* MONTH */\n\t0x0045: 1, /* YEAR */\n\t0x0047: 1, /* HOUR */\n\t0x0048: 1, /* MINUTE */\n\t0x0049: 1, /* SECOND */\n\t0x004B: 1, /* AREAS */\n\t0x004C: 1, /* ROWS */\n\t0x004D: 1, /* COLUMNS */\n\t0x004F: 2, /* ABSREF */\n\t0x0050: 2, /* RELREF */\n\t0x0053: 1, /* TRANSPOSE */\n\t0x0056: 1, /* TYPE */\n\t0x005A: 1, /* DEREF */\n\t0x0061: 2, /* ATAN2 */\n\t0x0062: 1, /* ASIN */\n\t0x0063: 1, /* ACOS */\n\t0x0069: 1, /* ISREF */\n\t0x006F: 1, /* CHAR */\n\t0x0070: 1, /* LOWER */\n\t0x0071: 1, /* UPPER */\n\t0x0072: 1, /* PROPER */\n\t0x0075: 2, /* EXACT */\n\t0x0076: 1, /* TRIM */\n\t0x0077: 4, /* REPLACE */\n\t0x0079: 1, /* CODE */\n\t0x007E: 1, /* ISERR */\n\t0x007F: 1, /* ISTEXT */\n\t0x0080: 1, /* ISNUMBER */\n\t0x0081: 1, /* ISBLANK */\n\t0x0082: 1, /* T */\n\t0x0083: 1, /* N */\n\t0x0085: 1, /* FCLOSE */\n\t0x0086: 1, /* FSIZE */\n\t0x0087: 1, /* FREADLN */\n\t0x0088: 2, /* FREAD */\n\t0x0089: 2, /* FWRITELN */\n\t0x008A: 2, /* FWRITE */\n\t0x008C: 1, /* DATEVALUE */\n\t0x008D: 1, /* TIMEVALUE */\n\t0x008E: 3, /* SLN */\n\t0x008F: 4, /* SYD */\n\t0x00A2: 1, /* CLEAN */\n\t0x00A3: 1, /* MDETERM */\n\t0x00A4: 1, /* MINVERSE */\n\t0x00A5: 2, /* MMULT */\n\t0x00AC: 1, /* WHILE */\n\t0x00AF: 2, /* INITIATE */\n\t0x00B0: 2, /* REQUEST */\n\t0x00B1: 3, /* POKE */\n\t0x00B2: 2, /* EXECUTE */\n\t0x00B3: 1, /* TERMINATE */\n\t0x00B8: 1, /* FACT */\n\t0x00BD: 3, /* DPRODUCT */\n\t0x00BE: 1, /* ISNONTEXT */\n\t0x00C3: 3, /* DSTDEVP */\n\t0x00C4: 3, /* DVARP */\n\t0x00C6: 1, /* ISLOGICAL */\n\t0x00C7: 3, /* DCOUNTA */\n\t0x00C9: 1, /* UNREGISTER */\n\t0x00CF: 4, /* REPLACEB */\n\t0x00D2: 3, /* MIDB */\n\t0x00D3: 1, /* LENB */\n\t0x00D4: 2, /* ROUNDUP */\n\t0x00D5: 2, /* ROUNDDOWN */\n\t0x00D6: 1, /* ASC */\n\t0x00D7: 1, /* DBCS */\n\t0x00E5: 1, /* SINH */\n\t0x00E6: 1, /* COSH */\n\t0x00E7: 1, /* TANH */\n\t0x00E8: 1, /* ASINH */\n\t0x00E9: 1, /* ACOSH */\n\t0x00EA: 1, /* ATANH */\n\t0x00EB: 3, /* DGET */\n\t0x00F4: 1, /* INFO */\n\t0x00FC: 2, /* FREQUENCY */\n\t0x0101: 1, /* EVALUATE */\n\t0x0105: 1, /* ERROR.TYPE */\n\t0x010F: 1, /* GAMMALN */\n\t0x0111: 4, /* BINOMDIST */\n\t0x0112: 2, /* CHIDIST */\n\t0x0113: 2, /* CHIINV */\n\t0x0114: 2, /* COMBIN */\n\t0x0115: 3, /* CONFIDENCE */\n\t0x0116: 3, /* CRITBINOM */\n\t0x0117: 1, /* EVEN */\n\t0x0118: 3, /* EXPONDIST */\n\t0x0119: 3, /* FDIST */\n\t0x011A: 3, /* FINV */\n\t0x011B: 1, /* FISHER */\n\t0x011C: 1, /* FISHERINV */\n\t0x011D: 2, /* FLOOR */\n\t0x011E: 4, /* GAMMADIST */\n\t0x011F: 3, /* GAMMAINV */\n\t0x0120: 2, /* CEILING */\n\t0x0121: 4, /* HYPGEOMDIST */\n\t0x0122: 3, /* LOGNORMDIST */\n\t0x0123: 3, /* LOGINV */\n\t0x0124: 3, /* NEGBINOMDIST */\n\t0x0125: 4, /* NORMDIST */\n\t0x0126: 1, /* NORMSDIST */\n\t0x0127: 3, /* NORMINV */\n\t0x0128: 1, /* NORMSINV */\n\t0x0129: 3, /* STANDARDIZE */\n\t0x012A: 1, /* ODD */\n\t0x012B: 2, /* PERMUT */\n\t0x012C: 3, /* POISSON */\n\t0x012D: 3, /* TDIST */\n\t0x012E: 4, /* WEIBULL */\n\t0x012F: 2, /* SUMXMY2 */\n\t0x0130: 2, /* SUMX2MY2 */\n\t0x0131: 2, /* SUMX2PY2 */\n\t0x0132: 2, /* CHITEST */\n\t0x0133: 2, /* CORREL */\n\t0x0134: 2, /* COVAR */\n\t0x0135: 3, /* FORECAST */\n\t0x0136: 2, /* FTEST */\n\t0x0137: 2, /* INTERCEPT */\n\t0x0138: 2, /* PEARSON */\n\t0x0139: 2, /* RSQ */\n\t0x013A: 2, /* STEYX */\n\t0x013B: 2, /* SLOPE */\n\t0x013C: 4, /* TTEST */\n\t0x0145: 2, /* LARGE */\n\t0x0146: 2, /* SMALL */\n\t0x0147: 2, /* QUARTILE */\n\t0x0148: 2, /* PERCENTILE */\n\t0x014B: 2, /* TRIMMEAN */\n\t0x014C: 2, /* TINV */\n\t0x0151: 2, /* POWER */\n\t0x0156: 1, /* RADIANS */\n\t0x0157: 1, /* DEGREES */\n\t0x015A: 2, /* COUNTIF */\n\t0x015B: 1, /* COUNTBLANK */\n\t0x015E: 4, /* ISPMT */\n\t0x015F: 3, /* DATEDIF */\n\t0x0160: 1, /* DATESTRING */\n\t0x0161: 2, /* NUMBERSTRING */\n\t0x0168: 1, /* PHONETIC */\n\t0x0170: 1, /* BAHTTEXT */\n\t0x0171: 1, /* THAIDAYOFWEEK */\n\t0x0172: 1, /* THAIDIGIT */\n\t0x0173: 1, /* THAIMONTHOFYEAR */\n\t0x0174: 1, /* THAINUMSOUND */\n\t0x0175: 1, /* THAINUMSTRING */\n\t0x0176: 1, /* THAISTRINGLENGTH */\n\t0x0177: 1, /* ISTHAIDIGIT */\n\t0x0178: 1, /* ROUNDBAHTDOWN */\n\t0x0179: 1, /* ROUNDBAHTUP */\n\t0x017A: 1, /* THAIYEAR */\n\t0xFFFF: 0\n};\n/* [MS-XLSX] 2.2.3 Functions */\nvar XLSXFutureFunctions = {\n\t\"_xlfn.ACOT\": \"ACOT\",\n\t\"_xlfn.ACOTH\": \"ACOTH\",\n\t\"_xlfn.AGGREGATE\": \"AGGREGATE\",\n\t\"_xlfn.ARABIC\": \"ARABIC\",\n\t\"_xlfn.AVERAGEIF\": \"AVERAGEIF\",\n\t\"_xlfn.AVERAGEIFS\": \"AVERAGEIFS\",\n\t\"_xlfn.BASE\": \"BASE\",\n\t\"_xlfn.BETA.DIST\": \"BETA.DIST\",\n\t\"_xlfn.BETA.INV\": \"BETA.INV\",\n\t\"_xlfn.BINOM.DIST\": \"BINOM.DIST\",\n\t\"_xlfn.BINOM.DIST.RANGE\": \"BINOM.DIST.RANGE\",\n\t\"_xlfn.BINOM.INV\": \"BINOM.INV\",\n\t\"_xlfn.BITAND\": \"BITAND\",\n\t\"_xlfn.BITLSHIFT\": \"BITLSHIFT\",\n\t\"_xlfn.BITOR\": \"BITOR\",\n\t\"_xlfn.BITRSHIFT\": \"BITRSHIFT\",\n\t\"_xlfn.BITXOR\": \"BITXOR\",\n\t\"_xlfn.CEILING.MATH\": \"CEILING.MATH\",\n\t\"_xlfn.CEILING.PRECISE\": \"CEILING.PRECISE\",\n\t\"_xlfn.CHISQ.DIST\": \"CHISQ.DIST\",\n\t\"_xlfn.CHISQ.DIST.RT\": \"CHISQ.DIST.RT\",\n\t\"_xlfn.CHISQ.INV\": \"CHISQ.INV\",\n\t\"_xlfn.CHISQ.INV.RT\": \"CHISQ.INV.RT\",\n\t\"_xlfn.CHISQ.TEST\": \"CHISQ.TEST\",\n\t\"_xlfn.COMBINA\": \"COMBINA\",\n\t\"_xlfn.CONFIDENCE.NORM\": \"CONFIDENCE.NORM\",\n\t\"_xlfn.CONFIDENCE.T\": \"CONFIDENCE.T\",\n\t\"_xlfn.COT\": \"COT\",\n\t\"_xlfn.COTH\": \"COTH\",\n\t\"_xlfn.COUNTIFS\": \"COUNTIFS\",\n\t\"_xlfn.COVARIANCE.P\": \"COVARIANCE.P\",\n\t\"_xlfn.COVARIANCE.S\": \"COVARIANCE.S\",\n\t\"_xlfn.CSC\": \"CSC\",\n\t\"_xlfn.CSCH\": \"CSCH\",\n\t\"_xlfn.DAYS\": \"DAYS\",\n\t\"_xlfn.DECIMAL\": \"DECIMAL\",\n\t\"_xlfn.ECMA.CEILING\": \"ECMA.CEILING\",\n\t\"_xlfn.ERF.PRECISE\": \"ERF.PRECISE\",\n\t\"_xlfn.ERFC.PRECISE\": \"ERFC.PRECISE\",\n\t\"_xlfn.EXPON.DIST\": \"EXPON.DIST\",\n\t\"_xlfn.F.DIST\": \"F.DIST\",\n\t\"_xlfn.F.DIST.RT\": \"F.DIST.RT\",\n\t\"_xlfn.F.INV\": \"F.INV\",\n\t\"_xlfn.F.INV.RT\": \"F.INV.RT\",\n\t\"_xlfn.F.TEST\": \"F.TEST\",\n\t\"_xlfn.FILTERXML\": \"FILTERXML\",\n\t\"_xlfn.FLOOR.MATH\": \"FLOOR.MATH\",\n\t\"_xlfn.FLOOR.PRECISE\": \"FLOOR.PRECISE\",\n\t\"_xlfn.FORMULATEXT\": \"FORMULATEXT\",\n\t\"_xlfn.GAMMA\": \"GAMMA\",\n\t\"_xlfn.GAMMA.DIST\": \"GAMMA.DIST\",\n\t\"_xlfn.GAMMA.INV\": \"GAMMA.INV\",\n\t\"_xlfn.GAMMALN.PRECISE\": \"GAMMALN.PRECISE\",\n\t\"_xlfn.GAUSS\": \"GAUSS\",\n\t\"_xlfn.HYPGEOM.DIST\": \"HYPGEOM.DIST\",\n\t\"_xlfn.IFNA\": \"IFNA\",\n\t\"_xlfn.IFERROR\": \"IFERROR\",\n\t\"_xlfn.IMCOSH\": \"IMCOSH\",\n\t\"_xlfn.IMCOT\": \"IMCOT\",\n\t\"_xlfn.IMCSC\": \"IMCSC\",\n\t\"_xlfn.IMCSCH\": \"IMCSCH\",\n\t\"_xlfn.IMSEC\": \"IMSEC\",\n\t\"_xlfn.IMSECH\": \"IMSECH\",\n\t\"_xlfn.IMSINH\": \"IMSINH\",\n\t\"_xlfn.IMTAN\": \"IMTAN\",\n\t\"_xlfn.ISFORMULA\": \"ISFORMULA\",\n\t\"_xlfn.ISO.CEILING\": \"ISO.CEILING\",\n\t\"_xlfn.ISOWEEKNUM\": \"ISOWEEKNUM\",\n\t\"_xlfn.LOGNORM.DIST\": \"LOGNORM.DIST\",\n\t\"_xlfn.LOGNORM.INV\": \"LOGNORM.INV\",\n\t\"_xlfn.MODE.MULT\": \"MODE.MULT\",\n\t\"_xlfn.MODE.SNGL\": \"MODE.SNGL\",\n\t\"_xlfn.MUNIT\": \"MUNIT\",\n\t\"_xlfn.NEGBINOM.DIST\": \"NEGBINOM.DIST\",\n\t\"_xlfn.NETWORKDAYS.INTL\": \"NETWORKDAYS.INTL\",\n\t\"_xlfn.NIGBINOM\": \"NIGBINOM\",\n\t\"_xlfn.NORM.DIST\": \"NORM.DIST\",\n\t\"_xlfn.NORM.INV\": \"NORM.INV\",\n\t\"_xlfn.NORM.S.DIST\": \"NORM.S.DIST\",\n\t\"_xlfn.NORM.S.INV\": \"NORM.S.INV\",\n\t\"_xlfn.NUMBERVALUE\": \"NUMBERVALUE\",\n\t\"_xlfn.PDURATION\": \"PDURATION\",\n\t\"_xlfn.PERCENTILE.EXC\": \"PERCENTILE.EXC\",\n\t\"_xlfn.PERCENTILE.INC\": \"PERCENTILE.INC\",\n\t\"_xlfn.PERCENTRANK.EXC\": \"PERCENTRANK.EXC\",\n\t\"_xlfn.PERCENTRANK.INC\": \"PERCENTRANK.INC\",\n\t\"_xlfn.PERMUTATIONA\": \"PERMUTATIONA\",\n\t\"_xlfn.PHI\": \"PHI\",\n\t\"_xlfn.POISSON.DIST\": \"POISSON.DIST\",\n\t\"_xlfn.QUARTILE.EXC\": \"QUARTILE.EXC\",\n\t\"_xlfn.QUARTILE.INC\": \"QUARTILE.INC\",\n\t\"_xlfn.QUERYSTRING\": \"QUERYSTRING\",\n\t\"_xlfn.RANK.AVG\": \"RANK.AVG\",\n\t\"_xlfn.RANK.EQ\": \"RANK.EQ\",\n\t\"_xlfn.RRI\": \"RRI\",\n\t\"_xlfn.SEC\": \"SEC\",\n\t\"_xlfn.SECH\": \"SECH\",\n\t\"_xlfn.SHEET\": \"SHEET\",\n\t\"_xlfn.SHEETS\": \"SHEETS\",\n\t\"_xlfn.SKEW.P\": \"SKEW.P\",\n\t\"_xlfn.STDEV.P\": \"STDEV.P\",\n\t\"_xlfn.STDEV.S\": \"STDEV.S\",\n\t\"_xlfn.SUMIFS\": \"SUMIFS\",\n\t\"_xlfn.T.DIST\": \"T.DIST\",\n\t\"_xlfn.T.DIST.2T\": \"T.DIST.2T\",\n\t\"_xlfn.T.DIST.RT\": \"T.DIST.RT\",\n\t\"_xlfn.T.INV\": \"T.INV\",\n\t\"_xlfn.T.INV.2T\": \"T.INV.2T\",\n\t\"_xlfn.T.TEST\": \"T.TEST\",\n\t\"_xlfn.UNICHAR\": \"UNICHAR\",\n\t\"_xlfn.UNICODE\": \"UNICODE\",\n\t\"_xlfn.VAR.P\": \"VAR.P\",\n\t\"_xlfn.VAR.S\": \"VAR.S\",\n\t\"_xlfn.WEBSERVICE\": \"WEBSERVICE\",\n\t\"_xlfn.WEIBULL.DIST\": \"WEIBULL.DIST\",\n\t\"_xlfn.WORKDAY.INTL\": \"WORKDAY.INTL\",\n\t\"_xlfn.XOR\": \"XOR\",\n\t\"_xlfn.Z.TEST\": \"Z.TEST\"\n};\n\nvar strs = {}; // shared strings\nvar _ssfopts = {}; // spreadsheet formatting options\n\nRELS.WS = \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet\";\n\nfunction get_sst_id(sst, str) {\n\tfor(var i = 0, len = sst.length; i < len; ++i) if(sst[i].t === str) { sst.Count ++; return i; }\n\tsst[len] = {t:str}; sst.Count ++; sst.Unique ++; return len;\n}\n\nfunction get_cell_style(styles, cell, opts) {\n\tvar z = opts.revssf[cell.z != null ? cell.z : \"General\"];\n\tfor(var i = 0, len = styles.length; i != len; ++i) if(styles[i].numFmtId === z) return i;\n\tstyles[len] = {\n\t\tnumFmtId:z,\n\t\tfontId:0,\n\t\tfillId:0,\n\t\tborderId:0,\n\t\txfId:0,\n\t\tapplyNumberFormat:1\n\t};\n\treturn len;\n}\n\nfunction safe_format(p, fmtid, fillid, opts) {\n\ttry {\n\t\tif(p.t === 'e') p.w = p.w || BErr[p.v];\n\t\telse if(fmtid === 0) {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = SSF._general_int(p.v,_ssfopts);\n\t\t\t\telse p.w = SSF._general_num(p.v,_ssfopts);\n\t\t\t}\n\t\t\telse if(p.t === 'd') {\n\t\t\t\tvar dd = datenum(p.v);\n\t\t\t\tif((dd|0) === dd) p.w = SSF._general_int(dd,_ssfopts);\n\t\t\t\telse p.w = SSF._general_num(dd,_ssfopts);\n\t\t\t}\n\t\t\telse if(p.v === undefined) return \"\";\n\t\t\telse p.w = SSF._general(p.v,_ssfopts);\n\t\t}\n\t\telse if(p.t === 'd') p.w = SSF.format(fmtid,datenum(p.v),_ssfopts);\n\t\telse p.w = SSF.format(fmtid,p.v,_ssfopts);\n\t\tif(opts.cellNF) p.z = SSF._table[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(fillid) try {\n\t\tp.s = styles.Fills[fillid];\n\t\tif (p.s.fgColor && p.s.fgColor.theme) {\n\t\t\tp.s.fgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.fgColor.theme].rgb, p.s.fgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.fgColor.raw_rgb = themes.themeElements.clrScheme[p.s.fgColor.theme].rgb;\n\t\t}\n\t\tif (p.s.bgColor && p.s.bgColor.theme) {\n\t\t\tp.s.bgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.bgColor.theme].rgb, p.s.bgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.bgColor.raw_rgb = themes.themeElements.clrScheme[p.s.bgColor.theme].rgb;\n\t\t}\n\t} catch(e) { if(opts.WTF) throw e; }\n}\nfunction parse_ws_xml_dim(ws, s) {\n\tvar d = safe_decode_range(s);\n\tif(d.s.r<=d.e.r && d.s.c<=d.e.c && d.s.r>=0 && d.s.c>=0) ws[\"!ref\"] = encode_range(d);\n}\nvar mergecregex = /<mergeCell ref=\"[A-Z0-9:]+\"\\s*\\/>/g;\nvar sheetdataregex = /<(?:\\w+:)?sheetData>([^\\u2603]*)<\\/(?:\\w+:)?sheetData>/;\nvar hlinkregex = /<hyperlink[^>]*\\/>/g;\nvar dimregex = /\"(\\w*:\\w*)\"/;\nvar colregex = /<col[^>]*\\/>/g;\n/* 18.3 Worksheets */\nfunction parse_ws_xml(data, opts, rels) {\n\tif(!data) return data;\n\t/* 18.3.1.99 worksheet CT_Worksheet */\n\tvar s = {};\n\n\t/* 18.3.1.35 dimension CT_SheetDimension ? */\n\tvar ridx = data.indexOf(\"<dimension\");\n\tif(ridx > 0) {\n\t\tvar ref = data.substr(ridx,50).match(dimregex);\n\t\tif(ref != null) parse_ws_xml_dim(s, ref[1]);\n\t}\n\n\t/* 18.3.1.55 mergeCells CT_MergeCells */\n\tvar mergecells = [];\n\tif(data.indexOf(\"</mergeCells>\")!==-1) {\n\t\tvar merges = data.match(mergecregex);\n\t\tfor(ridx = 0; ridx != merges.length; ++ridx)\n\t\t\tmergecells[ridx] = safe_decode_range(merges[ridx].substr(merges[ridx].indexOf(\"\\\"\")+1));\n\t}\n\n\t/* 18.3.1.17 cols CT_Cols */\n\tvar columns = [];\n\tif(opts.cellStyles && data.indexOf(\"</cols>\")!==-1) {\n\t\t/* 18.3.1.13 col CT_Col */\n\t\tvar cols = data.match(colregex);\n\t\tparse_ws_xml_cols(columns, cols);\n\t}\n\n\tvar refguess = {s: {r:1000000, c:1000000}, e: {r:0, c:0} };\n\n\t/* 18.3.1.80 sheetData CT_SheetData ? */\n\tvar mtch=data.match(sheetdataregex);\n\tif(mtch) parse_ws_xml_data(mtch[1], s, opts, refguess);\n\n\t/* 18.3.1.48 hyperlinks CT_Hyperlinks */\n\tif(data.indexOf(\"</hyperlinks>\")!==-1) parse_ws_xml_hlinks(s, data.match(hlinkregex), rels);\n\n\tif(!s[\"!ref\"] && refguess.e.c >= refguess.s.c && refguess.e.r >= refguess.s.r) s[\"!ref\"] = encode_range(refguess);\n\tif(opts.sheetRows > 0 && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows < +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(mergecells.length > 0) s[\"!merges\"] = mergecells;\n\tif(columns.length > 0) s[\"!cols\"] = columns;\n\treturn s;\n}\n\nfunction write_ws_xml_merges(merges) {\n\tif(merges.length == 0) return \"\";\n\tvar o = '<mergeCells count=\"' + merges.length + '\">';\n\tfor(var i = 0; i != merges.length; ++i) o += '<mergeCell ref=\"' + encode_range(merges[i]) + '\"/>';\n\treturn o + '</mergeCells>';\n}\n\nfunction parse_ws_xml_hlinks(s, data, rels) {\n\tfor(var i = 0; i != data.length; ++i) {\n\t\tvar val = parsexmltag(data[i], true);\n\t\tif(!val.ref) return;\n\t\tvar rel = rels ? rels['!id'][val.id] : null;\n\t\tif(rel) {\n\t\t\tval.Target = rel.Target;\n\t\t\tif(val.location) val.Target += \"#\"+val.location;\n\t\t\tval.Rel = rel;\n\t\t} else {\n\t\t\tval.Target = val.location;\n\t\t\trel = {Target: val.location, TargetMode: 'Internal'};\n\t\t\tval.Rel = rel;\n\t\t}\n\t\tvar rng = safe_decode_range(val.ref);\n\t\tfor(var R=rng.s.r;R<=rng.e.r;++R) for(var C=rng.s.c;C<=rng.e.c;++C) {\n\t\t\tvar addr = encode_cell({c:C,r:R});\n\t\t\tif(!s[addr]) s[addr] = {t:\"stub\",v:undefined};\n\t\t\ts[addr].l = val;\n\t\t}\n\t}\n}\n\nfunction parse_ws_xml_cols(columns, cols) {\n\tvar seencol = false;\n\tfor(var coli = 0; coli != cols.length; ++coli) {\n\t\tvar coll = parsexmltag(cols[coli], true);\n\t\tvar colm=parseInt(coll.min, 10)-1, colM=parseInt(coll.max,10)-1;\n\t\tdelete coll.min; delete coll.max;\n\t\tif(!seencol && coll.width) { seencol = true; find_mdw(+coll.width, coll); }\n\t\tif(coll.width) {\n\t\t\tcoll.wpx = width2px(+coll.width);\n\t\t\tcoll.wch = px2char(coll.wpx);\n\t\t\tcoll.MDW = MDW;\n\t\t}\n\t\twhile(colm <= colM) columns[colm++] = coll;\n\t}\n}\n\nfunction write_ws_xml_cols(ws, cols) {\n\tvar o = [\"<cols>\"], col, width;\n\tfor(var i = 0; i != cols.length; ++i) {\n\t\tif(!(col = cols[i])) continue;\n\t\tvar p = {min:i+1,max:i+1};\n\t\t/* wch (chars), wpx (pixels) */\n\t\twidth = -1;\n\t\tif(col.wpx) width = px2char(col.wpx);\n\t\telse if(col.wch) width = col.wch;\n\t\tif(width > -1) { p.width = char2width(width); p.customWidth= 1; }\n\t\to[o.length] = (writextag('col', null, p));\n\t}\n\to[o.length] = \"</cols>\";\n\treturn o.join(\"\");\n}\n\nfunction write_ws_xml_cell(cell, ref, ws, opts, idx, wb) {\n\tif(cell.v === undefined) return \"\";\n\tvar vv = \"\";\n\tvar oldt = cell.t, oldv = cell.v;\n\tswitch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'n': vv = ''+cell.v; break;\n\t\tcase 'e': vv = BErr[cell.v]; break;\n\t\tcase 'd':\n\t\t\tif(opts.cellDates) vv = new Date(cell.v).toISOString();\n\t\t\telse {\n\t\t\t\tcell.t = 'n';\n\t\t\t\tvv = ''+(cell.v = datenum(cell.v));\n\t\t\t\tif(typeof cell.z === 'undefined') cell.z = SSF._table[14];\n\t\t\t}\n\t\t\tbreak;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar v = writetag('v', escapexml(vv)), o = {r:ref};\n\t/* TODO: cell style */\n\tvar os = get_cell_style(opts.cellXfs, cell, opts);\n\tif(os !== 0) o.s = os;\n\tswitch(cell.t) {\n\t\tcase 'n': break;\n\t\tcase 'd': o.t = \"d\"; break;\n\t\tcase 'b': o.t = \"b\"; break;\n\t\tcase 'e': o.t = \"e\"; break;\n\t\tdefault:\n\t\t\tif(opts.bookSST) {\n\t\t\t\tv = writetag('v', ''+get_sst_id(opts.Strings, cell.v));\n\t\t\t\to.t = \"s\"; break;\n\t\t\t}\n\t\t\to.t = \"str\"; break;\n\t}\n\tif(cell.t != oldt) { cell.t = oldt; cell.v = oldv; }\n\treturn writextag('c', v, o);\n}\n\nvar parse_ws_xml_data = (function parse_ws_xml_data_factory() {\n\tvar cellregex = /<(?:\\w+:)?c[ >]/, rowregex = /<\\/(?:\\w+:)?row>/;\n\tvar rregex = /r=[\"']([^\"']*)[\"']/, isregex = /<is>([\\S\\s]*?)<\\/is>/;\n\tvar match_v = matchtag(\"v\"), match_f = matchtag(\"f\");\n\nreturn function parse_ws_xml_data(sdata, s, opts, guess) {\n\tvar ri = 0, x = \"\", cells = [], cref = [], idx = 0, i=0, cc=0, d=\"\", p;\n\tvar tag, tagr = 0, tagc = 0;\n\tvar sstr;\n\tvar fmtid = 0, fillid = 0, do_format = Array.isArray(styles.CellXf), cf;\n\tfor(var marr = sdata.split(rowregex), mt = 0, marrlen = marr.length; mt != marrlen; ++mt) {\n\t\tx = marr[mt].trim();\n\t\tvar xlen = x.length;\n\t\tif(xlen === 0) continue;\n\n\t\t/* 18.3.1.73 row CT_Row */\n\t\tfor(ri = 0; ri < xlen; ++ri) if(x.charCodeAt(ri) === 62) break; ++ri;\n\t\ttag = parsexmltag(x.substr(0,ri), true);\n\t\t/* SpreadSheetGear uses implicit r/c */\n\t\ttagr = typeof tag.r !== 'undefined' ? parseInt(tag.r, 10) : tagr+1; tagc = -1;\n\t\tif(opts.sheetRows && opts.sheetRows < tagr) continue;\n\t\tif(guess.s.r > tagr - 1) guess.s.r = tagr - 1;\n\t\tif(guess.e.r < tagr - 1) guess.e.r = tagr - 1;\n\n\t\t/* 18.3.1.4 c CT_Cell */\n\t\tcells = x.substr(ri).split(cellregex);\n\t\tfor(ri = typeof tag.r === 'undefined' ? 0 : 1; ri != cells.length; ++ri) {\n\t\t\tx = cells[ri].trim();\n\t\t\tif(x.length === 0) continue;\n\t\t\tcref = x.match(rregex); idx = ri; i=0; cc=0;\n\t\t\tx = \"<c \" + (x.substr(0,1)==\"<\"?\">\":\"\") + x;\n\t\t\tif(cref !== null && cref.length === 2) {\n\t\t\t\tidx = 0; d=cref[1];\n\t\t\t\tfor(i=0; i != d.length; ++i) {\n\t\t\t\t\tif((cc=d.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\t\t\t\tidx = 26*idx + cc;\n\t\t\t\t}\n\t\t\t\t--idx;\n\t\t\t\ttagc = idx;\n\t\t\t} else ++tagc;\n\t\t\tfor(i = 0; i != x.length; ++i) if(x.charCodeAt(i) === 62) break; ++i;\n\t\t\ttag = parsexmltag(x.substr(0,i), true);\n\t\t\tif(!tag.r) tag.r = utils.encode_cell({r:tagr-1, c:tagc});\n\t\t\td = x.substr(i);\n\t\t\tp = {t:\"\"};\n\n\t\t\tif((cref=d.match(match_v))!== null && cref[1] !== '') p.v=unescapexml(cref[1]);\n\t\t\tif(opts.cellFormula && (cref=d.match(match_f))!== null) p.f=unescapexml(cref[1]);\n\n\t\t\t/* SCHEMA IS ACTUALLY INCORRECT HERE. IF A CELL HAS NO T, EMIT \"\" */\n\t\t\tif(tag.t === undefined && p.v === undefined) {\n\t\t\t\tif(!opts.sheetStubs) continue;\n\t\t\t\tp.t = \"stub\";\n\t\t\t}\n\t\t\telse p.t = tag.t || \"n\";\n\t\t\tif(guess.s.c > idx) guess.s.c = idx;\n\t\t\tif(guess.e.c < idx) guess.e.c = idx;\n\t\t\t/* 18.18.11 t ST_CellType */\n\t\t\tswitch(p.t) {\n\t\t\t\tcase 'n': p.v = parseFloat(p.v); break;\n\t\t\t\tcase 's':\n\t\t\t\t\tsstr = strs[parseInt(p.v, 10)];\n\t\t\t\t\tp.v = sstr.t;\n\t\t\t\t\tp.r = sstr.r;\n\t\t\t\t\tif(opts.cellHTML) p.h = sstr.h;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'str':\n\t\t\t\t\tp.t = \"s\";\n\t\t\t\t\tp.v = (p.v!=null) ? utf8read(p.v) : '';\n\t\t\t\t\tif(opts.cellHTML) p.h = p.v;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'inlineStr':\n\t\t\t\t\tcref = d.match(isregex);\n\t\t\t\t\tp.t = 's';\n\t\t\t\t\tif(cref !== null) { sstr = parse_si(cref[1]); p.v = sstr.t; } else p.v = \"\";\n\t\t\t\t\tbreak; // inline string\n\t\t\t\tcase 'b': p.v = parsexmlbool(p.v); break;\n\t\t\t\tcase 'd':\n\t\t\t\t\tif(!opts.cellDates) { p.v = datenum(p.v); p.t = 'n'; }\n\t\t\t\t\tbreak;\n\t\t\t\t/* error string in .v, number in .v */\n\t\t\t\tcase 'e': p.w = p.v; p.v = RBErr[p.v]; break;\n\t\t\t}\n\t\t\t/* formatting */\n\t\t\tfmtid = fillid = 0;\n\t\t\tif(do_format && tag.s !== undefined) {\n\t\t\t\tcf = styles.CellXf[tag.s];\n\t\t\t\tif(cf != null) {\n\t\t\t\t\tif(cf.numFmtId != null) fmtid = cf.numFmtId;\n\t\t\t\t\tif(opts.cellStyles && cf.fillId != null) fillid = cf.fillId;\n\t\t\t\t}\n\t\t\t}\n\t\t\tsafe_format(p, fmtid, fillid, opts);\n\t\t\ts[tag.r] = p;\n\t\t}\n\t}\n}; })();\n\nfunction write_ws_xml_data(ws, opts, idx, wb) {\n\tvar o = [], r = [], range = safe_decode_range(ws['!ref']), cell, ref, rr = \"\", cols = [], R, C;\n\tfor(C = range.s.c; C <= range.e.c; ++C) cols[C] = encode_col(C);\n\tfor(R = range.s.r; R <= range.e.r; ++R) {\n\t\tr = [];\n\t\trr = encode_row(R);\n\t\tfor(C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tref = cols[C] + rr;\n\t\t\tif(ws[ref] === undefined) continue;\n\t\t\tif((cell = write_ws_xml_cell(ws[ref], ref, ws, opts, idx, wb)) != null) r.push(cell);\n\t\t}\n\t\tif(r.length > 0) o[o.length] = (writextag('row', r.join(\"\"), {r:rr}));\n\t}\n\treturn o.join(\"\");\n}\n\nvar WS_XML_ROOT = writextag('worksheet', null, {\n\t'xmlns': XMLNS.main[0],\n\t'xmlns:r': XMLNS.r\n});\n\nfunction write_ws_xml(idx, opts, wb) {\n\tvar o = [XML_HEADER, WS_XML_ROOT];\n\tvar s = wb.SheetNames[idx], sidx = 0, rdata = \"\";\n\tvar ws = wb.Sheets[s];\n\tif(ws === undefined) ws = {};\n\tvar ref = ws['!ref']; if(ref === undefined) ref = 'A1';\n\to[o.length] = (writextag('dimension', null, {'ref': ref}));\n\n\tif(ws['!cols'] !== undefined && ws['!cols'].length > 0) o[o.length] = (write_ws_xml_cols(ws, ws['!cols']));\n\to[sidx = o.length] = '<sheetData/>';\n\tif(ws['!ref'] !== undefined) {\n\t\trdata = write_ws_xml_data(ws, opts, idx, wb);\n\t\tif(rdata.length > 0) o[o.length] = (rdata);\n\t}\n\tif(o.length>sidx+1) { o[o.length] = ('</sheetData>'); o[sidx]=o[sidx].replace(\"/>\",\">\"); }\n\n\tif(ws['!merges'] !== undefined && ws['!merges'].length > 0) o[o.length] = (write_ws_xml_merges(ws['!merges']));\n\n\tif(o.length>2) { o[o.length] = ('</worksheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSB] 2.4.718 BrtRowHdr */\nfunction parse_BrtRowHdr(data, length) {\n\tvar z = [];\n\tz.r = data.read_shift(4);\n\tdata.l += length-4;\n\treturn z;\n}\n\n/* [MS-XLSB] 2.4.812 BrtWsDim */\nvar parse_BrtWsDim = parse_UncheckedRfX;\nvar write_BrtWsDim = write_UncheckedRfX;\n\n/* [MS-XLSB] 2.4.815 BrtWsProp */\nfunction parse_BrtWsProp(data, length) {\n\tvar z = {};\n\t/* TODO: pull flags */\n\tdata.l += 19;\n\tz.name = parse_XLSBCodeName(data, length - 19);\n\treturn z;\n}\n\n/* [MS-XLSB] 2.4.303 BrtCellBlank */\nfunction parse_BrtCellBlank(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\treturn [cell];\n}\nfunction write_BrtCellBlank(cell, val, o) {\n\tif(o == null) o = new_buf(8);\n\treturn write_XLSBCell(val, o);\n}\n\n\n/* [MS-XLSB] 2.4.304 BrtCellBool */\nfunction parse_BrtCellBool(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'b'];\n}\n\n/* [MS-XLSB] 2.4.305 BrtCellError */\nfunction parse_BrtCellError(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'e'];\n}\n\n/* [MS-XLSB] 2.4.308 BrtCellIsst */\nfunction parse_BrtCellIsst(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar isst = data.read_shift(4);\n\treturn [cell, isst, 's'];\n}\n\n/* [MS-XLSB] 2.4.310 BrtCellReal */\nfunction parse_BrtCellReal(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_Xnum(data);\n\treturn [cell, value, 'n'];\n}\n\n/* [MS-XLSB] 2.4.311 BrtCellRk */\nfunction parse_BrtCellRk(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_RkNumber(data);\n\treturn [cell, value, 'n'];\n}\n\n/* [MS-XLSB] 2.4.314 BrtCellSt */\nfunction parse_BrtCellSt(data, length) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_XLWideString(data);\n\treturn [cell, value, 'str'];\n}\n\n/* [MS-XLSB] 2.4.647 BrtFmlaBool */\nfunction parse_BrtFmlaBool(data, length, opts) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'b'];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBCellParsedFormula(data, length-9);\n\t\to[3] = \"\"; /* TODO */\n\t}\n\telse data.l += length-9;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.648 BrtFmlaError */\nfunction parse_BrtFmlaError(data, length, opts) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'e'];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBCellParsedFormula(data, length-9);\n\t\to[3] = \"\"; /* TODO */\n\t}\n\telse data.l += length-9;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.649 BrtFmlaNum */\nfunction parse_BrtFmlaNum(data, length, opts) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_Xnum(data);\n\tvar o = [cell, value, 'n'];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBCellParsedFormula(data, length - 16);\n\t\to[3] = \"\"; /* TODO */\n\t}\n\telse data.l += length-16;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.650 BrtFmlaString */\nfunction parse_BrtFmlaString(data, length, opts) {\n\tvar start = data.l;\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_XLWideString(data);\n\tvar o = [cell, value, 'str'];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBCellParsedFormula(data, start + length - data.l);\n\t}\n\telse data.l = start + length;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.676 BrtMergeCell */\nvar parse_BrtMergeCell = parse_UncheckedRfX;\n\n/* [MS-XLSB] 2.4.656 BrtHLink */\nfunction parse_BrtHLink(data, length, opts) {\n\tvar end = data.l + length;\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tvar relId = parse_XLNullableWideString(data);\n\tvar loc = parse_XLWideString(data);\n\tvar tooltip = parse_XLWideString(data);\n\tvar display = parse_XLWideString(data);\n\tdata.l = end;\n\treturn {rfx:rfx, relId:relId, loc:loc, tooltip:tooltip, display:display};\n}\n\n/* [MS-XLSB] 2.1.7.61 Worksheet */\nfunction parse_ws_bin(data, opts, rels) {\n\tif(!data) return data;\n\tif(!rels) rels = {'!id':{}};\n\tvar s = {};\n\n\tvar ref;\n\tvar refguess = {s: {r:1000000, c:1000000}, e: {r:0, c:0} };\n\n\tvar pass = false, end = false;\n\tvar row, p, cf, R, C, addr, sstr, rr;\n\tvar mergecells = [];\n\trecordhopper(data, function ws_parse(val, R) {\n\t\tif(end) return;\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtWsDim': ref = val; break;\n\t\t\tcase 'BrtRowHdr':\n\t\t\t\trow = val;\n\t\t\t\tif(opts.sheetRows && opts.sheetRows <= row.r) end=true;\n\t\t\t\trr = encode_row(row.r);\n\t\t\t\tbreak;\n\n\t\t\tcase 'BrtFmlaBool':\n\t\t\tcase 'BrtFmlaError':\n\t\t\tcase 'BrtFmlaNum':\n\t\t\tcase 'BrtFmlaString':\n\t\t\tcase 'BrtCellBool':\n\t\t\tcase 'BrtCellError':\n\t\t\tcase 'BrtCellIsst':\n\t\t\tcase 'BrtCellReal':\n\t\t\tcase 'BrtCellRk':\n\t\t\tcase 'BrtCellSt':\n\t\t\t\tp = {t:val[2]};\n\t\t\t\tswitch(val[2]) {\n\t\t\t\t\tcase 'n': p.v = val[1]; break;\n\t\t\t\t\tcase 's': sstr = strs[val[1]]; p.v = sstr.t; p.r = sstr.r; break;\n\t\t\t\t\tcase 'b': p.v = val[1] ? true : false; break;\n\t\t\t\t\tcase 'e': p.v = val[1]; p.w = BErr[p.v]; break;\n\t\t\t\t\tcase 'str': p.t = 's'; p.v = utf8read(val[1]); break;\n\t\t\t\t}\n\t\t\t\tif(opts.cellFormula && val.length > 3) p.f = val[3];\n\t\t\t\tif((cf = styles.CellXf[val[0].iStyleRef])) safe_format(p,cf.ifmt,null,opts);\n\t\t\t\ts[encode_col(C=val[0].c) + rr] = p;\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tbreak;\n\n\t\t\tcase 'BrtCellBlank': if(!opts.sheetStubs) break;\n\t\t\t\tp = {t:'s',v:undefined};\n\t\t\t\ts[encode_col(C=val[0].c) + rr] = p;\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tbreak;\n\n\t\t\t/* Merge Cells */\n\t\t\tcase 'BrtBeginMergeCells': break;\n\t\t\tcase 'BrtEndMergeCells': break;\n\t\t\tcase 'BrtMergeCell': mergecells.push(val); break;\n\n\t\t\tcase 'BrtHLink':\n\t\t\t\tvar rel = rels['!id'][val.relId];\n\t\t\t\tif(rel) {\n\t\t\t\t\tval.Target = rel.Target;\n\t\t\t\t\tif(val.loc) val.Target += \"#\"+val.loc;\n\t\t\t\t\tval.Rel = rel;\n\t\t\t\t}\n\t\t\t\tfor(R=val.rfx.s.r;R<=val.rfx.e.r;++R) for(C=val.rfx.s.c;C<=val.rfx.e.c;++C) {\n\t\t\t\t\taddr = encode_cell({c:C,r:R});\n\t\t\t\t\tif(!s[addr]) s[addr] = {t:'s',v:undefined};\n\t\t\t\t\ts[addr].l = val;\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 'BrtArrFmla': break; // TODO\n\t\t\tcase 'BrtShrFmla': break; // TODO\n\t\t\tcase 'BrtBeginSheet': break;\n\t\t\tcase 'BrtWsProp': break; // TODO\n\t\t\tcase 'BrtSheetCalcProp': break; // TODO\n\t\t\tcase 'BrtBeginWsViews': break; // TODO\n\t\t\tcase 'BrtBeginWsView': break; // TODO\n\t\t\tcase 'BrtPane': break; // TODO\n\t\t\tcase 'BrtSel': break; // TODO\n\t\t\tcase 'BrtEndWsView': break; // TODO\n\t\t\tcase 'BrtEndWsViews': break; // TODO\n\t\t\tcase 'BrtACBegin': break; // TODO\n\t\t\tcase 'BrtRwDescent': break; // TODO\n\t\t\tcase 'BrtACEnd': break; // TODO\n\t\t\tcase 'BrtWsFmtInfoEx14': break; // TODO\n\t\t\tcase 'BrtWsFmtInfo': break; // TODO\n\t\t\tcase 'BrtBeginColInfos': break; // TODO\n\t\t\tcase 'BrtColInfo': break; // TODO\n\t\t\tcase 'BrtEndColInfos': break; // TODO\n\t\t\tcase 'BrtBeginSheetData': break; // TODO\n\t\t\tcase 'BrtEndSheetData': break; // TODO\n\t\t\tcase 'BrtSheetProtection': break; // TODO\n\t\t\tcase 'BrtPrintOptions': break; // TODO\n\t\t\tcase 'BrtMargins': break; // TODO\n\t\t\tcase 'BrtPageSetup': break; // TODO\n\t\t\tcase 'BrtFRTBegin': pass = true; break;\n\t\t\tcase 'BrtFRTEnd': pass = false; break;\n\t\t\tcase 'BrtEndSheet': break; // TODO\n\t\t\tcase 'BrtDrawing': break; // TODO\n\t\t\tcase 'BrtLegacyDrawing': break; // TODO\n\t\t\tcase 'BrtLegacyDrawingHF': break; // TODO\n\t\t\tcase 'BrtPhoneticInfo': break; // TODO\n\t\t\tcase 'BrtBeginHeaderFooter': break; // TODO\n\t\t\tcase 'BrtEndHeaderFooter': break; // TODO\n\t\t\tcase 'BrtBrk': break; // TODO\n\t\t\tcase 'BrtBeginRwBrk': break; // TODO\n\t\t\tcase 'BrtEndRwBrk': break; // TODO\n\t\t\tcase 'BrtBeginColBrk': break; // TODO\n\t\t\tcase 'BrtEndColBrk': break; // TODO\n\t\t\tcase 'BrtBeginUserShViews': break; // TODO\n\t\t\tcase 'BrtBeginUserShView': break; // TODO\n\t\t\tcase 'BrtEndUserShView': break; // TODO\n\t\t\tcase 'BrtEndUserShViews': break; // TODO\n\t\t\tcase 'BrtBkHim': break; // TODO\n\t\t\tcase 'BrtBeginOleObjects': break; // TODO\n\t\t\tcase 'BrtOleObject': break; // TODO\n\t\t\tcase 'BrtEndOleObjects': break; // TODO\n\t\t\tcase 'BrtBeginListParts': break; // TODO\n\t\t\tcase 'BrtListPart': break; // TODO\n\t\t\tcase 'BrtEndListParts': break; // TODO\n\t\t\tcase 'BrtBeginSortState': break; // TODO\n\t\t\tcase 'BrtBeginSortCond': break; // TODO\n\t\t\tcase 'BrtEndSortCond': break; // TODO\n\t\t\tcase 'BrtEndSortState': break; // TODO\n\t\t\tcase 'BrtBeginConditionalFormatting': break; // TODO\n\t\t\tcase 'BrtEndConditionalFormatting': break; // TODO\n\t\t\tcase 'BrtBeginCFRule': break; // TODO\n\t\t\tcase 'BrtEndCFRule': break; // TODO\n\t\t\tcase 'BrtBeginDVals': break; // TODO\n\t\t\tcase 'BrtDVal': break; // TODO\n\t\t\tcase 'BrtEndDVals': break; // TODO\n\t\t\tcase 'BrtRangeProtection': break; // TODO\n\t\t\tcase 'BrtBeginDCon': break; // TODO\n\t\t\tcase 'BrtEndDCon': break; // TODO\n\t\t\tcase 'BrtBeginDRefs': break;\n\t\t\tcase 'BrtDRef': break;\n\t\t\tcase 'BrtEndDRefs': break;\n\n\t\t\t/* ActiveX */\n\t\t\tcase 'BrtBeginActiveXControls': break;\n\t\t\tcase 'BrtActiveX': break;\n\t\t\tcase 'BrtEndActiveXControls': break;\n\n\t\t\t/* AutoFilter */\n\t\t\tcase 'BrtBeginAFilter': break;\n\t\t\tcase 'BrtEndAFilter': break;\n\t\t\tcase 'BrtBeginFilterColumn': break;\n\t\t\tcase 'BrtBeginFilters': break;\n\t\t\tcase 'BrtFilter': break;\n\t\t\tcase 'BrtEndFilters': break;\n\t\t\tcase 'BrtEndFilterColumn': break;\n\t\t\tcase 'BrtDynamicFilter': break;\n\t\t\tcase 'BrtTop10Filter': break;\n\t\t\tcase 'BrtBeginCustomFilters': break;\n\t\t\tcase 'BrtCustomFilter': break;\n\t\t\tcase 'BrtEndCustomFilters': break;\n\n\t\t\t/* Smart Tags */\n\t\t\tcase 'BrtBeginSmartTags': break;\n\t\t\tcase 'BrtBeginCellSmartTags': break;\n\t\t\tcase 'BrtBeginCellSmartTag': break;\n\t\t\tcase 'BrtCellSmartTagProperty': break;\n\t\t\tcase 'BrtEndCellSmartTag': break;\n\t\t\tcase 'BrtEndCellSmartTags': break;\n\t\t\tcase 'BrtEndSmartTags': break;\n\n\t\t\t/* Cell Watch */\n\t\t\tcase 'BrtBeginCellWatches': break;\n\t\t\tcase 'BrtCellWatch': break;\n\t\t\tcase 'BrtEndCellWatches': break;\n\n\t\t\t/* Table */\n\t\t\tcase 'BrtTable': break;\n\n\t\t\t/* Ignore Cell Errors */\n\t\t\tcase 'BrtBeginCellIgnoreECs': break;\n\t\t\tcase 'BrtCellIgnoreEC': break;\n\t\t\tcase 'BrtEndCellIgnoreECs': break;\n\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + R.n);\n\t\t}\n\t}, opts);\n\tif(!s[\"!ref\"] && (refguess.s.r < 1000000 || ref.e.r > 0 || ref.e.c > 0 || ref.s.r > 0 || ref.s.c > 0)) s[\"!ref\"] = encode_range(ref);\n\tif(opts.sheetRows && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows < +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(mergecells.length > 0) s[\"!merges\"] = mergecells;\n\treturn s;\n}\n\n/* TODO: something useful -- this is a stub */\nfunction write_ws_bin_cell(ba, cell, R, C, opts) {\n\tif(cell.v === undefined) return \"\";\n\tvar vv = \"\";\n\tswitch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'n': case 'e': vv = ''+cell.v; break;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar o = {r:R, c:C};\n\t/* TODO: cell style */\n\to.s = get_cell_style(opts.cellXfs, cell, opts);\n\tswitch(cell.t) {\n\t\tcase 's': case 'str':\n\t\t\tif(opts.bookSST) {\n\t\t\t\tvv = get_sst_id(opts.Strings, cell.v);\n\t\t\t\to.t = \"s\"; break;\n\t\t\t}\n\t\t\to.t = \"str\"; break;\n\t\tcase 'n': break;\n\t\tcase 'b': o.t = \"b\"; break;\n\t\tcase 'e': o.t = \"e\"; break;\n\t}\n\twrite_record(ba, \"BrtCellBlank\", write_BrtCellBlank(cell, o));\n}\n\nfunction write_CELLTABLE(ba, ws, idx, opts, wb) {\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\"), ref, rr = \"\", cols = [];\n\twrite_record(ba, 'BrtBeginSheetData');\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\t/* [ACCELLTABLE] */\n\t\t/* BrtRowHdr */\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t/* *16384CELL */\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tif(!ws[ref]) continue;\n\t\t\t/* write cell */\n\t\t\twrite_ws_bin_cell(ba, ws[ref], R, C, opts);\n\t\t}\n\t}\n\twrite_record(ba, 'BrtEndSheetData');\n}\n\nfunction write_ws_bin(idx, opts, wb) {\n\tvar ba = buf_array();\n\tvar s = wb.SheetNames[idx], ws = wb.Sheets[s] || {};\n\tvar r = safe_decode_range(ws['!ref'] || \"A1\");\n\twrite_record(ba, \"BrtBeginSheet\");\n\t/* [BrtWsProp] */\n\twrite_record(ba, \"BrtWsDim\", write_BrtWsDim(r));\n\t/* [WSVIEWS2] */\n\t/* [WSFMTINFO] */\n\t/* *COLINFOS */\n\twrite_CELLTABLE(ba, ws, idx, opts, wb);\n\t/* [BrtSheetCalcProp] */\n\t/* [[BrtSheetProtectionIso] BrtSheetProtection] */\n\t/* *([BrtRangeProtectionIso] BrtRangeProtection) */\n\t/* [SCENMAN] */\n\t/* [AUTOFILTER] */\n\t/* [SORTSTATE] */\n\t/* [DCON] */\n\t/* [USERSHVIEWS] */\n\t/* [MERGECELLS] */\n\t/* [BrtPhoneticInfo] */\n\t/* *CONDITIONALFORMATTING */\n\t/* [DVALS] */\n\t/* *BrtHLink */\n\t/* [BrtPrintOptions] */\n\t/* [BrtMargins] */\n\t/* [BrtPageSetup] */\n\t/* [HEADERFOOTER] */\n\t/* [RWBRK] */\n\t/* [COLBRK] */\n\t/* *BrtBigName */\n\t/* [CELLWATCHES] */\n\t/* [IGNOREECS] */\n\t/* [SMARTTAGS] */\n\t/* [BrtDrawing] */\n\t/* [BrtLegacyDrawing] */\n\t/* [BrtLegacyDrawingHF] */\n\t/* [BrtBkHim] */\n\t/* [OLEOBJECTS] */\n\t/* [ACTIVEXCONTROLS] */\n\t/* [WEBPUBITEMS] */\n\t/* [LISTPARTS] */\n\t/* FRTWORKSHEET */\n\twrite_record(ba, \"BrtEndSheet\");\n\treturn ba.end();\n}\n/* 18.2.28 (CT_WorkbookProtection) Defaults */\nvar WBPropsDef = [\n\t['allowRefreshQuery', '0'],\n\t['autoCompressPictures', '1'],\n\t['backupFile', '0'],\n\t['checkCompatibility', '0'],\n\t['codeName', ''],\n\t['date1904', '0'],\n\t['dateCompatibility', '1'],\n\t//['defaultThemeVersion', '0'],\n\t['filterPrivacy', '0'],\n\t['hidePivotFieldList', '0'],\n\t['promptedSolutions', '0'],\n\t['publishItems', '0'],\n\t['refreshAllConnections', false],\n\t['saveExternalLinkValues', '1'],\n\t['showBorderUnselectedTables', '1'],\n\t['showInkAnnotation', '1'],\n\t['showObjects', 'all'],\n\t['showPivotChartFilter', '0']\n\t//['updateLinks', 'userSet']\n];\n\n/* 18.2.30 (CT_BookView) Defaults */\nvar WBViewDef = [\n\t['activeTab', '0'],\n\t['autoFilterDateGrouping', '1'],\n\t['firstSheet', '0'],\n\t['minimized', '0'],\n\t['showHorizontalScroll', '1'],\n\t['showSheetTabs', '1'],\n\t['showVerticalScroll', '1'],\n\t['tabRatio', '600'],\n\t['visibility', 'visible']\n\t//window{Height,Width}, {x,y}Window\n];\n\n/* 18.2.19 (CT_Sheet) Defaults */\nvar SheetDef = [\n\t['state', 'visible']\n];\n\n/* 18.2.2 (CT_CalcPr) Defaults */\nvar CalcPrDef = [\n\t['calcCompleted', 'true'],\n\t['calcMode', 'auto'],\n\t['calcOnSave', 'true'],\n\t['concurrentCalc', 'true'],\n\t['fullCalcOnLoad', 'false'],\n\t['fullPrecision', 'true'],\n\t['iterate', 'false'],\n\t['iterateCount', '100'],\n\t['iterateDelta', '0.001'],\n\t['refMode', 'A1']\n];\n\n/* 18.2.3 (CT_CustomWorkbookView) Defaults */\nvar CustomWBViewDef = [\n\t['autoUpdate', 'false'],\n\t['changesSavedWin', 'false'],\n\t['includeHiddenRowCol', 'true'],\n\t['includePrintSettings', 'true'],\n\t['maximized', 'false'],\n\t['minimized', 'false'],\n\t['onlySync', 'false'],\n\t['personalView', 'false'],\n\t['showComments', 'commIndicator'],\n\t['showFormulaBar', 'true'],\n\t['showHorizontalScroll', 'true'],\n\t['showObjects', 'all'],\n\t['showSheetTabs', 'true'],\n\t['showStatusbar', 'true'],\n\t['showVerticalScroll', 'true'],\n\t['tabRatio', '600'],\n\t['xWindow', '0'],\n\t['yWindow', '0']\n];\n\nfunction push_defaults_array(target, defaults) {\n\tfor(var j = 0; j != target.length; ++j) { var w = target[j];\n\t\tfor(var i=0; i != defaults.length; ++i) { var z = defaults[i];\n\t\t\tif(w[z[0]] == null) w[z[0]] = z[1];\n\t\t}\n\t}\n}\nfunction push_defaults(target, defaults) {\n\tfor(var i = 0; i != defaults.length; ++i) { var z = defaults[i];\n\t\tif(target[z[0]] == null) target[z[0]] = z[1];\n\t}\n}\n\nfunction parse_wb_defaults(wb) {\n\tpush_defaults(wb.WBProps, WBPropsDef);\n\tpush_defaults(wb.CalcPr, CalcPrDef);\n\n\tpush_defaults_array(wb.WBView, WBViewDef);\n\tpush_defaults_array(wb.Sheets, SheetDef);\n\n\t_ssfopts.date1904 = parsexmlbool(wb.WBProps.date1904, 'date1904');\n}\n/* 18.2 Workbook */\nvar wbnsregex = /<\\w+:workbook/;\nfunction parse_wb_xml(data, opts) {\n\tvar wb = { AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, xmlns: \"\" };\n\tvar pass = false, xmlns = \"xmlns\";\n\tdata.match(tagregex).forEach(function xml_wb(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 18.2.27 workbook CT_Workbook 1 */\n\t\t\tcase '<workbook':\n\t\t\t\tif(x.match(wbnsregex)) xmlns = \"xmlns\" + x.match(/<(\\w+):/)[1];\n\t\t\t\twb.xmlns = y[xmlns];\n\t\t\t\tbreak;\n\t\t\tcase '</workbook>': break;\n\n\t\t\t/* 18.2.13 fileVersion CT_FileVersion ? */\n\t\t\tcase '<fileVersion': delete y[0]; wb.AppVersion = y; break;\n\t\t\tcase '<fileVersion/>': break;\n\n\t\t\t/* 18.2.12 fileSharing CT_FileSharing ? */\n\t\t\tcase '<fileSharing': case '<fileSharing/>': break;\n\n\t\t\t/* 18.2.28 workbookPr CT_WorkbookPr ? */\n\t\t\tcase '<workbookPr': delete y[0]; wb.WBProps = y; break;\n\t\t\tcase '<workbookPr/>': delete y[0]; wb.WBProps = y; break;\n\n\t\t\t/* 18.2.29 workbookProtection CT_WorkbookProtection ? */\n\t\t\tcase '<workbookProtection': break;\n\t\t\tcase '<workbookProtection/>': break;\n\n\t\t\t/* 18.2.1 bookViews CT_BookViews ? */\n\t\t\tcase '<bookViews>': case '</bookViews>': break;\n\t\t\t/* 18.2.30 workbookView CT_BookView + */\n\t\t\tcase '<workbookView': delete y[0]; wb.WBView.push(y); break;\n\n\t\t\t/* 18.2.20 sheets CT_Sheets 1 */\n\t\t\tcase '<sheets>': case '</sheets>': break; // aggregate sheet\n\t\t\t/* 18.2.19 sheet CT_Sheet + */\n\t\t\tcase '<sheet': delete y[0]; y.name = utf8read(y.name); wb.Sheets.push(y); break;\n\n\t\t\t/* 18.2.15 functionGroups CT_FunctionGroups ? */\n\t\t\tcase '<functionGroups': case '<functionGroups/>': break;\n\t\t\t/* 18.2.14 functionGroup CT_FunctionGroup + */\n\t\t\tcase '<functionGroup': break;\n\n\t\t\t/* 18.2.9 externalReferences CT_ExternalReferences ? */\n\t\t\tcase '<externalReferences': case '</externalReferences>': case '<externalReferences>': break;\n\t\t\t/* 18.2.8 externalReference CT_ExternalReference + */\n\t\t\tcase '<externalReference': break;\n\n\t\t\t/* 18.2.6 definedNames CT_DefinedNames ? */\n\t\t\tcase '<definedNames/>': break;\n\t\t\tcase '<definedNames>': case '<definedNames': pass=true; break;\n\t\t\tcase '</definedNames>': pass=false; break;\n\t\t\t/* 18.2.5 definedName CT_DefinedName + */\n\t\t\tcase '<definedName': case '<definedName/>': case '</definedName>': break;\n\n\t\t\t/* 18.2.2 calcPr CT_CalcPr ? */\n\t\t\tcase '<calcPr': delete y[0]; wb.CalcPr = y; break;\n\t\t\tcase '<calcPr/>': delete y[0]; wb.CalcPr = y; break;\n\n\t\t\t/* 18.2.16 oleSize CT_OleSize ? (ref required) */\n\t\t\tcase '<oleSize': break;\n\n\t\t\t/* 18.2.4 customWorkbookViews CT_CustomWorkbookViews ? */\n\t\t\tcase '<customWorkbookViews>': case '</customWorkbookViews>': case '<customWorkbookViews': break;\n\t\t\t/* 18.2.3 customWorkbookView CT_CustomWorkbookView + */\n\t\t\tcase '<customWorkbookView': case '</customWorkbookView>': break;\n\n\t\t\t/* 18.2.18 pivotCaches CT_PivotCaches ? */\n\t\t\tcase '<pivotCaches>': case '</pivotCaches>': case '<pivotCaches': break;\n\t\t\t/* 18.2.17 pivotCache CT_PivotCache ? */\n\t\t\tcase '<pivotCache': break;\n\n\t\t\t/* 18.2.21 smartTagPr CT_SmartTagPr ? */\n\t\t\tcase '<smartTagPr': case '<smartTagPr/>': break;\n\n\t\t\t/* 18.2.23 smartTagTypes CT_SmartTagTypes ? */\n\t\t\tcase '<smartTagTypes': case '<smartTagTypes>': case '</smartTagTypes>': break;\n\t\t\t/* 18.2.22 smartTagType CT_SmartTagType ? */\n\t\t\tcase '<smartTagType': break;\n\n\t\t\t/* 18.2.24 webPublishing CT_WebPublishing ? */\n\t\t\tcase '<webPublishing': case '<webPublishing/>': break;\n\n\t\t\t/* 18.2.11 fileRecoveryPr CT_FileRecoveryPr ? */\n\t\t\tcase '<fileRecoveryPr': case '<fileRecoveryPr/>': break;\n\n\t\t\t/* 18.2.26 webPublishObjects CT_WebPublishObjects ? */\n\t\t\tcase '<webPublishObjects>': case '<webPublishObjects': case '</webPublishObjects>': break;\n\t\t\t/* 18.2.25 webPublishObject CT_WebPublishObject ? */\n\t\t\tcase '<webPublishObject': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7 ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break; //TODO: check with versions of excel\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\t/* Others */\n\t\t\tcase '<ArchID': break;\n\t\t\tcase '<AlternateContent': pass=true; break;\n\t\t\tcase '</AlternateContent>': pass=false; break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw 'unrecognized ' + y[0] + ' in workbook';\n\t\t}\n\t});\n\tif(XMLNS.main.indexOf(wb.xmlns) === -1) throw new Error(\"Unknown Namespace: \" + wb.xmlns);\n\n\tparse_wb_defaults(wb);\n\n\treturn wb;\n}\n\nvar WB_XML_ROOT = writextag('workbook', null, {\n\t'xmlns': XMLNS.main[0],\n\t//'xmlns:mx': XMLNS.mx,\n\t//'xmlns:s': XMLNS.main[0],\n\t'xmlns:r': XMLNS.r\n});\n\nfunction safe1904(wb) {\n\t/* TODO: store date1904 somewhere else */\n\ttry { return parsexmlbool(wb.Workbook.WBProps.date1904) ? \"true\" : \"false\"; } catch(e) { return \"false\"; }\n}\n\nfunction write_wb_xml(wb, opts) {\n\tvar o = [XML_HEADER];\n\to[o.length] = WB_XML_ROOT;\n\to[o.length] = (writextag('workbookPr', null, {date1904:safe1904(wb)}));\n\to[o.length] = \"<sheets>\";\n\tfor(var i = 0; i != wb.SheetNames.length; ++i)\n\t\to[o.length] = (writextag('sheet',null,{name:wb.SheetNames[i].substr(0,31), sheetId:\"\"+(i+1), \"r:id\":\"rId\"+(i+1)}));\n\to[o.length] = \"</sheets>\";\n\tif(o.length>2){ o[o.length] = '</workbook>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.301 BrtBundleSh */\nfunction parse_BrtBundleSh(data, length) {\n\tvar z = {};\n\tz.hsState = data.read_shift(4); //ST_SheetState\n\tz.iTabID = data.read_shift(4);\n\tz.strRelID = parse_RelID(data,length-8);\n\tz.name = parse_XLWideString(data);\n\treturn z;\n}\nfunction write_BrtBundleSh(data, o) {\n\tif(!o) o = new_buf(127);\n\to.write_shift(4, data.hsState);\n\to.write_shift(4, data.iTabID);\n\twrite_RelID(data.strRelID, o);\n\twrite_XLWideString(data.name.substr(0,31), o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.807 BrtWbProp */\nfunction parse_BrtWbProp(data, length) {\n\tdata.read_shift(4);\n\tvar dwThemeVersion = data.read_shift(4);\n\tvar strName = (length > 8) ? parse_XLWideString(data) : \"\";\n\treturn [dwThemeVersion, strName];\n}\nfunction write_BrtWbProp(data, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\treturn o;\n}\n\nfunction parse_BrtFRTArchID$(data, length) {\n\tvar o = {};\n\tdata.read_shift(4);\n\to.ArchID = data.read_shift(4);\n\tdata.l += length - 8;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.7.60 Workbook */\nfunction parse_wb_bin(data, opts) {\n\tvar wb = { AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, xmlns: \"\" };\n\tvar pass = false, z;\n\n\trecordhopper(data, function hopper_wb(val, R) {\n\t\tswitch(R.n) {\n\t\t\tcase 'BrtBundleSh': wb.Sheets.push(val); break;\n\n\t\t\tcase 'BrtBeginBook': break;\n\t\t\tcase 'BrtFileVersion': break;\n\t\t\tcase 'BrtWbProp': break;\n\t\t\tcase 'BrtACBegin': break;\n\t\t\tcase 'BrtAbsPath15': break;\n\t\t\tcase 'BrtACEnd': break;\n\t\t\tcase 'BrtWbFactoid': break;\n\t\t\t/*case 'BrtBookProtectionIso': break;*/\n\t\t\tcase 'BrtBookProtection': break;\n\t\t\tcase 'BrtBeginBookViews': break;\n\t\t\tcase 'BrtBookView': break;\n\t\t\tcase 'BrtEndBookViews': break;\n\t\t\tcase 'BrtBeginBundleShs': break;\n\t\t\tcase 'BrtEndBundleShs': break;\n\t\t\tcase 'BrtBeginFnGroup': break;\n\t\t\tcase 'BrtEndFnGroup': break;\n\t\t\tcase 'BrtBeginExternals': break;\n\t\t\tcase 'BrtSupSelf': break;\n\t\t\tcase 'BrtSupBookSrc': break;\n\t\t\tcase 'BrtExternSheet': break;\n\t\t\tcase 'BrtEndExternals': break;\n\t\t\tcase 'BrtName': break;\n\t\t\tcase 'BrtCalcProp': break;\n\t\t\tcase 'BrtUserBookView': break;\n\t\t\tcase 'BrtBeginPivotCacheIDs': break;\n\t\t\tcase 'BrtBeginPivotCacheID': break;\n\t\t\tcase 'BrtEndPivotCacheID': break;\n\t\t\tcase 'BrtEndPivotCacheIDs': break;\n\t\t\tcase 'BrtWebOpt': break;\n\t\t\tcase 'BrtFileRecover': break;\n\t\t\tcase 'BrtFileSharing': break;\n\t\t\t/*case 'BrtBeginWebPubItems': break;\n\t\t\tcase 'BrtBeginWebPubItem': break;\n\t\t\tcase 'BrtEndWebPubItem': break;\n\t\t\tcase 'BrtEndWebPubItems': break;*/\n\n\t\t\t/* Smart Tags */\n\t\t\tcase 'BrtBeginSmartTagTypes': break;\n\t\t\tcase 'BrtSmartTagType': break;\n\t\t\tcase 'BrtEndSmartTagTypes': break;\n\n\t\t\tcase 'BrtFRTBegin': pass = true; break;\n\t\t\tcase 'BrtFRTArchID$': break;\n\t\t\tcase 'BrtWorkBookPr15': break;\n\t\t\tcase 'BrtFRTEnd': pass = false; break;\n\t\t\tcase 'BrtEndBook': break;\n\t\t\tdefault: if(!pass || opts.WTF) throw new Error(\"Unexpected record \" + R.n);\n\t\t}\n\t});\n\n\tparse_wb_defaults(wb);\n\n\treturn wb;\n}\n\n/* [MS-XLSB] 2.1.7.60 Workbook */\nfunction write_BUNDLESHS(ba, wb, opts) {\n\twrite_record(ba, \"BrtBeginBundleShs\");\n\tfor(var idx = 0; idx != wb.SheetNames.length; ++idx) {\n\t\tvar d = { hsState: 0, iTabID: idx+1, strRelID: 'rId' + (idx+1), name: wb.SheetNames[idx] };\n\t\twrite_record(ba, \"BrtBundleSh\", write_BrtBundleSh(d));\n\t}\n\twrite_record(ba, \"BrtEndBundleShs\");\n}\n\n/* [MS-XLSB] 2.4.643 BrtFileVersion */\nfunction write_BrtFileVersion(data, o) {\n\tif(!o) o = new_buf(127);\n\tfor(var i = 0; i != 4; ++i) o.write_shift(4, 0);\n\twrite_XLWideString(\"SheetJS\", o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(\"7262\", o);\n\to.length = o.l;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.7.60 Workbook */\nfunction write_BOOKVIEWS(ba, wb, opts) {\n\twrite_record(ba, \"BrtBeginBookViews\");\n\t/* 1*(BrtBookView *FRT) */\n\twrite_record(ba, \"BrtEndBookViews\");\n}\n\n/* [MS-XLSB] 2.4.302 BrtCalcProp */\nfunction write_BrtCalcProp(data, o) {\n\tif(!o) o = new_buf(26);\n\to.write_shift(4,0); /* force recalc */\n\to.write_shift(4,1);\n\to.write_shift(4,0);\n\twrite_Xnum(0, o);\n\to.write_shift(-4, 1023);\n\to.write_shift(1, 0x33);\n\to.write_shift(1, 0x00);\n\treturn o;\n}\n\nfunction write_BrtFileRecover(data, o) {\n\tif(!o) o = new_buf(1);\n\to.write_shift(1,0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.7.60 Workbook */\nfunction write_wb_bin(wb, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, \"BrtBeginBook\");\n\twrite_record(ba, \"BrtFileVersion\", write_BrtFileVersion());\n\t/* [[BrtFileSharingIso] BrtFileSharing] */\n\twrite_record(ba, \"BrtWbProp\", write_BrtWbProp());\n\t/* [ACABSPATH] */\n\t/* [[BrtBookProtectionIso] BrtBookProtection] */\n\twrite_BOOKVIEWS(ba, wb, opts);\n\twrite_BUNDLESHS(ba, wb, opts);\n\t/* [FNGROUP] */\n\t/* [EXTERNALS] */\n\t/* *BrtName */\n\twrite_record(ba, \"BrtCalcProp\", write_BrtCalcProp());\n\t/* [BrtOleSize] */\n\t/* *(BrtUserBookView *FRT) */\n\t/* [PIVOTCACHEIDS] */\n\t/* [BrtWbFactoid] */\n\t/* [SMARTTAGTYPES] */\n\t/* [BrtWebOpt] */\n\twrite_record(ba, \"BrtFileRecover\", write_BrtFileRecover());\n\t/* [WEBPUBITEMS] */\n\t/* [CRERRS] */\n\t/* FRTWORKBOOK */\n\twrite_record(ba, \"BrtEndBook\");\n\n\treturn ba.end();\n}\nfunction parse_wb(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? parse_wb_bin : parse_wb_xml)(data, opts);\n}\n\nfunction parse_ws(data, name, opts, rels) {\n\treturn (name.substr(-4)===\".bin\" ? parse_ws_bin : parse_ws_xml)(data, opts, rels);\n}\n\nfunction parse_sty(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? parse_sty_bin : parse_sty_xml)(data, opts);\n}\n\nfunction parse_theme(data, name, opts) {\n\treturn parse_theme_xml(data, opts);\n}\n\nfunction parse_sst(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? parse_sst_bin : parse_sst_xml)(data, opts);\n}\n\nfunction parse_cmnt(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? parse_comments_bin : parse_comments_xml)(data, opts);\n}\n\nfunction parse_cc(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? parse_cc_bin : parse_cc_xml)(data, opts);\n}\n\nfunction write_wb(wb, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? write_wb_bin : write_wb_xml)(wb, opts);\n}\n\nfunction write_ws(data, name, opts, wb) {\n\treturn (name.substr(-4)===\".bin\" ? write_ws_bin : write_ws_xml)(data, opts, wb);\n}\n\nfunction write_sty(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? write_sty_bin : write_sty_xml)(data, opts);\n}\n\nfunction write_sst(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? write_sst_bin : write_sst_xml)(data, opts);\n}\n/*\nfunction write_cmnt(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? write_comments_bin : write_comments_xml)(data, opts);\n}\n\nfunction write_cc(data, name, opts) {\n\treturn (name.substr(-4)===\".bin\" ? write_cc_bin : write_cc_xml)(data, opts);\n}\n*/\nvar attregexg2=/([\\w:]+)=((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:'))/g;\nvar attregex2=/([\\w:]+)=((?:\")(?:[^\"]*)(?:\")|(?:')(?:[^']*)(?:'))/;\nvar _chr = function(c) { return String.fromCharCode(c); };\nfunction xlml_parsexmltag(tag, skip_root) {\n\tvar words = tag.split(/\\s+/);\n\tvar z = []; if(!skip_root) z[0] = words[0];\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].substr(1,y[2].length-2);\n\t\telse {\n\t\t\tif(y[1].substr(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].substr(6);\n\t\t\telse w = y[1].substr(j+1);\n\t\t\tz[w] = y[2].substr(1,y[2].length-2);\n\t\t}\n\t}\n\treturn z;\n}\nfunction xlml_parsexmltagobj(tag) {\n\tvar words = tag.split(/\\s+/);\n\tvar z = {};\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].substr(1,y[2].length-2);\n\t\telse {\n\t\t\tif(y[1].substr(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].substr(6);\n\t\t\telse w = y[1].substr(j+1);\n\t\t\tz[w] = y[2].substr(1,y[2].length-2);\n\t\t}\n\t}\n\treturn z;\n}\n\n// ----\n\nfunction xlml_format(format, value) {\n\tvar fmt = XLMLFormatMap[format] || unescapexml(format);\n\tif(fmt === \"General\") return SSF._general(value);\n\treturn SSF.format(fmt, value);\n}\n\nfunction xlml_set_custprop(Custprops, Rn, cp, val) {\n\tswitch((cp[0].match(/dt:dt=\"([\\w.]+)\"/)||[\"\",\"\"])[1]) {\n\t\tcase \"boolean\": val = parsexmlbool(val); break;\n\t\tcase \"i2\": case \"int\": val = parseInt(val, 10); break;\n\t\tcase \"r4\": case \"float\": val = parseFloat(val); break;\n\t\tcase \"date\": case \"dateTime.tz\": val = new Date(val); break;\n\t\tcase \"i8\": case \"string\": case \"fixed\": case \"uuid\": case \"bin.base64\": break;\n\t\tdefault: throw \"bad custprop:\" + cp[0];\n\t}\n\tCustprops[unescapexml(Rn[3])] = val;\n}\n\nfunction safe_format_xlml(cell, nf, o) {\n\ttry {\n\t\tif(cell.t === 'e') { cell.w = cell.w || BErr[cell.v]; }\n\t\telse if(nf === \"General\") {\n\t\t\tif(cell.t === 'n') {\n\t\t\t\tif((cell.v|0) === cell.v) cell.w = SSF._general_int(cell.v);\n\t\t\t\telse cell.w = SSF._general_num(cell.v);\n\t\t\t}\n\t\t\telse cell.w = SSF._general(cell.v);\n\t\t}\n\t\telse cell.w = xlml_format(nf||\"General\", cell.v);\n\t\tif(o.cellNF) cell.z = XLMLFormatMap[nf]||nf||\"General\";\n\t} catch(e) { if(o.WTF) throw e; }\n}\n\nfunction process_style_xlml(styles, stag, opts) {\n\tif(opts.cellStyles) {\n\t\tif(stag.Interior) {\n\t\t\tvar I = stag.Interior;\n\t\t\tif(I.Pattern) I.patternType = XLMLPatternTypeMap[I.Pattern] || I.Pattern;\n\t\t}\n\t}\n\tstyles[stag.ID] = stag;\n}\n\n/* TODO: there must exist some form of OSP-blessed spec */\nfunction parse_xlml_data(xml, ss, data, cell, base, styles, csty, row, o) {\n\tvar nf = \"General\", sid = cell.StyleID, S = {}; o = o || {};\n\tvar interiors = [];\n\tif(sid === undefined && row) sid = row.StyleID;\n\tif(sid === undefined && csty) sid = csty.StyleID;\n\twhile(styles[sid] !== undefined) {\n\t\tif(styles[sid].nf) nf = styles[sid].nf;\n\t\tif(styles[sid].Interior) interiors.push(styles[sid].Interior);\n\t\tif(!styles[sid].Parent) break;\n\t\tsid = styles[sid].Parent;\n\t}\n\tswitch(data.Type) {\n\t\tcase 'Boolean':\n\t\t\tcell.t = 'b';\n\t\t\tcell.v = parsexmlbool(xml);\n\t\t\tbreak;\n\t\tcase 'String':\n\t\t\tcell.t = 's'; cell.r = xlml_fixstr(unescapexml(xml));\n\t\t\tcell.v = xml.indexOf(\"<\") > -1 ? ss : cell.r;\n\t\t\tbreak;\n\t\tcase 'DateTime':\n\t\t\tcell.v = (Date.parse(xml) - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);\n\t\t\tif(cell.v !== cell.v) cell.v = unescapexml(xml);\n\t\t\telse if(cell.v >= 1 && cell.v<60) cell.v = cell.v -1;\n\t\t\tif(!nf || nf == \"General\") nf = \"yyyy-mm-dd\";\n\t\t\t/* falls through */\n\t\tcase 'Number':\n\t\t\tif(cell.v === undefined) cell.v=+xml;\n\t\t\tif(!cell.t) cell.t = 'n';\n\t\t\tbreak;\n\t\tcase 'Error': cell.t = 'e'; cell.v = RBErr[xml]; cell.w = xml; break;\n\t\tdefault: cell.t = 's'; cell.v = xlml_fixstr(ss); break;\n\t}\n\tsafe_format_xlml(cell, nf, o);\n\tif(o.cellFormula != null && cell.Formula) {\n\t\tcell.f = rc_to_a1(unescapexml(cell.Formula), base);\n\t\tcell.Formula = undefined;\n\t}\n\tif(o.cellStyles) {\n\t\tinteriors.forEach(function(x) {\n\t\t\tif(!S.patternType && x.patternType) S.patternType = x.patternType;\n\t\t});\n\t\tcell.s = S;\n\t}\n\tcell.ixfe = cell.StyleID !== undefined ? cell.StyleID : 'Default';\n}\n\nfunction xlml_clean_comment(comment) {\n\tcomment.t = comment.v;\n\tcomment.v = comment.w = comment.ixfe = undefined;\n}\n\nfunction xlml_normalize(d) {\n\tif(has_buf && Buffer.isBuffer(d)) return d.toString('utf8');\n\tif(typeof d === 'string') return d;\n\tthrow \"badf\";\n}\n\n/* TODO: Everything */\nvar xlmlregex = /<(\\/?)([a-z0-9]*:|)(\\w+)[^>]*>/mg;\nfunction parse_xlml_xml(d, opts) {\n\tvar str = xlml_normalize(d);\n\tvar Rn;\n\tvar state = [], tmp;\n\tvar sheets = {}, sheetnames = [], cursheet = {}, sheetname = \"\";\n\tvar table = {}, cell = {}, row = {}, dtag, didx;\n\tvar c = 0, r = 0;\n\tvar refguess = {s: {r:1000000, c:1000000}, e: {r:0, c:0} };\n\tvar styles = {}, stag = {};\n\tvar ss = \"\", fidx = 0;\n\tvar mergecells = [];\n\tvar Props = {}, Custprops = {}, pidx = 0, cp = {};\n\tvar comments = [], comment = {};\n\tvar cstys = [], csty;\n\txlmlregex.lastIndex = 0;\n\twhile((Rn = xlmlregex.exec(str))) switch(Rn[3]) {\n\t\tcase 'Data':\n\t\t\tif(state[state.length-1][1]) break;\n\t\t\tif(Rn[1]==='/') parse_xlml_data(str.slice(didx, Rn.index), ss, dtag, state[state.length-1][0]==\"Comment\"?comment:cell, {c:c,r:r}, styles, cstys[c], row, opts);\n\t\t\telse { ss = \"\"; dtag = xlml_parsexmltag(Rn[0]); didx = Rn.index + Rn[0].length; }\n\t\t\tbreak;\n\t\tcase 'Cell':\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif(comments.length > 0) cell.c = comments;\n\t\t\t\tif((!opts.sheetRows || opts.sheetRows > r) && cell.v !== undefined) cursheet[encode_col(c) + encode_row(r)] = cell;\n\t\t\t\tif(cell.HRef) {\n\t\t\t\t\tcell.l = {Target:cell.HRef, tooltip:cell.HRefScreenTip};\n\t\t\t\t\tcell.HRef = cell.HRefScreenTip = undefined;\n\t\t\t\t}\n\t\t\t\tif(cell.MergeAcross || cell.MergeDown) {\n\t\t\t\t\tvar cc = c + (parseInt(cell.MergeAcross,10)|0);\n\t\t\t\t\tvar rr = r + (parseInt(cell.MergeDown,10)|0);\n\t\t\t\t\tmergecells.push({s:{c:c,r:r},e:{c:cc,r:rr}});\n\t\t\t\t}\n\t\t\t\t++c;\n\t\t\t\tif(cell.MergeAcross) c += +cell.MergeAcross;\n\t\t\t} else {\n\t\t\t\tcell = xlml_parsexmltagobj(Rn[0]);\n\t\t\t\tif(cell.Index) c = +cell.Index - 1;\n\t\t\t\tif(c < refguess.s.c) refguess.s.c = c;\n\t\t\t\tif(c > refguess.e.c) refguess.e.c = c;\n\t\t\t\tif(Rn[0].substr(-2) === \"/>\") ++c;\n\t\t\t\tcomments = [];\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'Row':\n\t\t\tif(Rn[1]==='/' || Rn[0].substr(-2) === \"/>\") {\n\t\t\t\tif(r < refguess.s.r) refguess.s.r = r;\n\t\t\t\tif(r > refguess.e.r) refguess.e.r = r;\n\t\t\t\tif(Rn[0].substr(-2) === \"/>\") {\n\t\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t\t}\n\t\t\t\tc = 0; ++r;\n\t\t\t} else {\n\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'Worksheet': /* TODO: read range from FullRows/FullColumns */\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\tsheetnames.push(sheetname);\n\t\t\t\tif(refguess.s.r <= refguess.e.r && refguess.s.c <= refguess.e.c) cursheet[\"!ref\"] = encode_range(refguess);\n\t\t\t\tif(mergecells.length) cursheet[\"!merges\"] = mergecells;\n\t\t\t\tsheets[sheetname] = cursheet;\n\t\t\t} else {\n\t\t\t\trefguess = {s: {r:1000000, c:1000000}, e: {r:0, c:0} };\n\t\t\t\tr = c = 0;\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tsheetname = tmp.Name;\n\t\t\t\tcursheet = {};\n\t\t\t\tmergecells = [];\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'Table':\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\telse if(Rn[0].slice(-2) == \"/>\") break;\n\t\t\telse {\n\t\t\t\ttable = xlml_parsexmltag(Rn[0]);\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\tcstys = [];\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'Style':\n\t\t\tif(Rn[1]==='/') process_style_xlml(styles, stag, opts);\n\t\t\telse stag = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\n\t\tcase 'NumberFormat':\n\t\t\tstag.nf = xlml_parsexmltag(Rn[0]).Format || \"General\";\n\t\t\tbreak;\n\n\t\tcase 'Column':\n\t\t\tif(state[state.length-1][0] !== 'Table') break;\n\t\t\tcsty = xlml_parsexmltag(Rn[0]);\n\t\t\tcstys[(csty.Index-1||cstys.length)] = csty;\n\t\t\tfor(var i = 0; i < +csty.Span; ++i) cstys[cstys.length] = csty;\n\t\t\tbreak;\n\n\t\tcase 'NamedRange': break;\n\t\tcase 'NamedCell': break;\n\t\tcase 'B': break;\n\t\tcase 'I': break;\n\t\tcase 'U': break;\n\t\tcase 'S': break;\n\t\tcase 'Sub': break;\n\t\tcase 'Sup': break;\n\t\tcase 'Span': break;\n\t\tcase 'Border': break;\n\t\tcase 'Alignment': break;\n\t\tcase 'Borders': break;\n\t\tcase 'Font':\n\t\t\tif(Rn[0].substr(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") ss += str.slice(fidx, Rn.index);\n\t\t\telse fidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'Interior':\n\t\t\tif(!opts.cellStyles) break;\n\t\t\tstag.Interior = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\t\tcase 'Protection': break;\n\n\t\tcase 'Author':\n\t\tcase 'Title':\n\t\tcase 'Description':\n\t\tcase 'Created':\n\t\tcase 'Keywords':\n\t\tcase 'Subject':\n\t\tcase 'Category':\n\t\tcase 'Company':\n\t\tcase 'LastAuthor':\n\t\tcase 'LastSaved':\n\t\tcase 'LastPrinted':\n\t\tcase 'Version':\n\t\tcase 'Revision':\n\t\tcase 'TotalTime':\n\t\tcase 'HyperlinkBase':\n\t\tcase 'Manager':\n\t\t\tif(Rn[0].substr(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") xlml_set_prop(Props, Rn[3], str.slice(pidx, Rn.index));\n\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'Paragraphs': break;\n\n\t\tcase 'Styles':\n\t\tcase 'Workbook':\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\telse state.push([Rn[3], false]);\n\t\t\tbreak;\n\n\t\tcase 'Comment':\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\txlml_clean_comment(comment);\n\t\t\t\tcomments.push(comment);\n\t\t\t} else {\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tcomment = {a:tmp.Author};\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'Name': break;\n\n\t\tcase 'ComponentOptions':\n\t\tcase 'DocumentProperties':\n\t\tcase 'CustomDocumentProperties':\n\t\tcase 'OfficeDocumentSettings':\n\t\tcase 'PivotTable':\n\t\tcase 'PivotCache':\n\t\tcase 'Names':\n\t\tcase 'MapInfo':\n\t\tcase 'PageBreaks':\n\t\tcase 'QueryTable':\n\t\tcase 'DataValidation':\n\t\tcase 'AutoFilter':\n\t\tcase 'Sorting':\n\t\tcase 'Schema':\n\t\tcase 'data':\n\t\tcase 'ConditionalFormatting':\n\t\tcase 'SmartTagType':\n\t\tcase 'SmartTags':\n\t\tcase 'ExcelWorkbook':\n\t\tcase 'WorkbookOptions':\n\t\tcase 'WorksheetOptions':\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\tbreak;\n\n\t\tdefault:\n\t\t\tvar seen = true;\n\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t/* OfficeDocumentSettings */\n\t\t\t\tcase 'OfficeDocumentSettings': switch(Rn[3]) {\n\t\t\t\t\tcase 'AllowPNG': break;\n\t\t\t\t\tcase 'RemovePersonalInformation': break;\n\t\t\t\t\tcase 'DownloadComponents': break;\n\t\t\t\t\tcase 'LocationOfComponents': break;\n\t\t\t\t\tcase 'Colors': break;\n\t\t\t\t\tcase 'Color': break;\n\t\t\t\t\tcase 'Index': break;\n\t\t\t\t\tcase 'RGB': break;\n\t\t\t\t\tcase 'PixelsPerInch': break;\n\t\t\t\t\tcase 'TargetScreenSize': break;\n\t\t\t\t\tcase 'ReadOnlyRecommended': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ComponentOptions */\n\t\t\t\tcase 'ComponentOptions': switch(Rn[3]) {\n\t\t\t\t\tcase 'Toolbar': break;\n\t\t\t\t\tcase 'HideOfficeLogo': break;\n\t\t\t\t\tcase 'SpreadsheetAutoFit': break;\n\t\t\t\t\tcase 'Label': break;\n\t\t\t\t\tcase 'Caption': break;\n\t\t\t\t\tcase 'MaxHeight': break;\n\t\t\t\t\tcase 'MaxWidth': break;\n\t\t\t\t\tcase 'NextSheetNumber': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ExcelWorkbook */\n\t\t\t\tcase 'ExcelWorkbook': switch(Rn[3]) {\n\t\t\t\t\tcase 'WindowHeight': break;\n\t\t\t\t\tcase 'WindowWidth': break;\n\t\t\t\t\tcase 'WindowTopX': break;\n\t\t\t\t\tcase 'WindowTopY': break;\n\t\t\t\t\tcase 'TabRatio': break;\n\t\t\t\t\tcase 'ProtectStructure': break;\n\t\t\t\t\tcase 'ProtectWindows': break;\n\t\t\t\t\tcase 'ActiveSheet': break;\n\t\t\t\t\tcase 'DisplayInkNotes': break;\n\t\t\t\t\tcase 'FirstVisibleSheet': break;\n\t\t\t\t\tcase 'SupBook': break;\n\t\t\t\t\tcase 'SheetName': break;\n\t\t\t\t\tcase 'SheetIndex': break;\n\t\t\t\t\tcase 'SheetIndexFirst': break;\n\t\t\t\t\tcase 'SheetIndexLast': break;\n\t\t\t\t\tcase 'Dll': break;\n\t\t\t\t\tcase 'AcceptLabelsInFormulas': break;\n\t\t\t\t\tcase 'DoNotSaveLinkValues': break;\n\t\t\t\t\tcase 'Date1904': break;\n\t\t\t\t\tcase 'Iteration': break;\n\t\t\t\t\tcase 'MaxIterations': break;\n\t\t\t\t\tcase 'MaxChange': break;\n\t\t\t\t\tcase 'Path': break;\n\t\t\t\t\tcase 'Xct': break;\n\t\t\t\t\tcase 'Count': break;\n\t\t\t\t\tcase 'SelectedSheets': break;\n\t\t\t\t\tcase 'Calculation': break;\n\t\t\t\t\tcase 'Uncalced': break;\n\t\t\t\t\tcase 'StartupPrompt': break;\n\t\t\t\t\tcase 'Crn': break;\n\t\t\t\t\tcase 'ExternName': break;\n\t\t\t\t\tcase 'Formula': break;\n\t\t\t\t\tcase 'ColFirst': break;\n\t\t\t\t\tcase 'ColLast': break;\n\t\t\t\t\tcase 'WantAdvise': break;\n\t\t\t\t\tcase 'Boolean': break;\n\t\t\t\t\tcase 'Error': break;\n\t\t\t\t\tcase 'Text': break;\n\t\t\t\t\tcase 'OLE': break;\n\t\t\t\t\tcase 'NoAutoRecover': break;\n\t\t\t\t\tcase 'PublishObjects': break;\n\t\t\t\t\tcase 'DoNotCalculateBeforeSave': break;\n\t\t\t\t\tcase 'Number': break;\n\t\t\t\t\tcase 'RefModeR1C1': break;\n\t\t\t\t\tcase 'EmbedSaveSmartTags': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorkbookOptions */\n\t\t\t\tcase 'WorkbookOptions': switch(Rn[3]) {\n\t\t\t\t\tcase 'OWCVersion': break;\n\t\t\t\t\tcase 'Height': break;\n\t\t\t\t\tcase 'Width': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorksheetOptions */\n\t\t\t\tcase 'WorksheetOptions': switch(Rn[3]) {\n\t\t\t\t\tcase 'Unsynced': break;\n\t\t\t\t\tcase 'Visible': break;\n\t\t\t\t\tcase 'Print': break;\n\t\t\t\t\tcase 'Panes': break;\n\t\t\t\t\tcase 'Scale': break;\n\t\t\t\t\tcase 'Pane': break;\n\t\t\t\t\tcase 'Number': break;\n\t\t\t\t\tcase 'Layout': break;\n\t\t\t\t\tcase 'Header': break;\n\t\t\t\t\tcase 'Footer': break;\n\t\t\t\t\tcase 'PageSetup': break;\n\t\t\t\t\tcase 'PageMargins': break;\n\t\t\t\t\tcase 'Selected': break;\n\t\t\t\t\tcase 'ProtectObjects': break;\n\t\t\t\t\tcase 'EnableSelection': break;\n\t\t\t\t\tcase 'ProtectScenarios': break;\n\t\t\t\t\tcase 'ValidPrinterInfo': break;\n\t\t\t\t\tcase 'HorizontalResolution': break;\n\t\t\t\t\tcase 'VerticalResolution': break;\n\t\t\t\t\tcase 'NumberofCopies': break;\n\t\t\t\t\tcase 'ActiveRow': break;\n\t\t\t\t\tcase 'ActiveCol': break;\n\t\t\t\t\tcase 'ActivePane': break;\n\t\t\t\t\tcase 'TopRowVisible': break;\n\t\t\t\t\tcase 'TopRowBottomPane': break;\n\t\t\t\t\tcase 'LeftColumnVisible': break;\n\t\t\t\t\tcase 'LeftColumnRightPane': break;\n\t\t\t\t\tcase 'FitToPage': break;\n\t\t\t\t\tcase 'RangeSelection': break;\n\t\t\t\t\tcase 'PaperSizeIndex': break;\n\t\t\t\t\tcase 'PageLayoutZoom': break;\n\t\t\t\t\tcase 'PageBreakZoom': break;\n\t\t\t\t\tcase 'FilterOn': break;\n\t\t\t\t\tcase 'DoNotDisplayGridlines': break;\n\t\t\t\t\tcase 'SplitHorizontal': break;\n\t\t\t\t\tcase 'SplitVertical': break;\n\t\t\t\t\tcase 'FreezePanes': break;\n\t\t\t\t\tcase 'FrozenNoSplit': break;\n\t\t\t\t\tcase 'FitWidth': break;\n\t\t\t\t\tcase 'FitHeight': break;\n\t\t\t\t\tcase 'CommentsLayout': break;\n\t\t\t\t\tcase 'Zoom': break;\n\t\t\t\t\tcase 'LeftToRight': break;\n\t\t\t\t\tcase 'Gridlines': break;\n\t\t\t\t\tcase 'AllowSort': break;\n\t\t\t\t\tcase 'AllowFilter': break;\n\t\t\t\t\tcase 'AllowInsertRows': break;\n\t\t\t\t\tcase 'AllowDeleteRows': break;\n\t\t\t\t\tcase 'AllowInsertCols': break;\n\t\t\t\t\tcase 'AllowDeleteCols': break;\n\t\t\t\t\tcase 'AllowInsertHyperlinks': break;\n\t\t\t\t\tcase 'AllowFormatCells': break;\n\t\t\t\t\tcase 'AllowSizeCols': break;\n\t\t\t\t\tcase 'AllowSizeRows': break;\n\t\t\t\t\tcase 'NoSummaryRowsBelowDetail': break;\n\t\t\t\t\tcase 'TabColorIndex': break;\n\t\t\t\t\tcase 'DoNotDisplayHeadings': break;\n\t\t\t\t\tcase 'ShowPageLayoutZoom': break;\n\t\t\t\t\tcase 'NoSummaryColumnsRightDetail': break;\n\t\t\t\t\tcase 'BlackAndWhite': break;\n\t\t\t\t\tcase 'DoNotDisplayZeros': break;\n\t\t\t\t\tcase 'DisplayPageBreak': break;\n\t\t\t\t\tcase 'RowColHeadings': break;\n\t\t\t\t\tcase 'DoNotDisplayOutline': break;\n\t\t\t\t\tcase 'NoOrientation': break;\n\t\t\t\t\tcase 'AllowUsePivotTables': break;\n\t\t\t\t\tcase 'ZeroHeight': break;\n\t\t\t\t\tcase 'ViewableRange': break;\n\t\t\t\t\tcase 'Selection': break;\n\t\t\t\t\tcase 'ProtectContents': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PivotTable */\n\t\t\t\tcase 'PivotTable': case 'PivotCache': switch(Rn[3]) {\n\t\t\t\t\tcase 'ImmediateItemsOnDrop': break;\n\t\t\t\t\tcase 'ShowPageMultipleItemLabel': break;\n\t\t\t\t\tcase 'CompactRowIndent': break;\n\t\t\t\t\tcase 'Location': break;\n\t\t\t\t\tcase 'PivotField': break;\n\t\t\t\t\tcase 'Orientation': break;\n\t\t\t\t\tcase 'LayoutForm': break;\n\t\t\t\t\tcase 'LayoutSubtotalLocation': break;\n\t\t\t\t\tcase 'LayoutCompactRow': break;\n\t\t\t\t\tcase 'Position': break;\n\t\t\t\t\tcase 'PivotItem': break;\n\t\t\t\t\tcase 'DataType': break;\n\t\t\t\t\tcase 'DataField': break;\n\t\t\t\t\tcase 'SourceName': break;\n\t\t\t\t\tcase 'ParentField': break;\n\t\t\t\t\tcase 'PTLineItems': break;\n\t\t\t\t\tcase 'PTLineItem': break;\n\t\t\t\t\tcase 'CountOfSameItems': break;\n\t\t\t\t\tcase 'Item': break;\n\t\t\t\t\tcase 'ItemType': break;\n\t\t\t\t\tcase 'PTSource': break;\n\t\t\t\t\tcase 'CacheIndex': break;\n\t\t\t\t\tcase 'ConsolidationReference': break;\n\t\t\t\t\tcase 'FileName': break;\n\t\t\t\t\tcase 'Reference': break;\n\t\t\t\t\tcase 'NoColumnGrand': break;\n\t\t\t\t\tcase 'NoRowGrand': break;\n\t\t\t\t\tcase 'BlankLineAfterItems': break;\n\t\t\t\t\tcase 'Hidden': break;\n\t\t\t\t\tcase 'Subtotal': break;\n\t\t\t\t\tcase 'BaseField': break;\n\t\t\t\t\tcase 'MapChildItems': break;\n\t\t\t\t\tcase 'Function': break;\n\t\t\t\t\tcase 'RefreshOnFileOpen': break;\n\t\t\t\t\tcase 'PrintSetTitles': break;\n\t\t\t\t\tcase 'MergeLabels': break;\n\t\t\t\t\tcase 'DefaultVersion': break;\n\t\t\t\t\tcase 'RefreshName': break;\n\t\t\t\t\tcase 'RefreshDate': break;\n\t\t\t\t\tcase 'RefreshDateCopy': break;\n\t\t\t\t\tcase 'VersionLastRefresh': break;\n\t\t\t\t\tcase 'VersionLastUpdate': break;\n\t\t\t\t\tcase 'VersionUpdateableMin': break;\n\t\t\t\t\tcase 'VersionRefreshableMin': break;\n\t\t\t\t\tcase 'Calculation': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PageBreaks */\n\t\t\t\tcase 'PageBreaks': switch(Rn[3]) {\n\t\t\t\t\tcase 'ColBreaks': break;\n\t\t\t\t\tcase 'ColBreak': break;\n\t\t\t\t\tcase 'RowBreaks': break;\n\t\t\t\t\tcase 'RowBreak': break;\n\t\t\t\t\tcase 'ColStart': break;\n\t\t\t\t\tcase 'ColEnd': break;\n\t\t\t\t\tcase 'RowEnd': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* AutoFilter */\n\t\t\t\tcase 'AutoFilter': switch(Rn[3]) {\n\t\t\t\t\tcase 'AutoFilterColumn': break;\n\t\t\t\t\tcase 'AutoFilterCondition': break;\n\t\t\t\t\tcase 'AutoFilterAnd': break;\n\t\t\t\t\tcase 'AutoFilterOr': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* QueryTable */\n\t\t\t\tcase 'QueryTable': switch(Rn[3]) {\n\t\t\t\t\tcase 'Id': break;\n\t\t\t\t\tcase 'AutoFormatFont': break;\n\t\t\t\t\tcase 'AutoFormatPattern': break;\n\t\t\t\t\tcase 'QuerySource': break;\n\t\t\t\t\tcase 'QueryType': break;\n\t\t\t\t\tcase 'EnableRedirections': break;\n\t\t\t\t\tcase 'RefreshedInXl9': break;\n\t\t\t\t\tcase 'URLString': break;\n\t\t\t\t\tcase 'HTMLTables': break;\n\t\t\t\t\tcase 'Connection': break;\n\t\t\t\t\tcase 'CommandText': break;\n\t\t\t\t\tcase 'RefreshInfo': break;\n\t\t\t\t\tcase 'NoTitles': break;\n\t\t\t\t\tcase 'NextId': break;\n\t\t\t\t\tcase 'ColumnInfo': break;\n\t\t\t\t\tcase 'OverwriteCells': break;\n\t\t\t\t\tcase 'DoNotPromptForFile': break;\n\t\t\t\t\tcase 'TextWizardSettings': break;\n\t\t\t\t\tcase 'Source': break;\n\t\t\t\t\tcase 'Number': break;\n\t\t\t\t\tcase 'Decimal': break;\n\t\t\t\t\tcase 'ThousandSeparator': break;\n\t\t\t\t\tcase 'TrailingMinusNumbers': break;\n\t\t\t\t\tcase 'FormatSettings': break;\n\t\t\t\t\tcase 'FieldType': break;\n\t\t\t\t\tcase 'Delimiters': break;\n\t\t\t\t\tcase 'Tab': break;\n\t\t\t\t\tcase 'Comma': break;\n\t\t\t\t\tcase 'AutoFormatName': break;\n\t\t\t\t\tcase 'VersionLastEdit': break;\n\t\t\t\t\tcase 'VersionLastRefresh': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* Sorting */\n\t\t\t\tcase 'Sorting':\n\t\t\t\t/* ConditionalFormatting */\n\t\t\t\tcase 'ConditionalFormatting':\n\t\t\t\t/* DataValidation */\n\t\t\t\tcase 'DataValidation': switch(Rn[3]) {\n\t\t\t\t\tcase 'Range': break;\n\t\t\t\t\tcase 'Type': break;\n\t\t\t\t\tcase 'Min': break;\n\t\t\t\t\tcase 'Max': break;\n\t\t\t\t\tcase 'Sort': break;\n\t\t\t\t\tcase 'Descending': break;\n\t\t\t\t\tcase 'Order': break;\n\t\t\t\t\tcase 'CaseSensitive': break;\n\t\t\t\t\tcase 'Value': break;\n\t\t\t\t\tcase 'ErrorStyle': break;\n\t\t\t\t\tcase 'ErrorMessage': break;\n\t\t\t\t\tcase 'ErrorTitle': break;\n\t\t\t\t\tcase 'CellRangeList': break;\n\t\t\t\t\tcase 'InputMessage': break;\n\t\t\t\t\tcase 'InputTitle': break;\n\t\t\t\t\tcase 'ComboHide': break;\n\t\t\t\t\tcase 'InputHide': break;\n\t\t\t\t\tcase 'Condition': break;\n\t\t\t\t\tcase 'Qualifier': break;\n\t\t\t\t\tcase 'UseBlank': break;\n\t\t\t\t\tcase 'Value1': break;\n\t\t\t\t\tcase 'Value2': break;\n\t\t\t\t\tcase 'Format': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* MapInfo (schema) */\n\t\t\t\tcase 'MapInfo': case 'Schema': case 'data': switch(Rn[3]) {\n\t\t\t\t\tcase 'Map': break;\n\t\t\t\t\tcase 'Entry': break;\n\t\t\t\t\tcase 'Range': break;\n\t\t\t\t\tcase 'XPath': break;\n\t\t\t\t\tcase 'Field': break;\n\t\t\t\t\tcase 'XSDType': break;\n\t\t\t\t\tcase 'FilterOn': break;\n\t\t\t\t\tcase 'Aggregate': break;\n\t\t\t\t\tcase 'ElementType': break;\n\t\t\t\t\tcase 'AttributeType': break;\n\t\t\t\t/* These are from xsd (XML Schema Definition) */\n\t\t\t\t\tcase 'schema':\n\t\t\t\t\tcase 'element':\n\t\t\t\t\tcase 'complexType':\n\t\t\t\t\tcase 'datatype':\n\t\t\t\t\tcase 'all':\n\t\t\t\t\tcase 'attribute':\n\t\t\t\t\tcase 'extends': break;\n\n\t\t\t\t\tcase 'row': break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* SmartTags (can be anything) */\n\t\t\t\tcase 'SmartTags': break;\n\n\t\t\t\tdefault: seen = false; break;\n\t\t\t}\n\t\t\tif(seen) break;\n\t\t\t/* CustomDocumentProperties */\n\t\t\tif(!state[state.length-1][1]) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t\t\tif(state[state.length-1][0]==='CustomDocumentProperties') {\n\t\t\t\tif(Rn[0].substr(-2) === \"/>\") break;\n\t\t\t\telse if(Rn[1]===\"/\") xlml_set_custprop(Custprops, Rn, cp, str.slice(pidx, Rn.index));\n\t\t\t\telse { cp = Rn; pidx = Rn.index + Rn[0].length; }\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(opts.WTF) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t}\n\tvar out = {};\n\tif(!opts.bookSheets && !opts.bookProps) out.Sheets = sheets;\n\tout.SheetNames = sheetnames;\n\tout.SSF = SSF.get_table();\n\tout.Props = Props;\n\tout.Custprops = Custprops;\n\treturn out;\n}\n\nfunction parse_xlml(data, opts) {\n\tfix_read_opts(opts=opts||{});\n\tswitch(opts.type||\"base64\") {\n\t\tcase \"base64\": return parse_xlml_xml(Base64.decode(data), opts);\n\t\tcase \"binary\": case \"buffer\": case \"file\": return parse_xlml_xml(data, opts);\n\t\tcase \"array\": return parse_xlml_xml(data.map(_chr).join(\"\"), opts);\n\t}\n}\n\nfunction write_xlml(wb, opts) { }\n\n/* [MS-OLEDS] 2.3.8 CompObjStream */\nfunction parse_compobj(obj) {\n\tvar v = {};\n\tvar o = obj.content;\n\n\t/* [MS-OLEDS] 2.3.7 CompObjHeader -- All fields MUST be ignored */\n\tvar l = 28, m;\n\tm = __lpstr(o, l);\n\tl += 4 + __readUInt32LE(o,l);\n\tv.UserType = m;\n\n\t/* [MS-OLEDS] 2.3.1 ClipboardFormatOrAnsiString */\n\tm = __readUInt32LE(o,l); l+= 4;\n\tswitch(m) {\n\t\tcase 0x00000000: break;\n\t\tcase 0xffffffff: case 0xfffffffe: l+=4; break;\n\t\tdefault:\n\t\t\tif(m > 0x190) throw new Error(\"Unsupported Clipboard: \" + m.toString(16));\n\t\t\tl += m;\n\t}\n\n\tm = __lpstr(o, l); l += m.length === 0 ? 0 : 5 + m.length; v.Reserved1 = m;\n\n\tif((m = __readUInt32LE(o,l)) !== 0x71b2e9f4) return v;\n\tthrow \"Unsupported Unicode Extension\";\n}\n\n/* 2.4.58 Continue logic */\nfunction slurp(R, blob, length, opts) {\n\tvar l = length;\n\tvar bufs = [];\n\tvar d = blob.slice(blob.l,blob.l+l);\n\tif(opts && opts.enc && opts.enc.insitu_decrypt) switch(R.n) {\n\tcase 'BOF': case 'FilePass': case 'FileLock': case 'InterfaceHdr': case 'RRDInfo': case 'RRDHead': case 'UsrExcl': break;\n\tdefault:\n\t\tif(d.length === 0) break;\n\t\topts.enc.insitu_decrypt(d);\n\t}\n\tbufs.push(d);\n\tblob.l += l;\n\tvar next = (XLSRecordEnum[__readUInt16LE(blob,blob.l)]);\n\twhile(next != null && next.n === 'Continue') {\n\t\tl = __readUInt16LE(blob,blob.l+2);\n\t\tbufs.push(blob.slice(blob.l+4,blob.l+4+l));\n\t\tblob.l += 4+l;\n\t\tnext = (XLSRecordEnum[__readUInt16LE(blob, blob.l)]);\n\t}\n\tvar b = bconcat(bufs);\n\tprep_blob(b, 0);\n\tvar ll = 0; b.lens = [];\n\tfor(var j = 0; j < bufs.length; ++j) { b.lens.push(ll); ll += bufs[j].length; }\n\treturn R.f(b, b.length, opts);\n}\n\nfunction safe_format_xf(p, opts, date1904) {\n\tif(!p.XF) return;\n\ttry {\n\t\tvar fmtid = p.XF.ifmt||0;\n\t\tif(p.t === 'e') { p.w = p.w || BErr[p.v]; }\n\t\telse if(fmtid === 0) {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = SSF._general_int(p.v);\n\t\t\t\telse p.w = SSF._general_num(p.v);\n\t\t\t}\n\t\t\telse p.w = SSF._general(p.v);\n\t\t}\n\t\telse p.w = SSF.format(fmtid,p.v, {date1904:date1904||false});\n\t\tif(opts.cellNF) p.z = SSF._table[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n}\n\nfunction make_cell(val, ixfe, t) {\n\treturn {v:val, ixfe:ixfe, t:t};\n}\n\n// 2.3.2\nfunction parse_workbook(blob, options) {\n\tvar wb = {opts:{}};\n\tvar Sheets = {};\n\tvar out = {};\n\tvar Directory = {};\n\tvar found_sheet = false;\n\tvar range = {};\n\tvar last_formula = null;\n\tvar sst = [];\n\tvar cur_sheet = \"\";\n\tvar Preamble = {};\n\tvar lastcell, last_cell, cc, cmnt, rng, rngC, rngR;\n\tvar shared_formulae = {};\n\tvar array_formulae = []; /* TODO: something more clever */\n\tvar temp_val;\n\tvar country;\n\tvar cell_valid = true;\n\tvar XFs = []; /* XF records */\n\tvar palette = [];\n\tvar get_rgb = function getrgb(icv) {\n\t\tif(icv < 8) return XLSIcv[icv];\n\t\tif(icv < 64) return palette[icv-8] || XLSIcv[icv];\n\t\treturn XLSIcv[icv];\n\t};\n\tvar process_cell_style = function pcs(cell, line) {\n\t\tvar xfd = line.XF.data;\n\t\tif(!xfd || !xfd.patternType) return;\n\t\tline.s = {};\n\t\tline.s.patternType = xfd.patternType;\n\t\tvar t;\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvFore)))) { line.s.fgColor = {rgb:t}; }\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvBack)))) { line.s.bgColor = {rgb:t}; }\n\t};\n\tvar addcell = function addcell(cell, line, options) {\n\t\tif(!cell_valid) return;\n\t\tif(options.cellStyles && line.XF && line.XF.data) process_cell_style(cell, line);\n\t\tlastcell = cell;\n\t\tlast_cell = encode_cell(cell);\n\t\tif(range.s) {\n\t\t\tif(cell.r < range.s.r) range.s.r = cell.r;\n\t\t\tif(cell.c < range.s.c) range.s.c = cell.c;\n\t\t}\n\t\tif(range.e) {\n\t\t\tif(cell.r + 1 > range.e.r) range.e.r = cell.r + 1;\n\t\t\tif(cell.c + 1 > range.e.c) range.e.c = cell.c + 1;\n\t\t}\n\t\tif(options.sheetRows && lastcell.r >= options.sheetRows) cell_valid = false;\n\t\telse out[last_cell] = line;\n\t};\n\tvar opts = {\n\t\tenc: false, // encrypted\n\t\tsbcch: 0, // cch in the preceding SupBook\n\t\tsnames: [], // sheetnames\n\t\tsharedf: shared_formulae, // shared formulae by address\n\t\tarrayf: array_formulae, // array formulae array\n\t\trrtabid: [], // RRTabId\n\t\tlastuser: \"\", // Last User from WriteAccess\n\t\tbiff: 8, // BIFF version\n\t\tcodepage: 0, // CP from CodePage record\n\t\twinlocked: 0, // fLockWn from WinProtect\n\t\twtf: false\n\t};\n\tif(options.password) opts.password = options.password;\n\tvar mergecells = [];\n\tvar objects = [];\n\tvar supbooks = [[]]; // 1-indexed, will hold extern names\n\tvar sbc = 0, sbci = 0, sbcli = 0;\n\tsupbooks.SheetNames = opts.snames;\n\tsupbooks.sharedf = opts.sharedf;\n\tsupbooks.arrayf = opts.arrayf;\n\tvar last_Rn = '';\n\tvar file_depth = 0; /* TODO: make a real stack */\n\n\t/* explicit override for some broken writers */\n\topts.codepage = 1200;\n\tset_cp(1200);\n\n\twhile(blob.l < blob.length - 1) {\n\t\tvar s = blob.l;\n\t\tvar RecordType = blob.read_shift(2);\n\t\tif(RecordType === 0 && last_Rn === 'EOF') break;\n\t\tvar length = (blob.l === blob.length ? 0 : blob.read_shift(2)), y;\n\t\tvar R = XLSRecordEnum[RecordType];\n\t\tif(R && R.f) {\n\t\t\tif(options.bookSheets) {\n\t\t\t\tif(last_Rn === 'BoundSheet8' && R.n !== 'BoundSheet8') break;\n\t\t\t}\n\t\t\tlast_Rn = R.n;\n\t\t\tif(R.r === 2 || R.r == 12) {\n\t\t\t\tvar rt = blob.read_shift(2); length -= 2;\n\t\t\t\tif(!opts.enc && rt !== RecordType) throw \"rt mismatch\";\n\t\t\t\tif(R.r == 12){ blob.l += 10; length -= 10; } // skip FRT\n\t\t\t}\n\t\t\t//console.error(R,blob.l,length,blob.length);\n\t\t\tvar val;\n\t\t\tif(R.n === 'EOF') val = R.f(blob, length, opts);\n\t\t\telse val = slurp(R, blob, length, opts);\n\t\t\tvar Rn = R.n;\n\t\t\t/* BIFF5 overrides */\n\t\t\tif(opts.biff === 5 || opts.biff === 2) switch(Rn) {\n\t\t\t\tcase 'Lbl': Rn = 'Label'; break;\n\t\t\t}\n\t\t\t/* nested switch statements to workaround V8 128 limit */\n\t\t\tswitch(Rn) {\n\t\t\t\t/* Workbook Options */\n\t\t\t\tcase 'Date1904': wb.opts.Date1904 = val; break;\n\t\t\t\tcase 'WriteProtect': wb.opts.WriteProtect = true; break;\n\t\t\t\tcase 'FilePass':\n\t\t\t\t\tif(!opts.enc) blob.l = 0;\n\t\t\t\t\topts.enc = val;\n\t\t\t\t\tif(opts.WTF) console.error(val);\n\t\t\t\t\tif(!options.password) throw new Error(\"File is password-protected\");\n\t\t\t\t\tif(val.Type !== 0) throw new Error(\"Encryption scheme unsupported\");\n\t\t\t\t\tif(!val.valid) throw new Error(\"Password is incorrect\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'WriteAccess': opts.lastuser = val; break;\n\t\t\t\tcase 'FileSharing': break; //TODO\n\t\t\t\tcase 'CodePage':\n\t\t\t\t\t/* overrides based on test cases */\n\t\t\t\t\tif(val === 0x5212) val = 1200;\n\t\t\t\t\telse if(val === 0x8001) val = 1252;\n\t\t\t\t\topts.codepage = val;\n\t\t\t\t\tset_cp(val);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'RRTabId': opts.rrtabid = val; break;\n\t\t\t\tcase 'WinProtect': opts.winlocked = val; break;\n\t\t\t\tcase 'Template': break; // TODO\n\t\t\t\tcase 'RefreshAll': wb.opts.RefreshAll = val; break;\n\t\t\t\tcase 'BookBool': break; // TODO\n\t\t\t\tcase 'UsesELFs': /* if(val) console.error(\"Unsupported ELFs\"); */ break;\n\t\t\t\tcase 'MTRSettings': {\n\t\t\t\t\tif(val[0] && val[1]) throw \"Unsupported threads: \" + val;\n\t\t\t\t} break; // TODO: actually support threads\n\t\t\t\tcase 'CalcCount': wb.opts.CalcCount = val; break;\n\t\t\t\tcase 'CalcDelta': wb.opts.CalcDelta = val; break;\n\t\t\t\tcase 'CalcIter': wb.opts.CalcIter = val; break;\n\t\t\t\tcase 'CalcMode': wb.opts.CalcMode = val; break;\n\t\t\t\tcase 'CalcPrecision': wb.opts.CalcPrecision = val; break;\n\t\t\t\tcase 'CalcSaveRecalc': wb.opts.CalcSaveRecalc = val; break;\n\t\t\t\tcase 'CalcRefMode': opts.CalcRefMode = val; break; // TODO: implement R1C1\n\t\t\t\tcase 'Uncalced': break;\n\t\t\t\tcase 'ForceFullCalculation': wb.opts.FullCalc = val; break;\n\t\t\t\tcase 'WsBool': break; // TODO\n\t\t\t\tcase 'XF': XFs.push(val); break;\n\t\t\t\tcase 'ExtSST': break; // TODO\n\t\t\t\tcase 'BookExt': break; // TODO\n\t\t\t\tcase 'RichTextStream': break;\n\t\t\t\tcase 'BkHim': break;\n\n\t\t\t\tcase 'SupBook': supbooks[++sbc] = [val]; sbci = 0; break;\n\t\t\t\tcase 'ExternName': supbooks[sbc][++sbci] = val; break;\n\t\t\t\tcase 'Index': break; // TODO\n\t\t\t\tcase 'Lbl': supbooks[0][++sbcli] = val; break;\n\t\t\t\tcase 'ExternSheet': supbooks[sbc] = supbooks[sbc].concat(val); sbci += val.length; break;\n\n\t\t\t\tcase 'Protect': out[\"!protect\"] = val; break; /* for sheet or book */\n\t\t\t\tcase 'Password': if(val !== 0 && opts.WTF) console.error(\"Password verifier: \" + val); break;\n\t\t\t\tcase 'Prot4Rev': case 'Prot4RevPass': break; /*TODO: Revision Control*/\n\n\t\t\t\tcase 'BoundSheet8': {\n\t\t\t\t\tDirectory[val.pos] = val;\n\t\t\t\t\topts.snames.push(val.name);\n\t\t\t\t} break;\n\t\t\t\tcase 'EOF': {\n\t\t\t\t\tif(--file_depth) break;\n\t\t\t\t\tif(range.e) {\n\t\t\t\t\t\tout[\"!range\"] = range;\n\t\t\t\t\t\tif(range.e.r > 0 && range.e.c > 0) {\n\t\t\t\t\t\t\trange.e.r--; range.e.c--;\n\t\t\t\t\t\t\tout[\"!ref\"] = encode_range(range);\n\t\t\t\t\t\t\trange.e.r++; range.e.c++;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(mergecells.length > 0) out[\"!merges\"] = mergecells;\n\t\t\t\t\t\tif(objects.length > 0) out[\"!objects\"] = objects;\n\t\t\t\t\t}\n\t\t\t\t\tif(cur_sheet === \"\") Preamble = out; else Sheets[cur_sheet] = out;\n\t\t\t\t\tout = {};\n\t\t\t\t} break;\n\t\t\t\tcase 'BOF': {\n\t\t\t\t\tif(opts.biff !== 8);\n\t\t\t\t\telse if(val.BIFFVer === 0x0500) opts.biff = 5;\n\t\t\t\t\telse if(val.BIFFVer === 0x0002) opts.biff = 2;\n\t\t\t\t\telse if(val.BIFFVer === 0x0007) opts.biff = 2;\n\t\t\t\t\tif(file_depth++) break;\n\t\t\t\t\tcell_valid = true;\n\t\t\t\t\tout = {};\n\t\t\t\t\tif(opts.biff === 2) {\n\t\t\t\t\t\tif(cur_sheet === \"\") cur_sheet = \"Sheet1\";\n\t\t\t\t\t\trange = {s:{r:0,c:0},e:{r:0,c:0}};\n\t\t\t\t\t}\n\t\t\t\t\telse cur_sheet = (Directory[s] || {name:\"\"}).name;\n\t\t\t\t\tmergecells = [];\n\t\t\t\t\tobjects = [];\n\t\t\t\t} break;\n\t\t\t\tcase 'Number': case 'BIFF2NUM': {\n\t\t\t\t\ttemp_val = {ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.val, t:'n'};\n\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 'BoolErr': {\n\t\t\t\t\ttemp_val = {ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.val, t:val.t};\n\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 'RK': {\n\t\t\t\t\ttemp_val = {ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.rknum, t:'n'};\n\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 'MulRk': {\n\t\t\t\t\tfor(var j = val.c; j <= val.C; ++j) {\n\t\t\t\t\t\tvar ixfe = val.rkrec[j-val.c][0];\n\t\t\t\t\t\ttemp_val= {ixfe:ixfe, XF:XFs[ixfe], v:val.rkrec[j-val.c][1], t:'n'};\n\t\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell({c:j, r:val.r}, temp_val, options);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 'Formula': {\n\t\t\t\t\tswitch(val.val) {\n\t\t\t\t\t\tcase 'String': last_formula = val; break;\n\t\t\t\t\t\tcase 'Array Formula': throw \"Array Formula unsupported\";\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\ttemp_val = {v:val.val, ixfe:val.cell.ixfe, t:val.tt};\n\t\t\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\t\t\tif(options.cellFormula) temp_val.f = \"=\"+stringify_formula(val.formula,range,val.cell,supbooks, opts);\n\t\t\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\t\taddcell(val.cell, temp_val, options);\n\t\t\t\t\t\t\tlast_formula = val;\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 'String': {\n\t\t\t\t\tif(last_formula) {\n\t\t\t\t\t\tlast_formula.val = val;\n\t\t\t\t\t\ttemp_val = {v:last_formula.val, ixfe:last_formula.cell.ixfe, t:'s'};\n\t\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\t\tif(options.cellFormula) temp_val.f = \"=\"+stringify_formula(last_formula.formula, range, last_formula.cell, supbooks, opts);\n\t\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell(last_formula.cell, temp_val, options);\n\t\t\t\t\t\tlast_formula = null;\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 'Array': {\n\t\t\t\t\tarray_formulae.push(val);\n\t\t\t\t} break;\n\t\t\t\tcase 'ShrFmla': {\n\t\t\t\t\tif(!cell_valid) break;\n\t\t\t\t\t//if(options.cellFormula) out[last_cell].f = stringify_formula(val[0], range, lastcell, supbooks, opts);\n\t\t\t\t\t/* TODO: capture range */\n\t\t\t\t\tshared_formulae[encode_cell(last_formula.cell)]= val[0];\n\t\t\t\t} break;\n\t\t\t\tcase 'LabelSst':\n\t\t\t\t\t//temp_val={v:sst[val.isst].t, ixfe:val.ixfe, t:'s'};\n\t\t\t\t\ttemp_val=make_cell(sst[val.isst].t, val.ixfe, 's');\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'Label': case 'BIFF2STR':\n\t\t\t\t\t/* Some writers erroneously write Label */\n\t\t\t\t\ttemp_val=make_cell(val.val, val.ixfe, 's');\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(temp_val.XF) safe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'Dimensions': {\n\t\t\t\t\tif(file_depth === 1) range = val; /* TODO: stack */\n\t\t\t\t} break;\n\t\t\t\tcase 'SST': {\n\t\t\t\t\tsst = val;\n\t\t\t\t} break;\n\t\t\t\tcase 'Format': { /* val = [id, fmt] */\n\t\t\t\t\tSSF.load(val[1], val[0]);\n\t\t\t\t} break;\n\n\t\t\t\tcase 'MergeCells': mergecells = mergecells.concat(val); break;\n\n\t\t\t\tcase 'Obj': objects[val.cmo[0]] = opts.lastobj = val; break;\n\t\t\t\tcase 'TxO': opts.lastobj.TxO = val; break;\n\n\t\t\t\tcase 'HLink': {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC)\n\t\t\t\t\t\t\tif(out[encode_cell({c:rngC,r:rngR})])\n\t\t\t\t\t\t\t\tout[encode_cell({c:rngC,r:rngR})].l = val[1];\n\t\t\t\t} break;\n\t\t\t\tcase 'HLinkTooltip': {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC)\n\t\t\t\t\t\t\tif(out[encode_cell({c:rngC,r:rngR})])\n\t\t\t\t\t\t\t\tout[encode_cell({c:rngC,r:rngR})].l.tooltip = val[1];\n\t\t\t\t} break;\n\n\t\t\t\t/* Comments */\n\t\t\t\tcase 'Note': {\n\t\t\t\t\tif(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */\n\t\t\t\t\tcc = out[encode_cell(val[0])];\n\t\t\t\t\tvar noteobj = objects[val[2]];\n\t\t\t\t\tif(!cc) break;\n\t\t\t\t\tif(!cc.c) cc.c = [];\n\t\t\t\t\tcmnt = {a:val[1],t:noteobj.TxO.t};\n\t\t\t\t\tcc.c.push(cmnt);\n\t\t\t\t} break;\n\n\t\t\t\tdefault: switch(R.n) { /* nested */\n\t\t\t\tcase 'ClrtClient': break;\n\t\t\t\tcase 'XFExt': update_xfext(XFs[val.ixfe], val.ext); break;\n\n\t\t\t\tcase 'NameCmt': break;\n\t\t\t\tcase 'Header': break; // TODO\n\t\t\t\tcase 'Footer': break; // TODO\n\t\t\t\tcase 'HCenter': break; // TODO\n\t\t\t\tcase 'VCenter': break; // TODO\n\t\t\t\tcase 'Pls': break; // TODO\n\t\t\t\tcase 'Setup': break; // TODO\n\t\t\t\tcase 'DefColWidth': break; // TODO\n\t\t\t\tcase 'GCW': break;\n\t\t\t\tcase 'LHRecord': break;\n\t\t\t\tcase 'ColInfo': break; // TODO\n\t\t\t\tcase 'Row': break; // TODO\n\t\t\t\tcase 'DBCell': break; // TODO\n\t\t\t\tcase 'MulBlank': break; // TODO\n\t\t\t\tcase 'EntExU2': break; // TODO\n\t\t\t\tcase 'SxView': break; // TODO\n\t\t\t\tcase 'Sxvd': break; // TODO\n\t\t\t\tcase 'SXVI': break; // TODO\n\t\t\t\tcase 'SXVDEx': break; // TODO\n\t\t\t\tcase 'SxIvd': break; // TODO\n\t\t\t\tcase 'SXDI': break; // TODO\n\t\t\t\tcase 'SXLI': break; // TODO\n\t\t\t\tcase 'SXEx': break; // TODO\n\t\t\t\tcase 'QsiSXTag': break; // TODO\n\t\t\t\tcase 'Selection': break;\n\t\t\t\tcase 'Feat': break;\n\t\t\t\tcase 'FeatHdr': case 'FeatHdr11': break;\n\t\t\t\tcase 'Feature11': case 'Feature12': case 'List12': break;\n\t\t\t\tcase 'Blank': break;\n\t\t\t\tcase 'Country': country = val; break;\n\t\t\t\tcase 'RecalcId': break;\n\t\t\t\tcase 'DefaultRowHeight': case 'DxGCol': break; // TODO: htmlify\n\t\t\t\tcase 'Fbi': case 'Fbi2': case 'GelFrame': break;\n\t\t\t\tcase 'Font': break; // TODO\n\t\t\t\tcase 'XFCRC': break; // TODO\n\t\t\t\tcase 'Style': break; // TODO\n\t\t\t\tcase 'StyleExt': break; // TODO\n\t\t\t\tcase 'Palette': palette = val; break; // TODO\n\t\t\t\tcase 'Theme': break; // TODO\n\t\t\t\t/* Protection */\n\t\t\t\tcase 'ScenarioProtect': break;\n\t\t\t\tcase 'ObjProtect': break;\n\n\t\t\t\t/* Conditional Formatting */\n\t\t\t\tcase 'CondFmt12': break;\n\n\t\t\t\t/* Table */\n\t\t\t\tcase 'Table': break; // TODO\n\t\t\t\tcase 'TableStyles': break; // TODO\n\t\t\t\tcase 'TableStyle': break; // TODO\n\t\t\t\tcase 'TableStyleElement': break; // TODO\n\n\t\t\t\t/* PivotTable */\n\t\t\t\tcase 'SXStreamID': break; // TODO\n\t\t\t\tcase 'SXVS': break; // TODO\n\t\t\t\tcase 'DConRef': break; // TODO\n\t\t\t\tcase 'SXAddl': break; // TODO\n\t\t\t\tcase 'DConBin': break; // TODO\n\t\t\t\tcase 'DConName': break; // TODO\n\t\t\t\tcase 'SXPI': break; // TODO\n\t\t\t\tcase 'SxFormat': break; // TODO\n\t\t\t\tcase 'SxSelect': break; // TODO\n\t\t\t\tcase 'SxRule': break; // TODO\n\t\t\t\tcase 'SxFilt': break; // TODO\n\t\t\t\tcase 'SxItm': break; // TODO\n\t\t\t\tcase 'SxDXF': break; // TODO\n\n\t\t\t\t/* Scenario Manager */\n\t\t\t\tcase 'ScenMan': break;\n\n\t\t\t\t/* Data Consolidation */\n\t\t\t\tcase 'DCon': break;\n\n\t\t\t\t/* Watched Cell */\n\t\t\t\tcase 'CellWatch': break;\n\n\t\t\t\t/* Print Settings */\n\t\t\t\tcase 'PrintRowCol': break;\n\t\t\t\tcase 'PrintGrid': break;\n\t\t\t\tcase 'PrintSize': break;\n\n\t\t\t\tcase 'XCT': break;\n\t\t\t\tcase 'CRN': break;\n\n\t\t\t\tcase 'Scl': {\n\t\t\t\t\t//console.log(\"Zoom Level:\", val[0]/val[1],val);\n\t\t\t\t} break;\n\t\t\t\tcase 'SheetExt': {\n\n\t\t\t\t} break;\n\t\t\t\tcase 'SheetExtOptional': {\n\n\t\t\t\t} break;\n\n\t\t\t\t/* VBA */\n\t\t\t\tcase 'ObNoMacros': {\n\n\t\t\t\t} break;\n\t\t\t\tcase 'ObProj': {\n\n\t\t\t\t} break;\n\t\t\t\tcase 'CodeName': {\n\n\t\t\t\t} break;\n\t\t\t\tcase 'GUIDTypeLib': {\n\n\t\t\t\t} break;\n\n\t\t\t\tcase 'WOpt': break; // TODO: WTF?\n\t\t\t\tcase 'PhoneticInfo': break;\n\n\t\t\t\tcase 'OleObjectSize': break;\n\n\t\t\t\t/* Differential Formatting */\n\t\t\t\tcase 'DXF': case 'DXFN': case 'DXFN12': case 'DXFN12List': case 'DXFN12NoCB': break;\n\n\t\t\t\t/* Data Validation */\n\t\t\t\tcase 'Dv': case 'DVal': break;\n\n\t\t\t\t/* Data Series */\n\t\t\t\tcase 'BRAI': case 'Series': case 'SeriesText': break;\n\n\t\t\t\t/* Data Connection */\n\t\t\t\tcase 'DConn': break;\n\t\t\t\tcase 'DbOrParamQry': break;\n\t\t\t\tcase 'DBQueryExt': break;\n\n\t\t\t\t/* Formatting */\n\t\t\t\tcase 'IFmtRecord': break;\n\t\t\t\tcase 'CondFmt': case 'CF': case 'CF12': case 'CFEx': break;\n\n\t\t\t\t/* Explicitly Ignored */\n\t\t\t\tcase 'Excel9File': break;\n\t\t\t\tcase 'Units': break;\n\t\t\t\tcase 'InterfaceHdr': case 'Mms': case 'InterfaceEnd': case 'DSF': case 'BuiltInFnGroupCount':\n\t\t\t\t/* View Stuff */\n\t\t\t\tcase 'Window1': case 'Window2': case 'HideObj': case 'GridSet': case 'Guts':\n\t\t\t\tcase 'UserBView': case 'UserSViewBegin': case 'UserSViewEnd':\n\t\t\t\tcase 'Pane': break;\n\t\t\t\tdefault: switch(R.n) { /* nested */\n\t\t\t\t/* Chart */\n\t\t\t\tcase 'Dat':\n\t\t\t\tcase 'Begin': case 'End':\n\t\t\t\tcase 'StartBlock': case 'EndBlock':\n\t\t\t\tcase 'Frame': case 'Area':\n\t\t\t\tcase 'Axis': case 'AxisLine': case 'Tick': break;\n\t\t\t\tcase 'AxesUsed':\n\t\t\t\tcase 'CrtLayout12': case 'CrtLayout12A': case 'CrtLink': case 'CrtLine': case 'CrtMlFrt': case 'CrtMlFrtContinue': break;\n\t\t\t\tcase 'LineFormat': case 'AreaFormat':\n\t\t\t\tcase 'Chart': case 'Chart3d': case 'Chart3DBarShape': case 'ChartFormat': case 'ChartFrtInfo': break;\n\t\t\t\tcase 'PlotArea': case 'PlotGrowth': break;\n\t\t\t\tcase 'SeriesList': case 'SerParent': case 'SerAuxTrend': break;\n\t\t\t\tcase 'DataFormat': case 'SerToCrt': case 'FontX': break;\n\t\t\t\tcase 'CatSerRange': case 'AxcExt': case 'SerFmt': break;\n\t\t\t\tcase 'ShtProps': break;\n\t\t\t\tcase 'DefaultText': case 'Text': case 'CatLab': break;\n\t\t\t\tcase 'DataLabExtContents': break;\n\t\t\t\tcase 'Legend': case 'LegendException': break;\n\t\t\t\tcase 'Pie': case 'Scatter': break;\n\t\t\t\tcase 'PieFormat': case 'MarkerFormat': break;\n\t\t\t\tcase 'StartObject': case 'EndObject': break;\n\t\t\t\tcase 'AlRuns': case 'ObjectLink': break;\n\t\t\t\tcase 'SIIndex': break;\n\t\t\t\tcase 'AttachedLabel': case 'YMult': break;\n\n\t\t\t\t/* Chart Group */\n\t\t\t\tcase 'Line': case 'Bar': break;\n\t\t\t\tcase 'Surf': break;\n\n\t\t\t\t/* Axis Group */\n\t\t\t\tcase 'AxisParent': break;\n\t\t\t\tcase 'Pos': break;\n\t\t\t\tcase 'ValueRange': break;\n\n\t\t\t\t/* Pivot Chart */\n\t\t\t\tcase 'SXViewEx9': break; // TODO\n\t\t\t\tcase 'SXViewLink': break;\n\t\t\t\tcase 'PivotChartBits': break;\n\t\t\t\tcase 'SBaseRef': break;\n\t\t\t\tcase 'TextPropsStream': break;\n\n\t\t\t\t/* Chart Misc */\n\t\t\t\tcase 'LnExt': break;\n\t\t\t\tcase 'MkrExt': break;\n\t\t\t\tcase 'CrtCoopt': break;\n\n\t\t\t\t/* Query Table */\n\t\t\t\tcase 'Qsi': case 'Qsif': case 'Qsir': case 'QsiSXTag': break;\n\t\t\t\tcase 'TxtQry': break;\n\n\t\t\t\t/* Filter */\n\t\t\t\tcase 'FilterMode': break;\n\t\t\t\tcase 'AutoFilter': case 'AutoFilterInfo': break;\n\t\t\t\tcase 'AutoFilter12': break;\n\t\t\t\tcase 'DropDownObjIds': break;\n\t\t\t\tcase 'Sort': break;\n\t\t\t\tcase 'SortData': break;\n\n\t\t\t\t/* Drawing */\n\t\t\t\tcase 'ShapePropsStream': break;\n\t\t\t\tcase 'MsoDrawing': case 'MsoDrawingGroup': case 'MsoDrawingSelection': break;\n\t\t\t\tcase 'ImData': break;\n\t\t\t\t/* Pub Stuff */\n\t\t\t\tcase 'WebPub': case 'AutoWebPub':\n\n\t\t\t\t/* Print Stuff */\n\t\t\t\tcase 'RightMargin': case 'LeftMargin': case 'TopMargin': case 'BottomMargin':\n\t\t\t\tcase 'HeaderFooter': case 'HFPicture': case 'PLV':\n\t\t\t\tcase 'HorizontalPageBreaks': case 'VerticalPageBreaks':\n\t\t\t\t/* Behavioral */\n\t\t\t\tcase 'Backup': case 'CompressPictures': case 'Compat12': break;\n\n\t\t\t\t/* Should not Happen */\n\t\t\t\tcase 'Continue': case 'ContinueFrt12': break;\n\n\t\t\t\t/* Future Records */\n\t\t\t\tcase 'FrtFontList': case 'FrtWrapper': break;\n\n\t\t\t\t/* BIFF5 records */\n\t\t\t\tcase 'ExternCount': break;\n\t\t\t\tcase 'RString': break;\n\t\t\t\tcase 'TabIdConf': case 'Radar': case 'RadarArea': case 'DropBar': case 'Intl': case 'CoordList': case 'SerAuxErrBar': break;\n\n\t\t\t\tdefault: switch(R.n) { /* nested */\n\t\t\t\t/* Miscellaneous */\n\t\t\t\tcase 'SCENARIO': case 'DConBin': case 'PicF': case 'DataLabExt':\n\t\t\t\tcase 'Lel': case 'BopPop': case 'BopPopCustom': case 'RealTimeData':\n\t\t\t\tcase 'Name': break;\n\t\t\t\tdefault: if(options.WTF) throw 'Unrecognized Record ' + R.n;\n\t\t\t}}}}\n\t\t} else blob.l += length;\n\t}\n\tvar sheetnamesraw = opts.biff === 2 ? ['Sheet1'] : Object.keys(Directory).sort(function(a,b) { return Number(a) - Number(b); }).map(function(x){return Directory[x].name;});\n\tvar sheetnames = sheetnamesraw.slice();\n\twb.Directory=sheetnamesraw;\n\twb.SheetNames=sheetnamesraw;\n\tif(!options.bookSheets) wb.Sheets=Sheets;\n\twb.Preamble=Preamble;\n\twb.Strings = sst;\n\twb.SSF = SSF.get_table();\n\tif(opts.enc) wb.Encryption = opts.enc;\n\twb.Metadata = {};\n\tif(country !== undefined) wb.Metadata.Country = country;\n\treturn wb;\n}\n\nfunction parse_xlscfb(cfb, options) {\nif(!options) options = {};\nfix_read_opts(options);\nreset_cp();\nvar CompObj, Summary, Workbook;\nif(cfb.find) {\n\tCompObj = cfb.find('!CompObj');\n\tSummary = cfb.find('!SummaryInformation');\n\tWorkbook = cfb.find('/Workbook');\n} else {\n\tprep_blob(cfb, 0);\n\tWorkbook = {content: cfb};\n}\n\nif(!Workbook) Workbook = cfb.find('/Book');\nvar CompObjP, SummaryP, WorkbookP;\n\nif(CompObj) CompObjP = parse_compobj(CompObj);\nif(options.bookProps && !options.bookSheets) WorkbookP = {};\nelse {\n\tif(Workbook) WorkbookP = parse_workbook(Workbook.content, options, !!Workbook.find);\n\telse throw new Error(\"Cannot find Workbook stream\");\n}\n\nif(cfb.find) parse_props(cfb);\n\nvar props = {};\nfor(var y in cfb.Summary) props[y] = cfb.Summary[y];\nfor(y in cfb.DocSummary) props[y] = cfb.DocSummary[y];\nWorkbookP.Props = WorkbookP.Custprops = props; /* TODO: split up properties */\nif(options.bookFiles) WorkbookP.cfb = cfb;\nWorkbookP.CompObjP = CompObjP;\nreturn WorkbookP;\n}\n\n/* TODO: WTF */\nfunction parse_props(cfb) {\n\t/* [MS-OSHARED] 2.3.3.2.2 Document Summary Information Property Set */\n\tvar DSI = cfb.find('!DocumentSummaryInformation');\n\tif(DSI) try { cfb.DocSummary = parse_PropertySetStream(DSI, DocSummaryPIDDSI); } catch(e) {}\n\n\t/* [MS-OSHARED] 2.3.3.2.1 Summary Information Property Set*/\n\tvar SI = cfb.find('!SummaryInformation');\n\tif(SI) try { cfb.Summary = parse_PropertySetStream(SI, SummaryPIDSI); } catch(e) {}\n}\n\n/* [MS-XLSB] 2.3 Record Enumeration */\nvar XLSBRecordEnum = {\n\t0x0000: { n:\"BrtRowHdr\", f:parse_BrtRowHdr },\n\t0x0001: { n:\"BrtCellBlank\", f:parse_BrtCellBlank },\n\t0x0002: { n:\"BrtCellRk\", f:parse_BrtCellRk },\n\t0x0003: { n:\"BrtCellError\", f:parse_BrtCellError },\n\t0x0004: { n:\"BrtCellBool\", f:parse_BrtCellBool },\n\t0x0005: { n:\"BrtCellReal\", f:parse_BrtCellReal },\n\t0x0006: { n:\"BrtCellSt\", f:parse_BrtCellSt },\n\t0x0007: { n:\"BrtCellIsst\", f:parse_BrtCellIsst },\n\t0x0008: { n:\"BrtFmlaString\", f:parse_BrtFmlaString },\n\t0x0009: { n:\"BrtFmlaNum\", f:parse_BrtFmlaNum },\n\t0x000A: { n:\"BrtFmlaBool\", f:parse_BrtFmlaBool },\n\t0x000B: { n:\"BrtFmlaError\", f:parse_BrtFmlaError },\n\t0x0010: { n:\"BrtFRTArchID$\", f:parse_BrtFRTArchID$ },\n\t0x0013: { n:\"BrtSSTItem\", f:parse_RichStr },\n\t0x0014: { n:\"BrtPCDIMissing\", f:parsenoop },\n\t0x0015: { n:\"BrtPCDINumber\", f:parsenoop },\n\t0x0016: { n:\"BrtPCDIBoolean\", f:parsenoop },\n\t0x0017: { n:\"BrtPCDIError\", f:parsenoop },\n\t0x0018: { n:\"BrtPCDIString\", f:parsenoop },\n\t0x0019: { n:\"BrtPCDIDatetime\", f:parsenoop },\n\t0x001A: { n:\"BrtPCDIIndex\", f:parsenoop },\n\t0x001B: { n:\"BrtPCDIAMissing\", f:parsenoop },\n\t0x001C: { n:\"BrtPCDIANumber\", f:parsenoop },\n\t0x001D: { n:\"BrtPCDIABoolean\", f:parsenoop },\n\t0x001E: { n:\"BrtPCDIAError\", f:parsenoop },\n\t0x001F: { n:\"BrtPCDIAString\", f:parsenoop },\n\t0x0020: { n:\"BrtPCDIADatetime\", f:parsenoop },\n\t0x0021: { n:\"BrtPCRRecord\", f:parsenoop },\n\t0x0022: { n:\"BrtPCRRecordDt\", f:parsenoop },\n\t0x0023: { n:\"BrtFRTBegin\", f:parsenoop },\n\t0x0024: { n:\"BrtFRTEnd\", f:parsenoop },\n\t0x0025: { n:\"BrtACBegin\", f:parsenoop },\n\t0x0026: { n:\"BrtACEnd\", f:parsenoop },\n\t0x0027: { n:\"BrtName\", f:parsenoop },\n\t0x0028: { n:\"BrtIndexRowBlock\", f:parsenoop },\n\t0x002A: { n:\"BrtIndexBlock\", f:parsenoop },\n\t0x002B: { n:\"BrtFont\", f:parse_BrtFont },\n\t0x002C: { n:\"BrtFmt\", f:parse_BrtFmt },\n\t0x002D: { n:\"BrtFill\", f:parsenoop },\n\t0x002E: { n:\"BrtBorder\", f:parsenoop },\n\t0x002F: { n:\"BrtXF\", f:parse_BrtXF },\n\t0x0030: { n:\"BrtStyle\", f:parsenoop },\n\t0x0031: { n:\"BrtCellMeta\", f:parsenoop },\n\t0x0032: { n:\"BrtValueMeta\", f:parsenoop },\n\t0x0033: { n:\"BrtMdb\", f:parsenoop },\n\t0x0034: { n:\"BrtBeginFmd\", f:parsenoop },\n\t0x0035: { n:\"BrtEndFmd\", f:parsenoop },\n\t0x0036: { n:\"BrtBeginMdx\", f:parsenoop },\n\t0x0037: { n:\"BrtEndMdx\", f:parsenoop },\n\t0x0038: { n:\"BrtBeginMdxTuple\", f:parsenoop },\n\t0x0039: { n:\"BrtEndMdxTuple\", f:parsenoop },\n\t0x003A: { n:\"BrtMdxMbrIstr\", f:parsenoop },\n\t0x003B: { n:\"BrtStr\", f:parsenoop },\n\t0x003C: { n:\"BrtColInfo\", f:parsenoop },\n\t0x003E: { n:\"BrtCellRString\", f:parsenoop },\n\t0x003F: { n:\"BrtCalcChainItem$\", f:parse_BrtCalcChainItem$ },\n\t0x0040: { n:\"BrtDVal\", f:parsenoop },\n\t0x0041: { n:\"BrtSxvcellNum\", f:parsenoop },\n\t0x0042: { n:\"BrtSxvcellStr\", f:parsenoop },\n\t0x0043: { n:\"BrtSxvcellBool\", f:parsenoop },\n\t0x0044: { n:\"BrtSxvcellErr\", f:parsenoop },\n\t0x0045: { n:\"BrtSxvcellDate\", f:parsenoop },\n\t0x0046: { n:\"BrtSxvcellNil\", f:parsenoop },\n\t0x0080: { n:\"BrtFileVersion\", f:parsenoop },\n\t0x0081: { n:\"BrtBeginSheet\", f:parsenoop },\n\t0x0082: { n:\"BrtEndSheet\", f:parsenoop },\n\t0x0083: { n:\"BrtBeginBook\", f:parsenoop, p:0 },\n\t0x0084: { n:\"BrtEndBook\", f:parsenoop },\n\t0x0085: { n:\"BrtBeginWsViews\", f:parsenoop },\n\t0x0086: { n:\"BrtEndWsViews\", f:parsenoop },\n\t0x0087: { n:\"BrtBeginBookViews\", f:parsenoop },\n\t0x0088: { n:\"BrtEndBookViews\", f:parsenoop },\n\t0x0089: { n:\"BrtBeginWsView\", f:parsenoop },\n\t0x008A: { n:\"BrtEndWsView\", f:parsenoop },\n\t0x008B: { n:\"BrtBeginCsViews\", f:parsenoop },\n\t0x008C: { n:\"BrtEndCsViews\", f:parsenoop },\n\t0x008D: { n:\"BrtBeginCsView\", f:parsenoop },\n\t0x008E: { n:\"BrtEndCsView\", f:parsenoop },\n\t0x008F: { n:\"BrtBeginBundleShs\", f:parsenoop },\n\t0x0090: { n:\"BrtEndBundleShs\", f:parsenoop },\n\t0x0091: { n:\"BrtBeginSheetData\", f:parsenoop },\n\t0x0092: { n:\"BrtEndSheetData\", f:parsenoop },\n\t0x0093: { n:\"BrtWsProp\", f:parse_BrtWsProp },\n\t0x0094: { n:\"BrtWsDim\", f:parse_BrtWsDim, p:16 },\n\t0x0097: { n:\"BrtPane\", f:parsenoop },\n\t0x0098: { n:\"BrtSel\", f:parsenoop },\n\t0x0099: { n:\"BrtWbProp\", f:parse_BrtWbProp },\n\t0x009A: { n:\"BrtWbFactoid\", f:parsenoop },\n\t0x009B: { n:\"BrtFileRecover\", f:parsenoop },\n\t0x009C: { n:\"BrtBundleSh\", f:parse_BrtBundleSh },\n\t0x009D: { n:\"BrtCalcProp\", f:parsenoop },\n\t0x009E: { n:\"BrtBookView\", f:parsenoop },\n\t0x009F: { n:\"BrtBeginSst\", f:parse_BrtBeginSst },\n\t0x00A0: { n:\"BrtEndSst\", f:parsenoop },\n\t0x00A1: { n:\"BrtBeginAFilter\", f:parsenoop },\n\t0x00A2: { n:\"BrtEndAFilter\", f:parsenoop },\n\t0x00A3: { n:\"BrtBeginFilterColumn\", f:parsenoop },\n\t0x00A4: { n:\"BrtEndFilterColumn\", f:parsenoop },\n\t0x00A5: { n:\"BrtBeginFilters\", f:parsenoop },\n\t0x00A6: { n:\"BrtEndFilters\", f:parsenoop },\n\t0x00A7: { n:\"BrtFilter\", f:parsenoop },\n\t0x00A8: { n:\"BrtColorFilter\", f:parsenoop },\n\t0x00A9: { n:\"BrtIconFilter\", f:parsenoop },\n\t0x00AA: { n:\"BrtTop10Filter\", f:parsenoop },\n\t0x00AB: { n:\"BrtDynamicFilter\", f:parsenoop },\n\t0x00AC: { n:\"BrtBeginCustomFilters\", f:parsenoop },\n\t0x00AD: { n:\"BrtEndCustomFilters\", f:parsenoop },\n\t0x00AE: { n:\"BrtCustomFilter\", f:parsenoop },\n\t0x00AF: { n:\"BrtAFilterDateGroupItem\", f:parsenoop },\n\t0x00B0: { n:\"BrtMergeCell\", f:parse_BrtMergeCell },\n\t0x00B1: { n:\"BrtBeginMergeCells\", f:parsenoop },\n\t0x00B2: { n:\"BrtEndMergeCells\", f:parsenoop },\n\t0x00B3: { n:\"BrtBeginPivotCacheDef\", f:parsenoop },\n\t0x00B4: { n:\"BrtEndPivotCacheDef\", f:parsenoop },\n\t0x00B5: { n:\"BrtBeginPCDFields\", f:parsenoop },\n\t0x00B6: { n:\"BrtEndPCDFields\", f:parsenoop },\n\t0x00B7: { n:\"BrtBeginPCDField\", f:parsenoop },\n\t0x00B8: { n:\"BrtEndPCDField\", f:parsenoop },\n\t0x00B9: { n:\"BrtBeginPCDSource\", f:parsenoop },\n\t0x00BA: { n:\"BrtEndPCDSource\", f:parsenoop },\n\t0x00BB: { n:\"BrtBeginPCDSRange\", f:parsenoop },\n\t0x00BC: { n:\"BrtEndPCDSRange\", f:parsenoop },\n\t0x00BD: { n:\"BrtBeginPCDFAtbl\", f:parsenoop },\n\t0x00BE: { n:\"BrtEndPCDFAtbl\", f:parsenoop },\n\t0x00BF: { n:\"BrtBeginPCDIRun\", f:parsenoop },\n\t0x00C0: { n:\"BrtEndPCDIRun\", f:parsenoop },\n\t0x00C1: { n:\"BrtBeginPivotCacheRecords\", f:parsenoop },\n\t0x00C2: { n:\"BrtEndPivotCacheRecords\", f:parsenoop },\n\t0x00C3: { n:\"BrtBeginPCDHierarchies\", f:parsenoop },\n\t0x00C4: { n:\"BrtEndPCDHierarchies\", f:parsenoop },\n\t0x00C5: { n:\"BrtBeginPCDHierarchy\", f:parsenoop },\n\t0x00C6: { n:\"BrtEndPCDHierarchy\", f:parsenoop },\n\t0x00C7: { n:\"BrtBeginPCDHFieldsUsage\", f:parsenoop },\n\t0x00C8: { n:\"BrtEndPCDHFieldsUsage\", f:parsenoop },\n\t0x00C9: { n:\"BrtBeginExtConnection\", f:parsenoop },\n\t0x00CA: { n:\"BrtEndExtConnection\", f:parsenoop },\n\t0x00CB: { n:\"BrtBeginECDbProps\", f:parsenoop },\n\t0x00CC: { n:\"BrtEndECDbProps\", f:parsenoop },\n\t0x00CD: { n:\"BrtBeginECOlapProps\", f:parsenoop },\n\t0x00CE: { n:\"BrtEndECOlapProps\", f:parsenoop },\n\t0x00CF: { n:\"BrtBeginPCDSConsol\", f:parsenoop },\n\t0x00D0: { n:\"BrtEndPCDSConsol\", f:parsenoop },\n\t0x00D1: { n:\"BrtBeginPCDSCPages\", f:parsenoop },\n\t0x00D2: { n:\"BrtEndPCDSCPages\", f:parsenoop },\n\t0x00D3: { n:\"BrtBeginPCDSCPage\", f:parsenoop },\n\t0x00D4: { n:\"BrtEndPCDSCPage\", f:parsenoop },\n\t0x00D5: { n:\"BrtBeginPCDSCPItem\", f:parsenoop },\n\t0x00D6: { n:\"BrtEndPCDSCPItem\", f:parsenoop },\n\t0x00D7: { n:\"BrtBeginPCDSCSets\", f:parsenoop },\n\t0x00D8: { n:\"BrtEndPCDSCSets\", f:parsenoop },\n\t0x00D9: { n:\"BrtBeginPCDSCSet\", f:parsenoop },\n\t0x00DA: { n:\"BrtEndPCDSCSet\", f:parsenoop },\n\t0x00DB: { n:\"BrtBeginPCDFGroup\", f:parsenoop },\n\t0x00DC: { n:\"BrtEndPCDFGroup\", f:parsenoop },\n\t0x00DD: { n:\"BrtBeginPCDFGItems\", f:parsenoop },\n\t0x00DE: { n:\"BrtEndPCDFGItems\", f:parsenoop },\n\t0x00DF: { n:\"BrtBeginPCDFGRange\", f:parsenoop },\n\t0x00E0: { n:\"BrtEndPCDFGRange\", f:parsenoop },\n\t0x00E1: { n:\"BrtBeginPCDFGDiscrete\", f:parsenoop },\n\t0x00E2: { n:\"BrtEndPCDFGDiscrete\", f:parsenoop },\n\t0x00E3: { n:\"BrtBeginPCDSDTupleCache\", f:parsenoop },\n\t0x00E4: { n:\"BrtEndPCDSDTupleCache\", f:parsenoop },\n\t0x00E5: { n:\"BrtBeginPCDSDTCEntries\", f:parsenoop },\n\t0x00E6: { n:\"BrtEndPCDSDTCEntries\", f:parsenoop },\n\t0x00E7: { n:\"BrtBeginPCDSDTCEMembers\", f:parsenoop },\n\t0x00E8: { n:\"BrtEndPCDSDTCEMembers\", f:parsenoop },\n\t0x00E9: { n:\"BrtBeginPCDSDTCEMember\", f:parsenoop },\n\t0x00EA: { n:\"BrtEndPCDSDTCEMember\", f:parsenoop },\n\t0x00EB: { n:\"BrtBeginPCDSDTCQueries\", f:parsenoop },\n\t0x00EC: { n:\"BrtEndPCDSDTCQueries\", f:parsenoop },\n\t0x00ED: { n:\"BrtBeginPCDSDTCQuery\", f:parsenoop },\n\t0x00EE: { n:\"BrtEndPCDSDTCQuery\", f:parsenoop },\n\t0x00EF: { n:\"BrtBeginPCDSDTCSets\", f:parsenoop },\n\t0x00F0: { n:\"BrtEndPCDSDTCSets\", f:parsenoop },\n\t0x00F1: { n:\"BrtBeginPCDSDTCSet\", f:parsenoop },\n\t0x00F2: { n:\"BrtEndPCDSDTCSet\", f:parsenoop },\n\t0x00F3: { n:\"BrtBeginPCDCalcItems\", f:parsenoop },\n\t0x00F4: { n:\"BrtEndPCDCalcItems\", f:parsenoop },\n\t0x00F5: { n:\"BrtBeginPCDCalcItem\", f:parsenoop },\n\t0x00F6: { n:\"BrtEndPCDCalcItem\", f:parsenoop },\n\t0x00F7: { n:\"BrtBeginPRule\", f:parsenoop },\n\t0x00F8: { n:\"BrtEndPRule\", f:parsenoop },\n\t0x00F9: { n:\"BrtBeginPRFilters\", f:parsenoop },\n\t0x00FA: { n:\"BrtEndPRFilters\", f:parsenoop },\n\t0x00FB: { n:\"BrtBeginPRFilter\", f:parsenoop },\n\t0x00FC: { n:\"BrtEndPRFilter\", f:parsenoop },\n\t0x00FD: { n:\"BrtBeginPNames\", f:parsenoop },\n\t0x00FE: { n:\"BrtEndPNames\", f:parsenoop },\n\t0x00FF: { n:\"BrtBeginPName\", f:parsenoop },\n\t0x0100: { n:\"BrtEndPName\", f:parsenoop },\n\t0x0101: { n:\"BrtBeginPNPairs\", f:parsenoop },\n\t0x0102: { n:\"BrtEndPNPairs\", f:parsenoop },\n\t0x0103: { n:\"BrtBeginPNPair\", f:parsenoop },\n\t0x0104: { n:\"BrtEndPNPair\", f:parsenoop },\n\t0x0105: { n:\"BrtBeginECWebProps\", f:parsenoop },\n\t0x0106: { n:\"BrtEndECWebProps\", f:parsenoop },\n\t0x0107: { n:\"BrtBeginEcWpTables\", f:parsenoop },\n\t0x0108: { n:\"BrtEndECWPTables\", f:parsenoop },\n\t0x0109: { n:\"BrtBeginECParams\", f:parsenoop },\n\t0x010A: { n:\"BrtEndECParams\", f:parsenoop },\n\t0x010B: { n:\"BrtBeginECParam\", f:parsenoop },\n\t0x010C: { n:\"BrtEndECParam\", f:parsenoop },\n\t0x010D: { n:\"BrtBeginPCDKPIs\", f:parsenoop },\n\t0x010E: { n:\"BrtEndPCDKPIs\", f:parsenoop },\n\t0x010F: { n:\"BrtBeginPCDKPI\", f:parsenoop },\n\t0x0110: { n:\"BrtEndPCDKPI\", f:parsenoop },\n\t0x0111: { n:\"BrtBeginDims\", f:parsenoop },\n\t0x0112: { n:\"BrtEndDims\", f:parsenoop },\n\t0x0113: { n:\"BrtBeginDim\", f:parsenoop },\n\t0x0114: { n:\"BrtEndDim\", f:parsenoop },\n\t0x0115: { n:\"BrtIndexPartEnd\", f:parsenoop },\n\t0x0116: { n:\"BrtBeginStyleSheet\", f:parsenoop },\n\t0x0117: { n:\"BrtEndStyleSheet\", f:parsenoop },\n\t0x0118: { n:\"BrtBeginSXView\", f:parsenoop },\n\t0x0119: { n:\"BrtEndSXVI\", f:parsenoop },\n\t0x011A: { n:\"BrtBeginSXVI\", f:parsenoop },\n\t0x011B: { n:\"BrtBeginSXVIs\", f:parsenoop },\n\t0x011C: { n:\"BrtEndSXVIs\", f:parsenoop },\n\t0x011D: { n:\"BrtBeginSXVD\", f:parsenoop },\n\t0x011E: { n:\"BrtEndSXVD\", f:parsenoop },\n\t0x011F: { n:\"BrtBeginSXVDs\", f:parsenoop },\n\t0x0120: { n:\"BrtEndSXVDs\", f:parsenoop },\n\t0x0121: { n:\"BrtBeginSXPI\", f:parsenoop },\n\t0x0122: { n:\"BrtEndSXPI\", f:parsenoop },\n\t0x0123: { n:\"BrtBeginSXPIs\", f:parsenoop },\n\t0x0124: { n:\"BrtEndSXPIs\", f:parsenoop },\n\t0x0125: { n:\"BrtBeginSXDI\", f:parsenoop },\n\t0x0126: { n:\"BrtEndSXDI\", f:parsenoop },\n\t0x0127: { n:\"BrtBeginSXDIs\", f:parsenoop },\n\t0x0128: { n:\"BrtEndSXDIs\", f:parsenoop },\n\t0x0129: { n:\"BrtBeginSXLI\", f:parsenoop },\n\t0x012A: { n:\"BrtEndSXLI\", f:parsenoop },\n\t0x012B: { n:\"BrtBeginSXLIRws\", f:parsenoop },\n\t0x012C: { n:\"BrtEndSXLIRws\", f:parsenoop },\n\t0x012D: { n:\"BrtBeginSXLICols\", f:parsenoop },\n\t0x012E: { n:\"BrtEndSXLICols\", f:parsenoop },\n\t0x012F: { n:\"BrtBeginSXFormat\", f:parsenoop },\n\t0x0130: { n:\"BrtEndSXFormat\", f:parsenoop },\n\t0x0131: { n:\"BrtBeginSXFormats\", f:parsenoop },\n\t0x0132: { n:\"BrtEndSxFormats\", f:parsenoop },\n\t0x0133: { n:\"BrtBeginSxSelect\", f:parsenoop },\n\t0x0134: { n:\"BrtEndSxSelect\", f:parsenoop },\n\t0x0135: { n:\"BrtBeginISXVDRws\", f:parsenoop },\n\t0x0136: { n:\"BrtEndISXVDRws\", f:parsenoop },\n\t0x0137: { n:\"BrtBeginISXVDCols\", f:parsenoop },\n\t0x0138: { n:\"BrtEndISXVDCols\", f:parsenoop },\n\t0x0139: { n:\"BrtEndSXLocation\", f:parsenoop },\n\t0x013A: { n:\"BrtBeginSXLocation\", f:parsenoop },\n\t0x013B: { n:\"BrtEndSXView\", f:parsenoop },\n\t0x013C: { n:\"BrtBeginSXTHs\", f:parsenoop },\n\t0x013D: { n:\"BrtEndSXTHs\", f:parsenoop },\n\t0x013E: { n:\"BrtBeginSXTH\", f:parsenoop },\n\t0x013F: { n:\"BrtEndSXTH\", f:parsenoop },\n\t0x0140: { n:\"BrtBeginISXTHRws\", f:parsenoop },\n\t0x0141: { n:\"BrtEndISXTHRws\", f:parsenoop },\n\t0x0142: { n:\"BrtBeginISXTHCols\", f:parsenoop },\n\t0x0143: { n:\"BrtEndISXTHCols\", f:parsenoop },\n\t0x0144: { n:\"BrtBeginSXTDMPS\", f:parsenoop },\n\t0x0145: { n:\"BrtEndSXTDMPs\", f:parsenoop },\n\t0x0146: { n:\"BrtBeginSXTDMP\", f:parsenoop },\n\t0x0147: { n:\"BrtEndSXTDMP\", f:parsenoop },\n\t0x0148: { n:\"BrtBeginSXTHItems\", f:parsenoop },\n\t0x0149: { n:\"BrtEndSXTHItems\", f:parsenoop },\n\t0x014A: { n:\"BrtBeginSXTHItem\", f:parsenoop },\n\t0x014B: { n:\"BrtEndSXTHItem\", f:parsenoop },\n\t0x014C: { n:\"BrtBeginMetadata\", f:parsenoop },\n\t0x014D: { n:\"BrtEndMetadata\", f:parsenoop },\n\t0x014E: { n:\"BrtBeginEsmdtinfo\", f:parsenoop },\n\t0x014F: { n:\"BrtMdtinfo\", f:parsenoop },\n\t0x0150: { n:\"BrtEndEsmdtinfo\", f:parsenoop },\n\t0x0151: { n:\"BrtBeginEsmdb\", f:parsenoop },\n\t0x0152: { n:\"BrtEndEsmdb\", f:parsenoop },\n\t0x0153: { n:\"BrtBeginEsfmd\", f:parsenoop },\n\t0x0154: { n:\"BrtEndEsfmd\", f:parsenoop },\n\t0x0155: { n:\"BrtBeginSingleCells\", f:parsenoop },\n\t0x0156: { n:\"BrtEndSingleCells\", f:parsenoop },\n\t0x0157: { n:\"BrtBeginList\", f:parsenoop },\n\t0x0158: { n:\"BrtEndList\", f:parsenoop },\n\t0x0159: { n:\"BrtBeginListCols\", f:parsenoop },\n\t0x015A: { n:\"BrtEndListCols\", f:parsenoop },\n\t0x015B: { n:\"BrtBeginListCol\", f:parsenoop },\n\t0x015C: { n:\"BrtEndListCol\", f:parsenoop },\n\t0x015D: { n:\"BrtBeginListXmlCPr\", f:parsenoop },\n\t0x015E: { n:\"BrtEndListXmlCPr\", f:parsenoop },\n\t0x015F: { n:\"BrtListCCFmla\", f:parsenoop },\n\t0x0160: { n:\"BrtListTrFmla\", f:parsenoop },\n\t0x0161: { n:\"BrtBeginExternals\", f:parsenoop },\n\t0x0162: { n:\"BrtEndExternals\", f:parsenoop },\n\t0x0163: { n:\"BrtSupBookSrc\", f:parsenoop },\n\t0x0165: { n:\"BrtSupSelf\", f:parsenoop },\n\t0x0166: { n:\"BrtSupSame\", f:parsenoop },\n\t0x0167: { n:\"BrtSupTabs\", f:parsenoop },\n\t0x0168: { n:\"BrtBeginSupBook\", f:parsenoop },\n\t0x0169: { n:\"BrtPlaceholderName\", f:parsenoop },\n\t0x016A: { n:\"BrtExternSheet\", f:parsenoop },\n\t0x016B: { n:\"BrtExternTableStart\", f:parsenoop },\n\t0x016C: { n:\"BrtExternTableEnd\", f:parsenoop },\n\t0x016E: { n:\"BrtExternRowHdr\", f:parsenoop },\n\t0x016F: { n:\"BrtExternCellBlank\", f:parsenoop },\n\t0x0170: { n:\"BrtExternCellReal\", f:parsenoop },\n\t0x0171: { n:\"BrtExternCellBool\", f:parsenoop },\n\t0x0172: { n:\"BrtExternCellError\", f:parsenoop },\n\t0x0173: { n:\"BrtExternCellString\", f:parsenoop },\n\t0x0174: { n:\"BrtBeginEsmdx\", f:parsenoop },\n\t0x0175: { n:\"BrtEndEsmdx\", f:parsenoop },\n\t0x0176: { n:\"BrtBeginMdxSet\", f:parsenoop },\n\t0x0177: { n:\"BrtEndMdxSet\", f:parsenoop },\n\t0x0178: { n:\"BrtBeginMdxMbrProp\", f:parsenoop },\n\t0x0179: { n:\"BrtEndMdxMbrProp\", f:parsenoop },\n\t0x017A: { n:\"BrtBeginMdxKPI\", f:parsenoop },\n\t0x017B: { n:\"BrtEndMdxKPI\", f:parsenoop },\n\t0x017C: { n:\"BrtBeginEsstr\", f:parsenoop },\n\t0x017D: { n:\"BrtEndEsstr\", f:parsenoop },\n\t0x017E: { n:\"BrtBeginPRFItem\", f:parsenoop },\n\t0x017F: { n:\"BrtEndPRFItem\", f:parsenoop },\n\t0x0180: { n:\"BrtBeginPivotCacheIDs\", f:parsenoop },\n\t0x0181: { n:\"BrtEndPivotCacheIDs\", f:parsenoop },\n\t0x0182: { n:\"BrtBeginPivotCacheID\", f:parsenoop },\n\t0x0183: { n:\"BrtEndPivotCacheID\", f:parsenoop },\n\t0x0184: { n:\"BrtBeginISXVIs\", f:parsenoop },\n\t0x0185: { n:\"BrtEndISXVIs\", f:parsenoop },\n\t0x0186: { n:\"BrtBeginColInfos\", f:parsenoop },\n\t0x0187: { n:\"BrtEndColInfos\", f:parsenoop },\n\t0x0188: { n:\"BrtBeginRwBrk\", f:parsenoop },\n\t0x0189: { n:\"BrtEndRwBrk\", f:parsenoop },\n\t0x018A: { n:\"BrtBeginColBrk\", f:parsenoop },\n\t0x018B: { n:\"BrtEndColBrk\", f:parsenoop },\n\t0x018C: { n:\"BrtBrk\", f:parsenoop },\n\t0x018D: { n:\"BrtUserBookView\", f:parsenoop },\n\t0x018E: { n:\"BrtInfo\", f:parsenoop },\n\t0x018F: { n:\"BrtCUsr\", f:parsenoop },\n\t0x0190: { n:\"BrtUsr\", f:parsenoop },\n\t0x0191: { n:\"BrtBeginUsers\", f:parsenoop },\n\t0x0193: { n:\"BrtEOF\", f:parsenoop },\n\t0x0194: { n:\"BrtUCR\", f:parsenoop },\n\t0x0195: { n:\"BrtRRInsDel\", f:parsenoop },\n\t0x0196: { n:\"BrtRREndInsDel\", f:parsenoop },\n\t0x0197: { n:\"BrtRRMove\", f:parsenoop },\n\t0x0198: { n:\"BrtRREndMove\", f:parsenoop },\n\t0x0199: { n:\"BrtRRChgCell\", f:parsenoop },\n\t0x019A: { n:\"BrtRREndChgCell\", f:parsenoop },\n\t0x019B: { n:\"BrtRRHeader\", f:parsenoop },\n\t0x019C: { n:\"BrtRRUserView\", f:parsenoop },\n\t0x019D: { n:\"BrtRRRenSheet\", f:parsenoop },\n\t0x019E: { n:\"BrtRRInsertSh\", f:parsenoop },\n\t0x019F: { n:\"BrtRRDefName\", f:parsenoop },\n\t0x01A0: { n:\"BrtRRNote\", f:parsenoop },\n\t0x01A1: { n:\"BrtRRConflict\", f:parsenoop },\n\t0x01A2: { n:\"BrtRRTQSIF\", f:parsenoop },\n\t0x01A3: { n:\"BrtRRFormat\", f:parsenoop },\n\t0x01A4: { n:\"BrtRREndFormat\", f:parsenoop },\n\t0x01A5: { n:\"BrtRRAutoFmt\", f:parsenoop },\n\t0x01A6: { n:\"BrtBeginUserShViews\", f:parsenoop },\n\t0x01A7: { n:\"BrtBeginUserShView\", f:parsenoop },\n\t0x01A8: { n:\"BrtEndUserShView\", f:parsenoop },\n\t0x01A9: { n:\"BrtEndUserShViews\", f:parsenoop },\n\t0x01AA: { n:\"BrtArrFmla\", f:parsenoop },\n\t0x01AB: { n:\"BrtShrFmla\", f:parsenoop },\n\t0x01AC: { n:\"BrtTable\", f:parsenoop },\n\t0x01AD: { n:\"BrtBeginExtConnections\", f:parsenoop },\n\t0x01AE: { n:\"BrtEndExtConnections\", f:parsenoop },\n\t0x01AF: { n:\"BrtBeginPCDCalcMems\", f:parsenoop },\n\t0x01B0: { n:\"BrtEndPCDCalcMems\", f:parsenoop },\n\t0x01B1: { n:\"BrtBeginPCDCalcMem\", f:parsenoop },\n\t0x01B2: { n:\"BrtEndPCDCalcMem\", f:parsenoop },\n\t0x01B3: { n:\"BrtBeginPCDHGLevels\", f:parsenoop },\n\t0x01B4: { n:\"BrtEndPCDHGLevels\", f:parsenoop },\n\t0x01B5: { n:\"BrtBeginPCDHGLevel\", f:parsenoop },\n\t0x01B6: { n:\"BrtEndPCDHGLevel\", f:parsenoop },\n\t0x01B7: { n:\"BrtBeginPCDHGLGroups\", f:parsenoop },\n\t0x01B8: { n:\"BrtEndPCDHGLGroups\", f:parsenoop },\n\t0x01B9: { n:\"BrtBeginPCDHGLGroup\", f:parsenoop },\n\t0x01BA: { n:\"BrtEndPCDHGLGroup\", f:parsenoop },\n\t0x01BB: { n:\"BrtBeginPCDHGLGMembers\", f:parsenoop },\n\t0x01BC: { n:\"BrtEndPCDHGLGMembers\", f:parsenoop },\n\t0x01BD: { n:\"BrtBeginPCDHGLGMember\", f:parsenoop },\n\t0x01BE: { n:\"BrtEndPCDHGLGMember\", f:parsenoop },\n\t0x01BF: { n:\"BrtBeginQSI\", f:parsenoop },\n\t0x01C0: { n:\"BrtEndQSI\", f:parsenoop },\n\t0x01C1: { n:\"BrtBeginQSIR\", f:parsenoop },\n\t0x01C2: { n:\"BrtEndQSIR\", f:parsenoop },\n\t0x01C3: { n:\"BrtBeginDeletedNames\", f:parsenoop },\n\t0x01C4: { n:\"BrtEndDeletedNames\", f:parsenoop },\n\t0x01C5: { n:\"BrtBeginDeletedName\", f:parsenoop },\n\t0x01C6: { n:\"BrtEndDeletedName\", f:parsenoop },\n\t0x01C7: { n:\"BrtBeginQSIFs\", f:parsenoop },\n\t0x01C8: { n:\"BrtEndQSIFs\", f:parsenoop },\n\t0x01C9: { n:\"BrtBeginQSIF\", f:parsenoop },\n\t0x01CA: { n:\"BrtEndQSIF\", f:parsenoop },\n\t0x01CB: { n:\"BrtBeginAutoSortScope\", f:parsenoop },\n\t0x01CC: { n:\"BrtEndAutoSortScope\", f:parsenoop },\n\t0x01CD: { n:\"BrtBeginConditionalFormatting\", f:parsenoop },\n\t0x01CE: { n:\"BrtEndConditionalFormatting\", f:parsenoop },\n\t0x01CF: { n:\"BrtBeginCFRule\", f:parsenoop },\n\t0x01D0: { n:\"BrtEndCFRule\", f:parsenoop },\n\t0x01D1: { n:\"BrtBeginIconSet\", f:parsenoop },\n\t0x01D2: { n:\"BrtEndIconSet\", f:parsenoop },\n\t0x01D3: { n:\"BrtBeginDatabar\", f:parsenoop },\n\t0x01D4: { n:\"BrtEndDatabar\", f:parsenoop },\n\t0x01D5: { n:\"BrtBeginColorScale\", f:parsenoop },\n\t0x01D6: { n:\"BrtEndColorScale\", f:parsenoop },\n\t0x01D7: { n:\"BrtCFVO\", f:parsenoop },\n\t0x01D8: { n:\"BrtExternValueMeta\", f:parsenoop },\n\t0x01D9: { n:\"BrtBeginColorPalette\", f:parsenoop },\n\t0x01DA: { n:\"BrtEndColorPalette\", f:parsenoop },\n\t0x01DB: { n:\"BrtIndexedColor\", f:parsenoop },\n\t0x01DC: { n:\"BrtMargins\", f:parsenoop },\n\t0x01DD: { n:\"BrtPrintOptions\", f:parsenoop },\n\t0x01DE: { n:\"BrtPageSetup\", f:parsenoop },\n\t0x01DF: { n:\"BrtBeginHeaderFooter\", f:parsenoop },\n\t0x01E0: { n:\"BrtEndHeaderFooter\", f:parsenoop },\n\t0x01E1: { n:\"BrtBeginSXCrtFormat\", f:parsenoop },\n\t0x01E2: { n:\"BrtEndSXCrtFormat\", f:parsenoop },\n\t0x01E3: { n:\"BrtBeginSXCrtFormats\", f:parsenoop },\n\t0x01E4: { n:\"BrtEndSXCrtFormats\", f:parsenoop },\n\t0x01E5: { n:\"BrtWsFmtInfo\", f:parsenoop },\n\t0x01E6: { n:\"BrtBeginMgs\", f:parsenoop },\n\t0x01E7: { n:\"BrtEndMGs\", f:parsenoop },\n\t0x01E8: { n:\"BrtBeginMGMaps\", f:parsenoop },\n\t0x01E9: { n:\"BrtEndMGMaps\", f:parsenoop },\n\t0x01EA: { n:\"BrtBeginMG\", f:parsenoop },\n\t0x01EB: { n:\"BrtEndMG\", f:parsenoop },\n\t0x01EC: { n:\"BrtBeginMap\", f:parsenoop },\n\t0x01ED: { n:\"BrtEndMap\", f:parsenoop },\n\t0x01EE: { n:\"BrtHLink\", f:parse_BrtHLink },\n\t0x01EF: { n:\"BrtBeginDCon\", f:parsenoop },\n\t0x01F0: { n:\"BrtEndDCon\", f:parsenoop },\n\t0x01F1: { n:\"BrtBeginDRefs\", f:parsenoop },\n\t0x01F2: { n:\"BrtEndDRefs\", f:parsenoop },\n\t0x01F3: { n:\"BrtDRef\", f:parsenoop },\n\t0x01F4: { n:\"BrtBeginScenMan\", f:parsenoop },\n\t0x01F5: { n:\"BrtEndScenMan\", f:parsenoop },\n\t0x01F6: { n:\"BrtBeginSct\", f:parsenoop },\n\t0x01F7: { n:\"BrtEndSct\", f:parsenoop },\n\t0x01F8: { n:\"BrtSlc\", f:parsenoop },\n\t0x01F9: { n:\"BrtBeginDXFs\", f:parsenoop },\n\t0x01FA: { n:\"BrtEndDXFs\", f:parsenoop },\n\t0x01FB: { n:\"BrtDXF\", f:parsenoop },\n\t0x01FC: { n:\"BrtBeginTableStyles\", f:parsenoop },\n\t0x01FD: { n:\"BrtEndTableStyles\", f:parsenoop },\n\t0x01FE: { n:\"BrtBeginTableStyle\", f:parsenoop },\n\t0x01FF: { n:\"BrtEndTableStyle\", f:parsenoop },\n\t0x0200: { n:\"BrtTableStyleElement\", f:parsenoop },\n\t0x0201: { n:\"BrtTableStyleClient\", f:parsenoop },\n\t0x0202: { n:\"BrtBeginVolDeps\", f:parsenoop },\n\t0x0203: { n:\"BrtEndVolDeps\", f:parsenoop },\n\t0x0204: { n:\"BrtBeginVolType\", f:parsenoop },\n\t0x0205: { n:\"BrtEndVolType\", f:parsenoop },\n\t0x0206: { n:\"BrtBeginVolMain\", f:parsenoop },\n\t0x0207: { n:\"BrtEndVolMain\", f:parsenoop },\n\t0x0208: { n:\"BrtBeginVolTopic\", f:parsenoop },\n\t0x0209: { n:\"BrtEndVolTopic\", f:parsenoop },\n\t0x020A: { n:\"BrtVolSubtopic\", f:parsenoop },\n\t0x020B: { n:\"BrtVolRef\", f:parsenoop },\n\t0x020C: { n:\"BrtVolNum\", f:parsenoop },\n\t0x020D: { n:\"BrtVolErr\", f:parsenoop },\n\t0x020E: { n:\"BrtVolStr\", f:parsenoop },\n\t0x020F: { n:\"BrtVolBool\", f:parsenoop },\n\t0x0210: { n:\"BrtBeginCalcChain$\", f:parsenoop },\n\t0x0211: { n:\"BrtEndCalcChain$\", f:parsenoop },\n\t0x0212: { n:\"BrtBeginSortState\", f:parsenoop },\n\t0x0213: { n:\"BrtEndSortState\", f:parsenoop },\n\t0x0214: { n:\"BrtBeginSortCond\", f:parsenoop },\n\t0x0215: { n:\"BrtEndSortCond\", f:parsenoop },\n\t0x0216: { n:\"BrtBookProtection\", f:parsenoop },\n\t0x0217: { n:\"BrtSheetProtection\", f:parsenoop },\n\t0x0218: { n:\"BrtRangeProtection\", f:parsenoop },\n\t0x0219: { n:\"BrtPhoneticInfo\", f:parsenoop },\n\t0x021A: { n:\"BrtBeginECTxtWiz\", f:parsenoop },\n\t0x021B: { n:\"BrtEndECTxtWiz\", f:parsenoop },\n\t0x021C: { n:\"BrtBeginECTWFldInfoLst\", f:parsenoop },\n\t0x021D: { n:\"BrtEndECTWFldInfoLst\", f:parsenoop },\n\t0x021E: { n:\"BrtBeginECTwFldInfo\", f:parsenoop },\n\t0x0224: { n:\"BrtFileSharing\", f:parsenoop },\n\t0x0225: { n:\"BrtOleSize\", f:parsenoop },\n\t0x0226: { n:\"BrtDrawing\", f:parsenoop },\n\t0x0227: { n:\"BrtLegacyDrawing\", f:parsenoop },\n\t0x0228: { n:\"BrtLegacyDrawingHF\", f:parsenoop },\n\t0x0229: { n:\"BrtWebOpt\", f:parsenoop },\n\t0x022A: { n:\"BrtBeginWebPubItems\", f:parsenoop },\n\t0x022B: { n:\"BrtEndWebPubItems\", f:parsenoop },\n\t0x022C: { n:\"BrtBeginWebPubItem\", f:parsenoop },\n\t0x022D: { n:\"BrtEndWebPubItem\", f:parsenoop },\n\t0x022E: { n:\"BrtBeginSXCondFmt\", f:parsenoop },\n\t0x022F: { n:\"BrtEndSXCondFmt\", f:parsenoop },\n\t0x0230: { n:\"BrtBeginSXCondFmts\", f:parsenoop },\n\t0x0231: { n:\"BrtEndSXCondFmts\", f:parsenoop },\n\t0x0232: { n:\"BrtBkHim\", f:parsenoop },\n\t0x0234: { n:\"BrtColor\", f:parsenoop },\n\t0x0235: { n:\"BrtBeginIndexedColors\", f:parsenoop },\n\t0x0236: { n:\"BrtEndIndexedColors\", f:parsenoop },\n\t0x0239: { n:\"BrtBeginMRUColors\", f:parsenoop },\n\t0x023A: { n:\"BrtEndMRUColors\", f:parsenoop },\n\t0x023C: { n:\"BrtMRUColor\", f:parsenoop },\n\t0x023D: { n:\"BrtBeginDVals\", f:parsenoop },\n\t0x023E: { n:\"BrtEndDVals\", f:parsenoop },\n\t0x0241: { n:\"BrtSupNameStart\", f:parsenoop },\n\t0x0242: { n:\"BrtSupNameValueStart\", f:parsenoop },\n\t0x0243: { n:\"BrtSupNameValueEnd\", f:parsenoop },\n\t0x0244: { n:\"BrtSupNameNum\", f:parsenoop },\n\t0x0245: { n:\"BrtSupNameErr\", f:parsenoop },\n\t0x0246: { n:\"BrtSupNameSt\", f:parsenoop },\n\t0x0247: { n:\"BrtSupNameNil\", f:parsenoop },\n\t0x0248: { n:\"BrtSupNameBool\", f:parsenoop },\n\t0x0249: { n:\"BrtSupNameFmla\", f:parsenoop },\n\t0x024A: { n:\"BrtSupNameBits\", f:parsenoop },\n\t0x024B: { n:\"BrtSupNameEnd\", f:parsenoop },\n\t0x024C: { n:\"BrtEndSupBook\", f:parsenoop },\n\t0x024D: { n:\"BrtCellSmartTagProperty\", f:parsenoop },\n\t0x024E: { n:\"BrtBeginCellSmartTag\", f:parsenoop },\n\t0x024F: { n:\"BrtEndCellSmartTag\", f:parsenoop },\n\t0x0250: { n:\"BrtBeginCellSmartTags\", f:parsenoop },\n\t0x0251: { n:\"BrtEndCellSmartTags\", f:parsenoop },\n\t0x0252: { n:\"BrtBeginSmartTags\", f:parsenoop },\n\t0x0253: { n:\"BrtEndSmartTags\", f:parsenoop },\n\t0x0254: { n:\"BrtSmartTagType\", f:parsenoop },\n\t0x0255: { n:\"BrtBeginSmartTagTypes\", f:parsenoop },\n\t0x0256: { n:\"BrtEndSmartTagTypes\", f:parsenoop },\n\t0x0257: { n:\"BrtBeginSXFilters\", f:parsenoop },\n\t0x0258: { n:\"BrtEndSXFilters\", f:parsenoop },\n\t0x0259: { n:\"BrtBeginSXFILTER\", f:parsenoop },\n\t0x025A: { n:\"BrtEndSXFilter\", f:parsenoop },\n\t0x025B: { n:\"BrtBeginFills\", f:parsenoop },\n\t0x025C: { n:\"BrtEndFills\", f:parsenoop },\n\t0x025D: { n:\"BrtBeginCellWatches\", f:parsenoop },\n\t0x025E: { n:\"BrtEndCellWatches\", f:parsenoop },\n\t0x025F: { n:\"BrtCellWatch\", f:parsenoop },\n\t0x0260: { n:\"BrtBeginCRErrs\", f:parsenoop },\n\t0x0261: { n:\"BrtEndCRErrs\", f:parsenoop },\n\t0x0262: { n:\"BrtCrashRecErr\", f:parsenoop },\n\t0x0263: { n:\"BrtBeginFonts\", f:parsenoop },\n\t0x0264: { n:\"BrtEndFonts\", f:parsenoop },\n\t0x0265: { n:\"BrtBeginBorders\", f:parsenoop },\n\t0x0266: { n:\"BrtEndBorders\", f:parsenoop },\n\t0x0267: { n:\"BrtBeginFmts\", f:parsenoop },\n\t0x0268: { n:\"BrtEndFmts\", f:parsenoop },\n\t0x0269: { n:\"BrtBeginCellXFs\", f:parsenoop },\n\t0x026A: { n:\"BrtEndCellXFs\", f:parsenoop },\n\t0x026B: { n:\"BrtBeginStyles\", f:parsenoop },\n\t0x026C: { n:\"BrtEndStyles\", f:parsenoop },\n\t0x0271: { n:\"BrtBigName\", f:parsenoop },\n\t0x0272: { n:\"BrtBeginCellStyleXFs\", f:parsenoop },\n\t0x0273: { n:\"BrtEndCellStyleXFs\", f:parsenoop },\n\t0x0274: { n:\"BrtBeginComments\", f:parsenoop },\n\t0x0275: { n:\"BrtEndComments\", f:parsenoop },\n\t0x0276: { n:\"BrtBeginCommentAuthors\", f:parsenoop },\n\t0x0277: { n:\"BrtEndCommentAuthors\", f:parsenoop },\n\t0x0278: { n:\"BrtCommentAuthor\", f:parse_BrtCommentAuthor },\n\t0x0279: { n:\"BrtBeginCommentList\", f:parsenoop },\n\t0x027A: { n:\"BrtEndCommentList\", f:parsenoop },\n\t0x027B: { n:\"BrtBeginComment\", f:parse_BrtBeginComment},\n\t0x027C: { n:\"BrtEndComment\", f:parsenoop },\n\t0x027D: { n:\"BrtCommentText\", f:parse_BrtCommentText },\n\t0x027E: { n:\"BrtBeginOleObjects\", f:parsenoop },\n\t0x027F: { n:\"BrtOleObject\", f:parsenoop },\n\t0x0280: { n:\"BrtEndOleObjects\", f:parsenoop },\n\t0x0281: { n:\"BrtBeginSxrules\", f:parsenoop },\n\t0x0282: { n:\"BrtEndSxRules\", f:parsenoop },\n\t0x0283: { n:\"BrtBeginActiveXControls\", f:parsenoop },\n\t0x0284: { n:\"BrtActiveX\", f:parsenoop },\n\t0x0285: { n:\"BrtEndActiveXControls\", f:parsenoop },\n\t0x0286: { n:\"BrtBeginPCDSDTCEMembersSortBy\", f:parsenoop },\n\t0x0288: { n:\"BrtBeginCellIgnoreECs\", f:parsenoop },\n\t0x0289: { n:\"BrtCellIgnoreEC\", f:parsenoop },\n\t0x028A: { n:\"BrtEndCellIgnoreECs\", f:parsenoop },\n\t0x028B: { n:\"BrtCsProp\", f:parsenoop },\n\t0x028C: { n:\"BrtCsPageSetup\", f:parsenoop },\n\t0x028D: { n:\"BrtBeginUserCsViews\", f:parsenoop },\n\t0x028E: { n:\"BrtEndUserCsViews\", f:parsenoop },\n\t0x028F: { n:\"BrtBeginUserCsView\", f:parsenoop },\n\t0x0290: { n:\"BrtEndUserCsView\", f:parsenoop },\n\t0x0291: { n:\"BrtBeginPcdSFCIEntries\", f:parsenoop },\n\t0x0292: { n:\"BrtEndPCDSFCIEntries\", f:parsenoop },\n\t0x0293: { n:\"BrtPCDSFCIEntry\", f:parsenoop },\n\t0x0294: { n:\"BrtBeginListParts\", f:parsenoop },\n\t0x0295: { n:\"BrtListPart\", f:parsenoop },\n\t0x0296: { n:\"BrtEndListParts\", f:parsenoop },\n\t0x0297: { n:\"BrtSheetCalcProp\", f:parsenoop },\n\t0x0298: { n:\"BrtBeginFnGroup\", f:parsenoop },\n\t0x0299: { n:\"BrtFnGroup\", f:parsenoop },\n\t0x029A: { n:\"BrtEndFnGroup\", f:parsenoop },\n\t0x029B: { n:\"BrtSupAddin\", f:parsenoop },\n\t0x029C: { n:\"BrtSXTDMPOrder\", f:parsenoop },\n\t0x029D: { n:\"BrtCsProtection\", f:parsenoop },\n\t0x029F: { n:\"BrtBeginWsSortMap\", f:parsenoop },\n\t0x02A0: { n:\"BrtEndWsSortMap\", f:parsenoop },\n\t0x02A1: { n:\"BrtBeginRRSort\", f:parsenoop },\n\t0x02A2: { n:\"BrtEndRRSort\", f:parsenoop },\n\t0x02A3: { n:\"BrtRRSortItem\", f:parsenoop },\n\t0x02A4: { n:\"BrtFileSharingIso\", f:parsenoop },\n\t0x02A5: { n:\"BrtBookProtectionIso\", f:parsenoop },\n\t0x02A6: { n:\"BrtSheetProtectionIso\", f:parsenoop },\n\t0x02A7: { n:\"BrtCsProtectionIso\", f:parsenoop },\n\t0x02A8: { n:\"BrtRangeProtectionIso\", f:parsenoop },\n\t0x0400: { n:\"BrtRwDescent\", f:parsenoop },\n\t0x0401: { n:\"BrtKnownFonts\", f:parsenoop },\n\t0x0402: { n:\"BrtBeginSXTupleSet\", f:parsenoop },\n\t0x0403: { n:\"BrtEndSXTupleSet\", f:parsenoop },\n\t0x0404: { n:\"BrtBeginSXTupleSetHeader\", f:parsenoop },\n\t0x0405: { n:\"BrtEndSXTupleSetHeader\", f:parsenoop },\n\t0x0406: { n:\"BrtSXTupleSetHeaderItem\", f:parsenoop },\n\t0x0407: { n:\"BrtBeginSXTupleSetData\", f:parsenoop },\n\t0x0408: { n:\"BrtEndSXTupleSetData\", f:parsenoop },\n\t0x0409: { n:\"BrtBeginSXTupleSetRow\", f:parsenoop },\n\t0x040A: { n:\"BrtEndSXTupleSetRow\", f:parsenoop },\n\t0x040B: { n:\"BrtSXTupleSetRowItem\", f:parsenoop },\n\t0x040C: { n:\"BrtNameExt\", f:parsenoop },\n\t0x040D: { n:\"BrtPCDH14\", f:parsenoop },\n\t0x040E: { n:\"BrtBeginPCDCalcMem14\", f:parsenoop },\n\t0x040F: { n:\"BrtEndPCDCalcMem14\", f:parsenoop },\n\t0x0410: { n:\"BrtSXTH14\", f:parsenoop },\n\t0x0411: { n:\"BrtBeginSparklineGroup\", f:parsenoop },\n\t0x0412: { n:\"BrtEndSparklineGroup\", f:parsenoop },\n\t0x0413: { n:\"BrtSparkline\", f:parsenoop },\n\t0x0414: { n:\"BrtSXDI14\", f:parsenoop },\n\t0x0415: { n:\"BrtWsFmtInfoEx14\", f:parsenoop },\n\t0x0416: { n:\"BrtBeginConditionalFormatting14\", f:parsenoop },\n\t0x0417: { n:\"BrtEndConditionalFormatting14\", f:parsenoop },\n\t0x0418: { n:\"BrtBeginCFRule14\", f:parsenoop },\n\t0x0419: { n:\"BrtEndCFRule14\", f:parsenoop },\n\t0x041A: { n:\"BrtCFVO14\", f:parsenoop },\n\t0x041B: { n:\"BrtBeginDatabar14\", f:parsenoop },\n\t0x041C: { n:\"BrtBeginIconSet14\", f:parsenoop },\n\t0x041D: { n:\"BrtDVal14\", f:parsenoop },\n\t0x041E: { n:\"BrtBeginDVals14\", f:parsenoop },\n\t0x041F: { n:\"BrtColor14\", f:parsenoop },\n\t0x0420: { n:\"BrtBeginSparklines\", f:parsenoop },\n\t0x0421: { n:\"BrtEndSparklines\", f:parsenoop },\n\t0x0422: { n:\"BrtBeginSparklineGroups\", f:parsenoop },\n\t0x0423: { n:\"BrtEndSparklineGroups\", f:parsenoop },\n\t0x0425: { n:\"BrtSXVD14\", f:parsenoop },\n\t0x0426: { n:\"BrtBeginSxview14\", f:parsenoop },\n\t0x0427: { n:\"BrtEndSxview14\", f:parsenoop },\n\t0x042A: { n:\"BrtBeginPCD14\", f:parsenoop },\n\t0x042B: { n:\"BrtEndPCD14\", f:parsenoop },\n\t0x042C: { n:\"BrtBeginExtConn14\", f:parsenoop },\n\t0x042D: { n:\"BrtEndExtConn14\", f:parsenoop },\n\t0x042E: { n:\"BrtBeginSlicerCacheIDs\", f:parsenoop },\n\t0x042F: { n:\"BrtEndSlicerCacheIDs\", f:parsenoop },\n\t0x0430: { n:\"BrtBeginSlicerCacheID\", f:parsenoop },\n\t0x0431: { n:\"BrtEndSlicerCacheID\", f:parsenoop },\n\t0x0433: { n:\"BrtBeginSlicerCache\", f:parsenoop },\n\t0x0434: { n:\"BrtEndSlicerCache\", f:parsenoop },\n\t0x0435: { n:\"BrtBeginSlicerCacheDef\", f:parsenoop },\n\t0x0436: { n:\"BrtEndSlicerCacheDef\", f:parsenoop },\n\t0x0437: { n:\"BrtBeginSlicersEx\", f:parsenoop },\n\t0x0438: { n:\"BrtEndSlicersEx\", f:parsenoop },\n\t0x0439: { n:\"BrtBeginSlicerEx\", f:parsenoop },\n\t0x043A: { n:\"BrtEndSlicerEx\", f:parsenoop },\n\t0x043B: { n:\"BrtBeginSlicer\", f:parsenoop },\n\t0x043C: { n:\"BrtEndSlicer\", f:parsenoop },\n\t0x043D: { n:\"BrtSlicerCachePivotTables\", f:parsenoop },\n\t0x043E: { n:\"BrtBeginSlicerCacheOlapImpl\", f:parsenoop },\n\t0x043F: { n:\"BrtEndSlicerCacheOlapImpl\", f:parsenoop },\n\t0x0440: { n:\"BrtBeginSlicerCacheLevelsData\", f:parsenoop },\n\t0x0441: { n:\"BrtEndSlicerCacheLevelsData\", f:parsenoop },\n\t0x0442: { n:\"BrtBeginSlicerCacheLevelData\", f:parsenoop },\n\t0x0443: { n:\"BrtEndSlicerCacheLevelData\", f:parsenoop },\n\t0x0444: { n:\"BrtBeginSlicerCacheSiRanges\", f:parsenoop },\n\t0x0445: { n:\"BrtEndSlicerCacheSiRanges\", f:parsenoop },\n\t0x0446: { n:\"BrtBeginSlicerCacheSiRange\", f:parsenoop },\n\t0x0447: { n:\"BrtEndSlicerCacheSiRange\", f:parsenoop },\n\t0x0448: { n:\"BrtSlicerCacheOlapItem\", f:parsenoop },\n\t0x0449: { n:\"BrtBeginSlicerCacheSelections\", f:parsenoop },\n\t0x044A: { n:\"BrtSlicerCacheSelection\", f:parsenoop },\n\t0x044B: { n:\"BrtEndSlicerCacheSelections\", f:parsenoop },\n\t0x044C: { n:\"BrtBeginSlicerCacheNative\", f:parsenoop },\n\t0x044D: { n:\"BrtEndSlicerCacheNative\", f:parsenoop },\n\t0x044E: { n:\"BrtSlicerCacheNativeItem\", f:parsenoop },\n\t0x044F: { n:\"BrtRangeProtection14\", f:parsenoop },\n\t0x0450: { n:\"BrtRangeProtectionIso14\", f:parsenoop },\n\t0x0451: { n:\"BrtCellIgnoreEC14\", f:parsenoop },\n\t0x0457: { n:\"BrtList14\", f:parsenoop },\n\t0x0458: { n:\"BrtCFIcon\", f:parsenoop },\n\t0x0459: { n:\"BrtBeginSlicerCachesPivotCacheIDs\", f:parsenoop },\n\t0x045A: { n:\"BrtEndSlicerCachesPivotCacheIDs\", f:parsenoop },\n\t0x045B: { n:\"BrtBeginSlicers\", f:parsenoop },\n\t0x045C: { n:\"BrtEndSlicers\", f:parsenoop },\n\t0x045D: { n:\"BrtWbProp14\", f:parsenoop },\n\t0x045E: { n:\"BrtBeginSXEdit\", f:parsenoop },\n\t0x045F: { n:\"BrtEndSXEdit\", f:parsenoop },\n\t0x0460: { n:\"BrtBeginSXEdits\", f:parsenoop },\n\t0x0461: { n:\"BrtEndSXEdits\", f:parsenoop },\n\t0x0462: { n:\"BrtBeginSXChange\", f:parsenoop },\n\t0x0463: { n:\"BrtEndSXChange\", f:parsenoop },\n\t0x0464: { n:\"BrtBeginSXChanges\", f:parsenoop },\n\t0x0465: { n:\"BrtEndSXChanges\", f:parsenoop },\n\t0x0466: { n:\"BrtSXTupleItems\", f:parsenoop },\n\t0x0468: { n:\"BrtBeginSlicerStyle\", f:parsenoop },\n\t0x0469: { n:\"BrtEndSlicerStyle\", f:parsenoop },\n\t0x046A: { n:\"BrtSlicerStyleElement\", f:parsenoop },\n\t0x046B: { n:\"BrtBeginStyleSheetExt14\", f:parsenoop },\n\t0x046C: { n:\"BrtEndStyleSheetExt14\", f:parsenoop },\n\t0x046D: { n:\"BrtBeginSlicerCachesPivotCacheID\", f:parsenoop },\n\t0x046E: { n:\"BrtEndSlicerCachesPivotCacheID\", f:parsenoop },\n\t0x046F: { n:\"BrtBeginConditionalFormattings\", f:parsenoop },\n\t0x0470: { n:\"BrtEndConditionalFormattings\", f:parsenoop },\n\t0x0471: { n:\"BrtBeginPCDCalcMemExt\", f:parsenoop },\n\t0x0472: { n:\"BrtEndPCDCalcMemExt\", f:parsenoop },\n\t0x0473: { n:\"BrtBeginPCDCalcMemsExt\", f:parsenoop },\n\t0x0474: { n:\"BrtEndPCDCalcMemsExt\", f:parsenoop },\n\t0x0475: { n:\"BrtPCDField14\", f:parsenoop },\n\t0x0476: { n:\"BrtBeginSlicerStyles\", f:parsenoop },\n\t0x0477: { n:\"BrtEndSlicerStyles\", f:parsenoop },\n\t0x0478: { n:\"BrtBeginSlicerStyleElements\", f:parsenoop },\n\t0x0479: { n:\"BrtEndSlicerStyleElements\", f:parsenoop },\n\t0x047A: { n:\"BrtCFRuleExt\", f:parsenoop },\n\t0x047B: { n:\"BrtBeginSXCondFmt14\", f:parsenoop },\n\t0x047C: { n:\"BrtEndSXCondFmt14\", f:parsenoop },\n\t0x047D: { n:\"BrtBeginSXCondFmts14\", f:parsenoop },\n\t0x047E: { n:\"BrtEndSXCondFmts14\", f:parsenoop },\n\t0x0480: { n:\"BrtBeginSortCond14\", f:parsenoop },\n\t0x0481: { n:\"BrtEndSortCond14\", f:parsenoop },\n\t0x0482: { n:\"BrtEndDVals14\", f:parsenoop },\n\t0x0483: { n:\"BrtEndIconSet14\", f:parsenoop },\n\t0x0484: { n:\"BrtEndDatabar14\", f:parsenoop },\n\t0x0485: { n:\"BrtBeginColorScale14\", f:parsenoop },\n\t0x0486: { n:\"BrtEndColorScale14\", f:parsenoop },\n\t0x0487: { n:\"BrtBeginSxrules14\", f:parsenoop },\n\t0x0488: { n:\"BrtEndSxrules14\", f:parsenoop },\n\t0x0489: { n:\"BrtBeginPRule14\", f:parsenoop },\n\t0x048A: { n:\"BrtEndPRule14\", f:parsenoop },\n\t0x048B: { n:\"BrtBeginPRFilters14\", f:parsenoop },\n\t0x048C: { n:\"BrtEndPRFilters14\", f:parsenoop },\n\t0x048D: { n:\"BrtBeginPRFilter14\", f:parsenoop },\n\t0x048E: { n:\"BrtEndPRFilter14\", f:parsenoop },\n\t0x048F: { n:\"BrtBeginPRFItem14\", f:parsenoop },\n\t0x0490: { n:\"BrtEndPRFItem14\", f:parsenoop },\n\t0x0491: { n:\"BrtBeginCellIgnoreECs14\", f:parsenoop },\n\t0x0492: { n:\"BrtEndCellIgnoreECs14\", f:parsenoop },\n\t0x0493: { n:\"BrtDxf14\", f:parsenoop },\n\t0x0494: { n:\"BrtBeginDxF14s\", f:parsenoop },\n\t0x0495: { n:\"BrtEndDxf14s\", f:parsenoop },\n\t0x0499: { n:\"BrtFilter14\", f:parsenoop },\n\t0x049A: { n:\"BrtBeginCustomFilters14\", f:parsenoop },\n\t0x049C: { n:\"BrtCustomFilter14\", f:parsenoop },\n\t0x049D: { n:\"BrtIconFilter14\", f:parsenoop },\n\t0x049E: { n:\"BrtPivotCacheConnectionName\", f:parsenoop },\n\t0x0800: { n:\"BrtBeginDecoupledPivotCacheIDs\", f:parsenoop },\n\t0x0801: { n:\"BrtEndDecoupledPivotCacheIDs\", f:parsenoop },\n\t0x0802: { n:\"BrtDecoupledPivotCacheID\", f:parsenoop },\n\t0x0803: { n:\"BrtBeginPivotTableRefs\", f:parsenoop },\n\t0x0804: { n:\"BrtEndPivotTableRefs\", f:parsenoop },\n\t0x0805: { n:\"BrtPivotTableRef\", f:parsenoop },\n\t0x0806: { n:\"BrtSlicerCacheBookPivotTables\", f:parsenoop },\n\t0x0807: { n:\"BrtBeginSxvcells\", f:parsenoop },\n\t0x0808: { n:\"BrtEndSxvcells\", f:parsenoop },\n\t0x0809: { n:\"BrtBeginSxRow\", f:parsenoop },\n\t0x080A: { n:\"BrtEndSxRow\", f:parsenoop },\n\t0x080C: { n:\"BrtPcdCalcMem15\", f:parsenoop },\n\t0x0813: { n:\"BrtQsi15\", f:parsenoop },\n\t0x0814: { n:\"BrtBeginWebExtensions\", f:parsenoop },\n\t0x0815: { n:\"BrtEndWebExtensions\", f:parsenoop },\n\t0x0816: { n:\"BrtWebExtension\", f:parsenoop },\n\t0x0817: { n:\"BrtAbsPath15\", f:parsenoop },\n\t0x0818: { n:\"BrtBeginPivotTableUISettings\", f:parsenoop },\n\t0x0819: { n:\"BrtEndPivotTableUISettings\", f:parsenoop },\n\t0x081B: { n:\"BrtTableSlicerCacheIDs\", f:parsenoop },\n\t0x081C: { n:\"BrtTableSlicerCacheID\", f:parsenoop },\n\t0x081D: { n:\"BrtBeginTableSlicerCache\", f:parsenoop },\n\t0x081E: { n:\"BrtEndTableSlicerCache\", f:parsenoop },\n\t0x081F: { n:\"BrtSxFilter15\", f:parsenoop },\n\t0x0820: { n:\"BrtBeginTimelineCachePivotCacheIDs\", f:parsenoop },\n\t0x0821: { n:\"BrtEndTimelineCachePivotCacheIDs\", f:parsenoop },\n\t0x0822: { n:\"BrtTimelineCachePivotCacheID\", f:parsenoop },\n\t0x0823: { n:\"BrtBeginTimelineCacheIDs\", f:parsenoop },\n\t0x0824: { n:\"BrtEndTimelineCacheIDs\", f:parsenoop },\n\t0x0825: { n:\"BrtBeginTimelineCacheID\", f:parsenoop },\n\t0x0826: { n:\"BrtEndTimelineCacheID\", f:parsenoop },\n\t0x0827: { n:\"BrtBeginTimelinesEx\", f:parsenoop },\n\t0x0828: { n:\"BrtEndTimelinesEx\", f:parsenoop },\n\t0x0829: { n:\"BrtBeginTimelineEx\", f:parsenoop },\n\t0x082A: { n:\"BrtEndTimelineEx\", f:parsenoop },\n\t0x082B: { n:\"BrtWorkBookPr15\", f:parsenoop },\n\t0x082C: { n:\"BrtPCDH15\", f:parsenoop },\n\t0x082D: { n:\"BrtBeginTimelineStyle\", f:parsenoop },\n\t0x082E: { n:\"BrtEndTimelineStyle\", f:parsenoop },\n\t0x082F: { n:\"BrtTimelineStyleElement\", f:parsenoop },\n\t0x0830: { n:\"BrtBeginTimelineStylesheetExt15\", f:parsenoop },\n\t0x0831: { n:\"BrtEndTimelineStylesheetExt15\", f:parsenoop },\n\t0x0832: { n:\"BrtBeginTimelineStyles\", f:parsenoop },\n\t0x0833: { n:\"BrtEndTimelineStyles\", f:parsenoop },\n\t0x0834: { n:\"BrtBeginTimelineStyleElements\", f:parsenoop },\n\t0x0835: { n:\"BrtEndTimelineStyleElements\", f:parsenoop },\n\t0x0836: { n:\"BrtDxf15\", f:parsenoop },\n\t0x0837: { n:\"BrtBeginDxfs15\", f:parsenoop },\n\t0x0838: { n:\"brtEndDxfs15\", f:parsenoop },\n\t0x0839: { n:\"BrtSlicerCacheHideItemsWithNoData\", f:parsenoop },\n\t0x083A: { n:\"BrtBeginItemUniqueNames\", f:parsenoop },\n\t0x083B: { n:\"BrtEndItemUniqueNames\", f:parsenoop },\n\t0x083C: { n:\"BrtItemUniqueName\", f:parsenoop },\n\t0x083D: { n:\"BrtBeginExtConn15\", f:parsenoop },\n\t0x083E: { n:\"BrtEndExtConn15\", f:parsenoop },\n\t0x083F: { n:\"BrtBeginOledbPr15\", f:parsenoop },\n\t0x0840: { n:\"BrtEndOledbPr15\", f:parsenoop },\n\t0x0841: { n:\"BrtBeginDataFeedPr15\", f:parsenoop },\n\t0x0842: { n:\"BrtEndDataFeedPr15\", f:parsenoop },\n\t0x0843: { n:\"BrtTextPr15\", f:parsenoop },\n\t0x0844: { n:\"BrtRangePr15\", f:parsenoop },\n\t0x0845: { n:\"BrtDbCommand15\", f:parsenoop },\n\t0x0846: { n:\"BrtBeginDbTables15\", f:parsenoop },\n\t0x0847: { n:\"BrtEndDbTables15\", f:parsenoop },\n\t0x0848: { n:\"BrtDbTable15\", f:parsenoop },\n\t0x0849: { n:\"BrtBeginDataModel\", f:parsenoop },\n\t0x084A: { n:\"BrtEndDataModel\", f:parsenoop },\n\t0x084B: { n:\"BrtBeginModelTables\", f:parsenoop },\n\t0x084C: { n:\"BrtEndModelTables\", f:parsenoop },\n\t0x084D: { n:\"BrtModelTable\", f:parsenoop },\n\t0x084E: { n:\"BrtBeginModelRelationships\", f:parsenoop },\n\t0x084F: { n:\"BrtEndModelRelationships\", f:parsenoop },\n\t0x0850: { n:\"BrtModelRelationship\", f:parsenoop },\n\t0x0851: { n:\"BrtBeginECTxtWiz15\", f:parsenoop },\n\t0x0852: { n:\"BrtEndECTxtWiz15\", f:parsenoop },\n\t0x0853: { n:\"BrtBeginECTWFldInfoLst15\", f:parsenoop },\n\t0x0854: { n:\"BrtEndECTWFldInfoLst15\", f:parsenoop },\n\t0x0855: { n:\"BrtBeginECTWFldInfo15\", f:parsenoop },\n\t0x0856: { n:\"BrtFieldListActiveItem\", f:parsenoop },\n\t0x0857: { n:\"BrtPivotCacheIdVersion\", f:parsenoop },\n\t0x0858: { n:\"BrtSXDI15\", f:parsenoop },\n\t0xFFFF: { n:\"\", f:parsenoop }\n};\n\nvar evert_RE = evert_key(XLSBRecordEnum, 'n');\n\n/* [MS-XLS] 2.3 Record Enumeration */\nvar XLSRecordEnum = {\n\t0x0003: { n:\"BIFF2NUM\", f:parse_BIFF2NUM },\n\t0x0004: { n:\"BIFF2STR\", f:parse_BIFF2STR },\n\t0x0006: { n:\"Formula\", f:parse_Formula },\n\t0x0009: { n:'BOF', f:parse_BOF },\n\t0x000a: { n:'EOF', f:parse_EOF },\n\t0x000c: { n:\"CalcCount\", f:parse_CalcCount },\n\t0x000d: { n:\"CalcMode\", f:parse_CalcMode },\n\t0x000e: { n:\"CalcPrecision\", f:parse_CalcPrecision },\n\t0x000f: { n:\"CalcRefMode\", f:parse_CalcRefMode },\n\t0x0010: { n:\"CalcDelta\", f:parse_CalcDelta },\n\t0x0011: { n:\"CalcIter\", f:parse_CalcIter },\n\t0x0012: { n:\"Protect\", f:parse_Protect },\n\t0x0013: { n:\"Password\", f:parse_Password },\n\t0x0014: { n:\"Header\", f:parse_Header },\n\t0x0015: { n:\"Footer\", f:parse_Footer },\n\t0x0017: { n:\"ExternSheet\", f:parse_ExternSheet },\n\t0x0018: { n:\"Lbl\", f:parse_Lbl },\n\t0x0019: { n:\"WinProtect\", f:parse_WinProtect },\n\t0x001a: { n:\"VerticalPageBreaks\", f:parse_VerticalPageBreaks },\n\t0x001b: { n:\"HorizontalPageBreaks\", f:parse_HorizontalPageBreaks },\n\t0x001c: { n:\"Note\", f:parse_Note },\n\t0x001d: { n:\"Selection\", f:parse_Selection },\n\t0x0022: { n:\"Date1904\", f:parse_Date1904 },\n\t0x0023: { n:\"ExternName\", f:parse_ExternName },\n\t0x0026: { n:\"LeftMargin\", f:parse_LeftMargin },\n\t0x0027: { n:\"RightMargin\", f:parse_RightMargin },\n\t0x0028: { n:\"TopMargin\", f:parse_TopMargin },\n\t0x0029: { n:\"BottomMargin\", f:parse_BottomMargin },\n\t0x002a: { n:\"PrintRowCol\", f:parse_PrintRowCol },\n\t0x002b: { n:\"PrintGrid\", f:parse_PrintGrid },\n\t0x002f: { n:\"FilePass\", f:parse_FilePass },\n\t0x0031: { n:\"Font\", f:parse_Font },\n\t0x0033: { n:\"PrintSize\", f:parse_PrintSize },\n\t0x003c: { n:\"Continue\", f:parse_Continue },\n\t0x003d: { n:\"Window1\", f:parse_Window1 },\n\t0x0040: { n:\"Backup\", f:parse_Backup },\n\t0x0041: { n:\"Pane\", f:parse_Pane },\n\t0x0042: { n:'CodePage', f:parse_CodePage },\n\t0x004d: { n:\"Pls\", f:parse_Pls },\n\t0x0050: { n:\"DCon\", f:parse_DCon },\n\t0x0051: { n:\"DConRef\", f:parse_DConRef },\n\t0x0052: { n:\"DConName\", f:parse_DConName },\n\t0x0055: { n:\"DefColWidth\", f:parse_DefColWidth },\n\t0x0059: { n:\"XCT\", f:parse_XCT },\n\t0x005a: { n:\"CRN\", f:parse_CRN },\n\t0x005b: { n:\"FileSharing\", f:parse_FileSharing },\n\t0x005c: { n:'WriteAccess', f:parse_WriteAccess },\n\t0x005d: { n:\"Obj\", f:parse_Obj },\n\t0x005e: { n:\"Uncalced\", f:parse_Uncalced },\n\t0x005f: { n:\"CalcSaveRecalc\", f:parse_CalcSaveRecalc },\n\t0x0060: { n:\"Template\", f:parse_Template },\n\t0x0061: { n:\"Intl\", f:parse_Intl },\n\t0x0063: { n:\"ObjProtect\", f:parse_ObjProtect },\n\t0x007d: { n:\"ColInfo\", f:parse_ColInfo },\n\t0x0080: { n:\"Guts\", f:parse_Guts },\n\t0x0081: { n:\"WsBool\", f:parse_WsBool },\n\t0x0082: { n:\"GridSet\", f:parse_GridSet },\n\t0x0083: { n:\"HCenter\", f:parse_HCenter },\n\t0x0084: { n:\"VCenter\", f:parse_VCenter },\n\t0x0085: { n:'BoundSheet8', f:parse_BoundSheet8 },\n\t0x0086: { n:\"WriteProtect\", f:parse_WriteProtect },\n\t0x008c: { n:\"Country\", f:parse_Country },\n\t0x008d: { n:\"HideObj\", f:parse_HideObj },\n\t0x0090: { n:\"Sort\", f:parse_Sort },\n\t0x0092: { n:\"Palette\", f:parse_Palette },\n\t0x0097: { n:\"Sync\", f:parse_Sync },\n\t0x0098: { n:\"LPr\", f:parse_LPr },\n\t0x0099: { n:\"DxGCol\", f:parse_DxGCol },\n\t0x009a: { n:\"FnGroupName\", f:parse_FnGroupName },\n\t0x009b: { n:\"FilterMode\", f:parse_FilterMode },\n\t0x009c: { n:\"BuiltInFnGroupCount\", f:parse_BuiltInFnGroupCount },\n\t0x009d: { n:\"AutoFilterInfo\", f:parse_AutoFilterInfo },\n\t0x009e: { n:\"AutoFilter\", f:parse_AutoFilter },\n\t0x00a0: { n:\"Scl\", f:parse_Scl },\n\t0x00a1: { n:\"Setup\", f:parse_Setup },\n\t0x00ae: { n:\"ScenMan\", f:parse_ScenMan },\n\t0x00af: { n:\"SCENARIO\", f:parse_SCENARIO },\n\t0x00b0: { n:\"SxView\", f:parse_SxView },\n\t0x00b1: { n:\"Sxvd\", f:parse_Sxvd },\n\t0x00b2: { n:\"SXVI\", f:parse_SXVI },\n\t0x00b4: { n:\"SxIvd\", f:parse_SxIvd },\n\t0x00b5: { n:\"SXLI\", f:parse_SXLI },\n\t0x00b6: { n:\"SXPI\", f:parse_SXPI },\n\t0x00b8: { n:\"DocRoute\", f:parse_DocRoute },\n\t0x00b9: { n:\"RecipName\", f:parse_RecipName },\n\t0x00bd: { n:\"MulRk\", f:parse_MulRk },\n\t0x00be: { n:\"MulBlank\", f:parse_MulBlank },\n\t0x00c1: { n:'Mms', f:parse_Mms },\n\t0x00c5: { n:\"SXDI\", f:parse_SXDI },\n\t0x00c6: { n:\"SXDB\", f:parse_SXDB },\n\t0x00c7: { n:\"SXFDB\", f:parse_SXFDB },\n\t0x00c8: { n:\"SXDBB\", f:parse_SXDBB },\n\t0x00c9: { n:\"SXNum\", f:parse_SXNum },\n\t0x00ca: { n:\"SxBool\", f:parse_SxBool },\n\t0x00cb: { n:\"SxErr\", f:parse_SxErr },\n\t0x00cc: { n:\"SXInt\", f:parse_SXInt },\n\t0x00cd: { n:\"SXString\", f:parse_SXString },\n\t0x00ce: { n:\"SXDtr\", f:parse_SXDtr },\n\t0x00cf: { n:\"SxNil\", f:parse_SxNil },\n\t0x00d0: { n:\"SXTbl\", f:parse_SXTbl },\n\t0x00d1: { n:\"SXTBRGIITM\", f:parse_SXTBRGIITM },\n\t0x00d2: { n:\"SxTbpg\", f:parse_SxTbpg },\n\t0x00d3: { n:\"ObProj\", f:parse_ObProj },\n\t0x00d5: { n:\"SXStreamID\", f:parse_SXStreamID },\n\t0x00d7: { n:\"DBCell\", f:parse_DBCell },\n\t0x00d8: { n:\"SXRng\", f:parse_SXRng },\n\t0x00d9: { n:\"SxIsxoper\", f:parse_SxIsxoper },\n\t0x00da: { n:\"BookBool\", f:parse_BookBool },\n\t0x00dc: { n:\"DbOrParamQry\", f:parse_DbOrParamQry },\n\t0x00dd: { n:\"ScenarioProtect\", f:parse_ScenarioProtect },\n\t0x00de: { n:\"OleObjectSize\", f:parse_OleObjectSize },\n\t0x00e0: { n:\"XF\", f:parse_XF },\n\t0x00e1: { n:'InterfaceHdr', f:parse_InterfaceHdr },\n\t0x00e2: { n:'InterfaceEnd', f:parse_InterfaceEnd },\n\t0x00e3: { n:\"SXVS\", f:parse_SXVS },\n\t0x00e5: { n:\"MergeCells\", f:parse_MergeCells },\n\t0x00e9: { n:\"BkHim\", f:parse_BkHim },\n\t0x00eb: { n:\"MsoDrawingGroup\", f:parse_MsoDrawingGroup },\n\t0x00ec: { n:\"MsoDrawing\", f:parse_MsoDrawing },\n\t0x00ed: { n:\"MsoDrawingSelection\", f:parse_MsoDrawingSelection },\n\t0x00ef: { n:\"PhoneticInfo\", f:parse_PhoneticInfo },\n\t0x00f0: { n:\"SxRule\", f:parse_SxRule },\n\t0x00f1: { n:\"SXEx\", f:parse_SXEx },\n\t0x00f2: { n:\"SxFilt\", f:parse_SxFilt },\n\t0x00f4: { n:\"SxDXF\", f:parse_SxDXF },\n\t0x00f5: { n:\"SxItm\", f:parse_SxItm },\n\t0x00f6: { n:\"SxName\", f:parse_SxName },\n\t0x00f7: { n:\"SxSelect\", f:parse_SxSelect },\n\t0x00f8: { n:\"SXPair\", f:parse_SXPair },\n\t0x00f9: { n:\"SxFmla\", f:parse_SxFmla },\n\t0x00fb: { n:\"SxFormat\", f:parse_SxFormat },\n\t0x00fc: { n:\"SST\", f:parse_SST },\n\t0x00fd: { n:\"LabelSst\", f:parse_LabelSst },\n\t0x00ff: { n:\"ExtSST\", f:parse_ExtSST },\n\t0x0100: { n:\"SXVDEx\", f:parse_SXVDEx },\n\t0x0103: { n:\"SXFormula\", f:parse_SXFormula },\n\t0x0122: { n:\"SXDBEx\", f:parse_SXDBEx },\n\t0x0137: { n:\"RRDInsDel\", f:parse_RRDInsDel },\n\t0x0138: { n:\"RRDHead\", f:parse_RRDHead },\n\t0x013b: { n:\"RRDChgCell\", f:parse_RRDChgCell },\n\t0x013d: { n:\"RRTabId\", f:parse_RRTabId },\n\t0x013e: { n:\"RRDRenSheet\", f:parse_RRDRenSheet },\n\t0x013f: { n:\"RRSort\", f:parse_RRSort },\n\t0x0140: { n:\"RRDMove\", f:parse_RRDMove },\n\t0x014a: { n:\"RRFormat\", f:parse_RRFormat },\n\t0x014b: { n:\"RRAutoFmt\", f:parse_RRAutoFmt },\n\t0x014d: { n:\"RRInsertSh\", f:parse_RRInsertSh },\n\t0x014e: { n:\"RRDMoveBegin\", f:parse_RRDMoveBegin },\n\t0x014f: { n:\"RRDMoveEnd\", f:parse_RRDMoveEnd },\n\t0x0150: { n:\"RRDInsDelBegin\", f:parse_RRDInsDelBegin },\n\t0x0151: { n:\"RRDInsDelEnd\", f:parse_RRDInsDelEnd },\n\t0x0152: { n:\"RRDConflict\", f:parse_RRDConflict },\n\t0x0153: { n:\"RRDDefName\", f:parse_RRDDefName },\n\t0x0154: { n:\"RRDRstEtxp\", f:parse_RRDRstEtxp },\n\t0x015f: { n:\"LRng\", f:parse_LRng },\n\t0x0160: { n:\"UsesELFs\", f:parse_UsesELFs },\n\t0x0161: { n:\"DSF\", f:parse_DSF },\n\t0x0191: { n:\"CUsr\", f:parse_CUsr },\n\t0x0192: { n:\"CbUsr\", f:parse_CbUsr },\n\t0x0193: { n:\"UsrInfo\", f:parse_UsrInfo },\n\t0x0194: { n:\"UsrExcl\", f:parse_UsrExcl },\n\t0x0195: { n:\"FileLock\", f:parse_FileLock },\n\t0x0196: { n:\"RRDInfo\", f:parse_RRDInfo },\n\t0x0197: { n:\"BCUsrs\", f:parse_BCUsrs },\n\t0x0198: { n:\"UsrChk\", f:parse_UsrChk },\n\t0x01a9: { n:\"UserBView\", f:parse_UserBView },\n\t0x01aa: { n:\"UserSViewBegin\", f:parse_UserSViewBegin },\n\t0x01ab: { n:\"UserSViewEnd\", f:parse_UserSViewEnd },\n\t0x01ac: { n:\"RRDUserView\", f:parse_RRDUserView },\n\t0x01ad: { n:\"Qsi\", f:parse_Qsi },\n\t0x01ae: { n:\"SupBook\", f:parse_SupBook },\n\t0x01af: { n:\"Prot4Rev\", f:parse_Prot4Rev },\n\t0x01b0: { n:\"CondFmt\", f:parse_CondFmt },\n\t0x01b1: { n:\"CF\", f:parse_CF },\n\t0x01b2: { n:\"DVal\", f:parse_DVal },\n\t0x01b5: { n:\"DConBin\", f:parse_DConBin },\n\t0x01b6: { n:\"TxO\", f:parse_TxO },\n\t0x01b7: { n:\"RefreshAll\", f:parse_RefreshAll },\n\t0x01b8: { n:\"HLink\", f:parse_HLink },\n\t0x01b9: { n:\"Lel\", f:parse_Lel },\n\t0x01ba: { n:\"CodeName\", f:parse_XLSCodeName },\n\t0x01bb: { n:\"SXFDBType\", f:parse_SXFDBType },\n\t0x01bc: { n:\"Prot4RevPass\", f:parse_Prot4RevPass },\n\t0x01bd: { n:\"ObNoMacros\", f:parse_ObNoMacros },\n\t0x01be: { n:\"Dv\", f:parse_Dv },\n\t0x01c0: { n:\"Excel9File\", f:parse_Excel9File },\n\t0x01c1: { n:\"RecalcId\", f:parse_RecalcId, r:2},\n\t0x01c2: { n:\"EntExU2\", f:parse_EntExU2 },\n\t0x0200: { n:\"Dimensions\", f:parse_Dimensions },\n\t0x0201: { n:\"Blank\", f:parse_Blank },\n\t0x0203: { n:\"Number\", f:parse_Number },\n\t0x0204: { n:\"Label\", f:parse_Label },\n\t0x0205: { n:\"BoolErr\", f:parse_BoolErr },\n\t0x0207: { n:\"String\", f:parse_String },\n\t0x0208: { n:'Row', f:parse_Row },\n\t0x020b: { n:\"Index\", f:parse_Index },\n\t0x0221: { n:\"Array\", f:parse_Array },\n\t0x0225: { n:\"DefaultRowHeight\", f:parse_DefaultRowHeight },\n\t0x0236: { n:\"Table\", f:parse_Table },\n\t0x023e: { n:\"Window2\", f:parse_Window2 },\n\t0x027e: { n:\"RK\", f:parse_RK },\n\t0x0293: { n:\"Style\", f:parse_Style },\n\t0x0418: { n:\"BigName\", f:parse_BigName },\n\t0x041e: { n:\"Format\", f:parse_Format },\n\t0x043c: { n:\"ContinueBigName\", f:parse_ContinueBigName },\n\t0x04bc: { n:\"ShrFmla\", f:parse_ShrFmla },\n\t0x0800: { n:\"HLinkTooltip\", f:parse_HLinkTooltip },\n\t0x0801: { n:\"WebPub\", f:parse_WebPub },\n\t0x0802: { n:\"QsiSXTag\", f:parse_QsiSXTag },\n\t0x0803: { n:\"DBQueryExt\", f:parse_DBQueryExt },\n\t0x0804: { n:\"ExtString\", f:parse_ExtString },\n\t0x0805: { n:\"TxtQry\", f:parse_TxtQry },\n\t0x0806: { n:\"Qsir\", f:parse_Qsir },\n\t0x0807: { n:\"Qsif\", f:parse_Qsif },\n\t0x0808: { n:\"RRDTQSIF\", f:parse_RRDTQSIF },\n\t0x0809: { n:'BOF', f:parse_BOF },\n\t0x080a: { n:\"OleDbConn\", f:parse_OleDbConn },\n\t0x080b: { n:\"WOpt\", f:parse_WOpt },\n\t0x080c: { n:\"SXViewEx\", f:parse_SXViewEx },\n\t0x080d: { n:\"SXTH\", f:parse_SXTH },\n\t0x080e: { n:\"SXPIEx\", f:parse_SXPIEx },\n\t0x080f: { n:\"SXVDTEx\", f:parse_SXVDTEx },\n\t0x0810: { n:\"SXViewEx9\", f:parse_SXViewEx9 },\n\t0x0812: { n:\"ContinueFrt\", f:parse_ContinueFrt },\n\t0x0813: { n:\"RealTimeData\", f:parse_RealTimeData },\n\t0x0850: { n:\"ChartFrtInfo\", f:parse_ChartFrtInfo },\n\t0x0851: { n:\"FrtWrapper\", f:parse_FrtWrapper },\n\t0x0852: { n:\"StartBlock\", f:parse_StartBlock },\n\t0x0853: { n:\"EndBlock\", f:parse_EndBlock },\n\t0x0854: { n:\"StartObject\", f:parse_StartObject },\n\t0x0855: { n:\"EndObject\", f:parse_EndObject },\n\t0x0856: { n:\"CatLab\", f:parse_CatLab },\n\t0x0857: { n:\"YMult\", f:parse_YMult },\n\t0x0858: { n:\"SXViewLink\", f:parse_SXViewLink },\n\t0x0859: { n:\"PivotChartBits\", f:parse_PivotChartBits },\n\t0x085a: { n:\"FrtFontList\", f:parse_FrtFontList },\n\t0x0862: { n:\"SheetExt\", f:parse_SheetExt },\n\t0x0863: { n:\"BookExt\", f:parse_BookExt, r:12},\n\t0x0864: { n:\"SXAddl\", f:parse_SXAddl },\n\t0x0865: { n:\"CrErr\", f:parse_CrErr },\n\t0x0866: { n:\"HFPicture\", f:parse_HFPicture },\n\t0x0867: { n:'FeatHdr', f:parse_FeatHdr },\n\t0x0868: { n:\"Feat\", f:parse_Feat },\n\t0x086a: { n:\"DataLabExt\", f:parse_DataLabExt },\n\t0x086b: { n:\"DataLabExtContents\", f:parse_DataLabExtContents },\n\t0x086c: { n:\"CellWatch\", f:parse_CellWatch },\n\t0x0871: { n:\"FeatHdr11\", f:parse_FeatHdr11 },\n\t0x0872: { n:\"Feature11\", f:parse_Feature11 },\n\t0x0874: { n:\"DropDownObjIds\", f:parse_DropDownObjIds },\n\t0x0875: { n:\"ContinueFrt11\", f:parse_ContinueFrt11 },\n\t0x0876: { n:\"DConn\", f:parse_DConn },\n\t0x0877: { n:\"List12\", f:parse_List12 },\n\t0x0878: { n:\"Feature12\", f:parse_Feature12 },\n\t0x0879: { n:\"CondFmt12\", f:parse_CondFmt12 },\n\t0x087a: { n:\"CF12\", f:parse_CF12 },\n\t0x087b: { n:\"CFEx\", f:parse_CFEx },\n\t0x087c: { n:\"XFCRC\", f:parse_XFCRC, r:12 },\n\t0x087d: { n:\"XFExt\", f:parse_XFExt, r:12 },\n\t0x087e: { n:\"AutoFilter12\", f:parse_AutoFilter12 },\n\t0x087f: { n:\"ContinueFrt12\", f:parse_ContinueFrt12 },\n\t0x0884: { n:\"MDTInfo\", f:parse_MDTInfo },\n\t0x0885: { n:\"MDXStr\", f:parse_MDXStr },\n\t0x0886: { n:\"MDXTuple\", f:parse_MDXTuple },\n\t0x0887: { n:\"MDXSet\", f:parse_MDXSet },\n\t0x0888: { n:\"MDXProp\", f:parse_MDXProp },\n\t0x0889: { n:\"MDXKPI\", f:parse_MDXKPI },\n\t0x088a: { n:\"MDB\", f:parse_MDB },\n\t0x088b: { n:\"PLV\", f:parse_PLV },\n\t0x088c: { n:\"Compat12\", f:parse_Compat12, r:12 },\n\t0x088d: { n:\"DXF\", f:parse_DXF },\n\t0x088e: { n:\"TableStyles\", f:parse_TableStyles, r:12 },\n\t0x088f: { n:\"TableStyle\", f:parse_TableStyle },\n\t0x0890: { n:\"TableStyleElement\", f:parse_TableStyleElement },\n\t0x0892: { n:\"StyleExt\", f:parse_StyleExt },\n\t0x0893: { n:\"NamePublish\", f:parse_NamePublish },\n\t0x0894: { n:\"NameCmt\", f:parse_NameCmt },\n\t0x0895: { n:\"SortData\", f:parse_SortData },\n\t0x0896: { n:\"Theme\", f:parse_Theme, r:12 },\n\t0x0897: { n:\"GUIDTypeLib\", f:parse_GUIDTypeLib },\n\t0x0898: { n:\"FnGrp12\", f:parse_FnGrp12 },\n\t0x0899: { n:\"NameFnGrp12\", f:parse_NameFnGrp12 },\n\t0x089a: { n:\"MTRSettings\", f:parse_MTRSettings, r:12 },\n\t0x089b: { n:\"CompressPictures\", f:parse_CompressPictures },\n\t0x089c: { n:\"HeaderFooter\", f:parse_HeaderFooter },\n\t0x089d: { n:\"CrtLayout12\", f:parse_CrtLayout12 },\n\t0x089e: { n:\"CrtMlFrt\", f:parse_CrtMlFrt },\n\t0x089f: { n:\"CrtMlFrtContinue\", f:parse_CrtMlFrtContinue },\n\t0x08a3: { n:\"ForceFullCalculation\", f:parse_ForceFullCalculation },\n\t0x08a4: { n:\"ShapePropsStream\", f:parse_ShapePropsStream },\n\t0x08a5: { n:\"TextPropsStream\", f:parse_TextPropsStream },\n\t0x08a6: { n:\"RichTextStream\", f:parse_RichTextStream },\n\t0x08a7: { n:\"CrtLayout12A\", f:parse_CrtLayout12A },\n\t0x1001: { n:\"Units\", f:parse_Units },\n\t0x1002: { n:\"Chart\", f:parse_Chart },\n\t0x1003: { n:\"Series\", f:parse_Series },\n\t0x1006: { n:\"DataFormat\", f:parse_DataFormat },\n\t0x1007: { n:\"LineFormat\", f:parse_LineFormat },\n\t0x1009: { n:\"MarkerFormat\", f:parse_MarkerFormat },\n\t0x100a: { n:\"AreaFormat\", f:parse_AreaFormat },\n\t0x100b: { n:\"PieFormat\", f:parse_PieFormat },\n\t0x100c: { n:\"AttachedLabel\", f:parse_AttachedLabel },\n\t0x100d: { n:\"SeriesText\", f:parse_SeriesText },\n\t0x1014: { n:\"ChartFormat\", f:parse_ChartFormat },\n\t0x1015: { n:\"Legend\", f:parse_Legend },\n\t0x1016: { n:\"SeriesList\", f:parse_SeriesList },\n\t0x1017: { n:\"Bar\", f:parse_Bar },\n\t0x1018: { n:\"Line\", f:parse_Line },\n\t0x1019: { n:\"Pie\", f:parse_Pie },\n\t0x101a: { n:\"Area\", f:parse_Area },\n\t0x101b: { n:\"Scatter\", f:parse_Scatter },\n\t0x101c: { n:\"CrtLine\", f:parse_CrtLine },\n\t0x101d: { n:\"Axis\", f:parse_Axis },\n\t0x101e: { n:\"Tick\", f:parse_Tick },\n\t0x101f: { n:\"ValueRange\", f:parse_ValueRange },\n\t0x1020: { n:\"CatSerRange\", f:parse_CatSerRange },\n\t0x1021: { n:\"AxisLine\", f:parse_AxisLine },\n\t0x1022: { n:\"CrtLink\", f:parse_CrtLink },\n\t0x1024: { n:\"DefaultText\", f:parse_DefaultText },\n\t0x1025: { n:\"Text\", f:parse_Text },\n\t0x1026: { n:\"FontX\", f:parse_FontX },\n\t0x1027: { n:\"ObjectLink\", f:parse_ObjectLink },\n\t0x1032: { n:\"Frame\", f:parse_Frame },\n\t0x1033: { n:\"Begin\", f:parse_Begin },\n\t0x1034: { n:\"End\", f:parse_End },\n\t0x1035: { n:\"PlotArea\", f:parse_PlotArea },\n\t0x103a: { n:\"Chart3d\", f:parse_Chart3d },\n\t0x103c: { n:\"PicF\", f:parse_PicF },\n\t0x103d: { n:\"DropBar\", f:parse_DropBar },\n\t0x103e: { n:\"Radar\", f:parse_Radar },\n\t0x103f: { n:\"Surf\", f:parse_Surf },\n\t0x1040: { n:\"RadarArea\", f:parse_RadarArea },\n\t0x1041: { n:\"AxisParent\", f:parse_AxisParent },\n\t0x1043: { n:\"LegendException\", f:parse_LegendException },\n\t0x1044: { n:\"ShtProps\", f:parse_ShtProps },\n\t0x1045: { n:\"SerToCrt\", f:parse_SerToCrt },\n\t0x1046: { n:\"AxesUsed\", f:parse_AxesUsed },\n\t0x1048: { n:\"SBaseRef\", f:parse_SBaseRef },\n\t0x104a: { n:\"SerParent\", f:parse_SerParent },\n\t0x104b: { n:\"SerAuxTrend\", f:parse_SerAuxTrend },\n\t0x104e: { n:\"IFmtRecord\", f:parse_IFmtRecord },\n\t0x104f: { n:\"Pos\", f:parse_Pos },\n\t0x1050: { n:\"AlRuns\", f:parse_AlRuns },\n\t0x1051: { n:\"BRAI\", f:parse_BRAI },\n\t0x105b: { n:\"SerAuxErrBar\", f:parse_SerAuxErrBar },\n\t0x105c: { n:\"ClrtClient\", f:parse_ClrtClient },\n\t0x105d: { n:\"SerFmt\", f:parse_SerFmt },\n\t0x105f: { n:\"Chart3DBarShape\", f:parse_Chart3DBarShape },\n\t0x1060: { n:\"Fbi\", f:parse_Fbi },\n\t0x1061: { n:\"BopPop\", f:parse_BopPop },\n\t0x1062: { n:\"AxcExt\", f:parse_AxcExt },\n\t0x1063: { n:\"Dat\", f:parse_Dat },\n\t0x1064: { n:\"PlotGrowth\", f:parse_PlotGrowth },\n\t0x1065: { n:\"SIIndex\", f:parse_SIIndex },\n\t0x1066: { n:\"GelFrame\", f:parse_GelFrame },\n\t0x1067: { n:\"BopPopCustom\", f:parse_BopPopCustom },\n\t0x1068: { n:\"Fbi2\", f:parse_Fbi2 },\n\n\t/* These are specified in an older version of the spec */\n\t0x0016: { n:\"ExternCount\", f:parsenoop },\n\t0x007e: { n:\"RK\", f:parsenoop }, /* Not necessarily same as 0x027e */\n\t0x007f: { n:\"ImData\", f:parsenoop },\n\t0x0087: { n:\"Addin\", f:parsenoop },\n\t0x0088: { n:\"Edg\", f:parsenoop },\n\t0x0089: { n:\"Pub\", f:parsenoop },\n\t0x0091: { n:\"Sub\", f:parsenoop },\n\t0x0094: { n:\"LHRecord\", f:parsenoop },\n\t0x0095: { n:\"LHNGraph\", f:parsenoop },\n\t0x0096: { n:\"Sound\", f:parsenoop },\n\t0x00a9: { n:\"CoordList\", f:parsenoop },\n\t0x00ab: { n:\"GCW\", f:parsenoop },\n\t0x00bc: { n:\"ShrFmla\", f:parsenoop }, /* Not necessarily same as 0x04bc */\n\t0x00c2: { n:\"AddMenu\", f:parsenoop },\n\t0x00c3: { n:\"DelMenu\", f:parsenoop },\n\t0x00d6: { n:\"RString\", f:parsenoop },\n\t0x00df: { n:\"UDDesc\", f:parsenoop },\n\t0x00ea: { n:\"TabIdConf\", f:parsenoop },\n\t0x0162: { n:\"XL5Modify\", f:parsenoop },\n\t0x01a5: { n:\"FileSharing2\", f:parsenoop },\n\t0x0218: { n:\"Name\", f:parsenoop },\n\t0x0223: { n:\"ExternName\", f:parse_ExternName },\n\t0x0231: { n:\"Font\", f:parsenoop },\n\t0x0406: { n:\"Formula\", f:parse_Formula },\n\t0x086d: { n:\"FeatInfo\", f:parsenoop },\n\t0x0873: { n:\"FeatInfo11\", f:parsenoop },\n\t0x0881: { n:\"SXAddl12\", f:parsenoop },\n\t0x08c0: { n:\"AutoWebPub\", f:parsenoop },\n\t0x08c1: { n:\"ListObj\", f:parsenoop },\n\t0x08c2: { n:\"ListField\", f:parsenoop },\n\t0x08c3: { n:\"ListDV\", f:parsenoop },\n\t0x08c4: { n:\"ListCondFmt\", f:parsenoop },\n\t0x08c5: { n:\"ListCF\", f:parsenoop },\n\t0x08c6: { n:\"FMQry\", f:parsenoop },\n\t0x08c7: { n:\"FMSQry\", f:parsenoop },\n\t0x08c8: { n:\"PLV\", f:parsenoop }, /* supposedly PLV for Excel 11 */\n\t0x08c9: { n:\"LnExt\", f:parsenoop },\n\t0x08ca: { n:\"MkrExt\", f:parsenoop },\n\t0x08cb: { n:\"CrtCoopt\", f:parsenoop },\n\n\t0x0000: {}\n};\n\n\n/* Helper function to call out to ODS parser */\nfunction parse_ods(zip, opts) {\n\tif(typeof module !== \"undefined\" && typeof require !== 'undefined' && typeof ODS === 'undefined') ODS = require('./od' + 's');\n\tif(typeof ODS === 'undefined' || !ODS.parse_ods) throw new Error(\"Unsupported ODS\");\n\treturn ODS.parse_ods(zip, opts);\n}\nfunction fix_opts_func(defaults) {\n\treturn function fix_opts(opts) {\n\t\tfor(var i = 0; i != defaults.length; ++i) {\n\t\t\tvar d = defaults[i];\n\t\t\tif(opts[d[0]] === undefined) opts[d[0]] = d[1];\n\t\t\tif(d[2] === 'n') opts[d[0]] = Number(opts[d[0]]);\n\t\t}\n\t};\n}\n\nvar fix_read_opts = fix_opts_func([\n\t['cellNF', false], /* emit cell number format string as .z */\n\t['cellHTML', true], /* emit html string as .h */\n\t['cellFormula', true], /* emit formulae as .f */\n\t['cellStyles', false], /* emits style/theme as .s */\n\t['cellDates', false], /* emit date cells with type `d` */\n\n\t['sheetStubs', false], /* emit empty cells */\n\t['sheetRows', 0, 'n'], /* read n rows (0 = read all rows) */\n\n\t['bookDeps', false], /* parse calculation chains */\n\t['bookSheets', false], /* only try to get sheet names (no Sheets) */\n\t['bookProps', false], /* only try to get properties (no Sheets) */\n\t['bookFiles', false], /* include raw file structure (keys, files, cfb) */\n\t['bookVBA', false], /* include vba raw data (vbaraw) */\n\n\t['password',''], /* password */\n\t['WTF', false] /* WTF mode (throws errors) */\n]);\n\n\nvar fix_write_opts = fix_opts_func([\n\t['cellDates', false], /* write date cells with type `d` */\n\n\t['bookSST', false], /* Generate Shared String Table */\n\n\t['bookType', 'xlsx'], /* Type of workbook (xlsx/m/b) */\n\n\t['WTF', false] /* WTF mode (throws errors) */\n]);\nfunction safe_parse_wbrels(wbrels, sheets) {\n\tif(!wbrels) return 0;\n\ttry {\n\t\twbrels = sheets.map(function pwbr(w) { return [w.name, wbrels['!id'][w.id].Target]; });\n\t} catch(e) { return null; }\n\treturn !wbrels || wbrels.length === 0 ? null : wbrels;\n}\n\nfunction safe_parse_ws(zip, path, relsPath, sheet, sheetRels, sheets, opts) {\n\ttry {\n\t\tsheetRels[sheet]=parse_rels(getzipdata(zip, relsPath, true), path);\n\t\tsheets[sheet]=parse_ws(getzipdata(zip, path),path,opts,sheetRels[sheet]);\n\t} catch(e) { if(opts.WTF) throw e; }\n}\n\nvar nodirs = function nodirs(x){return x.substr(-1) != '/';};\nfunction parse_zip(zip, opts) {\n\tmake_ssf(SSF);\n\topts = opts || {};\n\tfix_read_opts(opts);\n\treset_cp();\n\n\t/* OpenDocument Part 3 Section 2.2.1 OpenDocument Package */\n\tif(safegetzipfile(zip, 'META-INF/manifest.xml')) return parse_ods(zip, opts);\n\n\tvar entries = keys(zip.files).filter(nodirs).sort();\n\tvar dir = parse_ct(getzipdata(zip, '[Content_Types].xml'), opts);\n\tvar xlsb = false;\n\tvar sheets, binname;\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.xml\";\n\t\tif(getzipdata(zip,binname, true)) dir.workbooks.push(binname);\n\t}\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.bin\";\n\t\tif(!getzipfile(zip,binname,true)) throw new Error(\"Could not find workbook\");\n\t\tdir.workbooks.push(binname);\n\t\txlsb = true;\n\t}\n\tif(dir.workbooks[0].substr(-3) == \"bin\") xlsb = true;\n\tif(xlsb) set_cp(1200);\n\n\tif(!opts.bookSheets && !opts.bookProps) {\n\t\tstrs = [];\n\t\tif(dir.sst) strs=parse_sst(getzipdata(zip, dir.sst.replace(/^\\//,'')), dir.sst, opts);\n\n\t\tstyles = {};\n\t\tif(dir.style) styles = parse_sty(getzipdata(zip, dir.style.replace(/^\\//,'')),dir.style, opts);\n\n\t\tthemes = {};\n\t\tif(opts.cellStyles && dir.themes.length) themes = parse_theme(getzipdata(zip, dir.themes[0].replace(/^\\//,''), true),dir.themes[0], opts);\n\t}\n\n\tvar wb = parse_wb(getzipdata(zip, dir.workbooks[0].replace(/^\\//,'')), dir.workbooks[0], opts);\n\n\tvar props = {}, propdata = \"\";\n\n\tif(dir.coreprops.length !== 0) {\n\t\tpropdata = getzipdata(zip, dir.coreprops[0].replace(/^\\//,''), true);\n\t\tif(propdata) props = parse_core_props(propdata);\n\t\tif(dir.extprops.length !== 0) {\n\t\t\tpropdata = getzipdata(zip, dir.extprops[0].replace(/^\\//,''), true);\n\t\t\tif(propdata) parse_ext_props(propdata, props);\n\t\t}\n\t}\n\n\tvar custprops = {};\n\tif(!opts.bookSheets || opts.bookProps) {\n\t\tif (dir.custprops.length !== 0) {\n\t\t\tpropdata = getzipdata(zip, dir.custprops[0].replace(/^\\//,''), true);\n\t\t\tif(propdata) custprops = parse_cust_props(propdata, opts);\n\t\t}\n\t}\n\n\tvar out = {};\n\tif(opts.bookSheets || opts.bookProps) {\n\t\tif(props.Worksheets && props.SheetNames.length > 0) sheets=props.SheetNames;\n\t\telse if(wb.Sheets) sheets = wb.Sheets.map(function pluck(x){ return x.name; });\n\t\tif(opts.bookProps) { out.Props = props; out.Custprops = custprops; }\n\t\tif(typeof sheets !== 'undefined') out.SheetNames = sheets;\n\t\tif(opts.bookSheets ? out.SheetNames : opts.bookProps) return out;\n\t}\n\tsheets = {};\n\n\tvar deps = {};\n\tif(opts.bookDeps && dir.calcchain) deps=parse_cc(getzipdata(zip, dir.calcchain.replace(/^\\//,'')),dir.calcchain,opts);\n\n\tvar i=0;\n\tvar sheetRels = {};\n\tvar path, relsPath;\n\tif(!props.Worksheets) {\n\t\tvar wbsheets = wb.Sheets;\n\t\tprops.Worksheets = wbsheets.length;\n\t\tprops.SheetNames = [];\n\t\tfor(var j = 0; j != wbsheets.length; ++j) {\n\t\t\tprops.SheetNames[j] = wbsheets[j].name;\n\t\t}\n\t}\n\n\tvar wbext = xlsb ? \"bin\" : \"xml\";\n\tvar wbrelsfile = 'xl/_rels/workbook.' + wbext + '.rels';\n\tvar wbrels = parse_rels(getzipdata(zip, wbrelsfile, true), wbrelsfile);\n\tif(wbrels) wbrels = safe_parse_wbrels(wbrels, wb.Sheets);\n\t/* Numbers iOS hack */\n\tvar nmode = (getzipdata(zip,\"xl/worksheets/sheet.xml\",true))?1:0;\n\tfor(i = 0; i != props.Worksheets; ++i) {\n\t\tif(wbrels) path = 'xl/' + (wbrels[i][1]).replace(/[\\/]?xl\\//, \"\");\n\t\telse {\n\t\t\tpath = 'xl/worksheets/sheet'+(i+1-nmode)+\".\" + wbext;\n\t\t\tpath = path.replace(/sheet0\\./,\"sheet.\");\n\t\t}\n\t\trelsPath = path.replace(/^(.*)(\\/)([^\\/]*)$/, \"$1/_rels/$3.rels\");\n\t\tsafe_parse_ws(zip, path, relsPath, props.SheetNames[i], sheetRels, sheets, opts);\n\t}\n\n\tif(dir.comments) parse_comments(zip, dir.comments, sheets, sheetRels, opts);\n\n\tout = {\n\t\tDirectory: dir,\n\t\tWorkbook: wb,\n\t\tProps: props,\n\t\tCustprops: custprops,\n\t\tDeps: deps,\n\t\tSheets: sheets,\n\t\tSheetNames: props.SheetNames,\n\t\tStrings: strs,\n\t\tStyles: styles,\n\t\tThemes: themes,\n\t\tSSF: SSF.get_table()\n\t};\n\tif(opts.bookFiles) {\n\t\tout.keys = entries;\n\t\tout.files = zip.files;\n\t}\n\tif(opts.bookVBA) {\n\t\tif(dir.vba.length > 0) out.vbaraw = getzipdata(zip,dir.vba[0],true);\n\t\telse if(dir.defaults.bin === 'application/vnd.ms-office.vbaProject') out.vbaraw = getzipdata(zip,'xl/vbaProject.bin',true);\n\t}\n\treturn out;\n}\nfunction add_rels(rels, rId, f, type, relobj) {\n\tif(!relobj) relobj = {};\n\tif(!rels['!id']) rels['!id'] = {};\n\trelobj.Id = 'rId' + rId;\n\trelobj.Type = type;\n\trelobj.Target = f;\n\tif(rels['!id'][relobj.Id]) throw new Error(\"Cannot rewrite rId \" + rId);\n\trels['!id'][relobj.Id] = relobj;\n\trels[('/' + relobj.Target).replace(\"//\",\"/\")] = relobj;\n}\n\nfunction write_zip(wb, opts) {\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = SSF.get_table();\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(SSF); SSF.load_table(wb.SSF);\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t}\n\topts.rels = {}; opts.wbrels = {};\n\topts.Strings = []; opts.Strings.Count = 0; opts.Strings.Unique = 0;\n\tvar wbext = opts.bookType == \"xlsb\" ? \"bin\" : \"xml\";\n\tvar ct = { workbooks: [], sheets: [], calcchains: [], themes: [], styles: [],\n\t\tcoreprops: [], extprops: [], custprops: [], strs:[], comments: [], vba: [],\n\t\tTODO:[], rels:[], xmlns: \"\" };\n\tfix_write_opts(opts = opts || {});\n\tvar zip = new jszip();\n\tvar f = \"\", rId = 0;\n\n\topts.cellXfs = [];\n\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tf = \"docProps/core.xml\";\n\tzip.file(f, write_core_props(wb.Props, opts));\n\tct.coreprops.push(f);\n\tadd_rels(opts.rels, 2, f, RELS.CORE_PROPS);\n\n\tf = \"docProps/app.xml\";\n\tif(!wb.Props) wb.Props = {};\n\twb.Props.SheetNames = wb.SheetNames;\n\twb.Props.Worksheets = wb.SheetNames.length;\n\tzip.file(f, write_ext_props(wb.Props, opts));\n\tct.extprops.push(f);\n\tadd_rels(opts.rels, 3, f, RELS.EXT_PROPS);\n\n\tif(wb.Custprops !== wb.Props && keys(wb.Custprops||{}).length > 0) {\n\t\tf = \"docProps/custom.xml\";\n\t\tzip.file(f, write_cust_props(wb.Custprops, opts));\n\t\tct.custprops.push(f);\n\t\tadd_rels(opts.rels, 4, f, RELS.CUST_PROPS);\n\t}\n\n\tf = \"xl/workbook.\" + wbext;\n\tzip.file(f, write_wb(wb, f, opts));\n\tct.workbooks.push(f);\n\tadd_rels(opts.rels, 1, f, RELS.WB);\n\n\tfor(rId=1;rId <= wb.SheetNames.length; ++rId) {\n\t\tf = \"xl/worksheets/sheet\" + rId + \".\" + wbext;\n\t\tzip.file(f, write_ws(rId-1, f, opts, wb));\n\t\tct.sheets.push(f);\n\t\tadd_rels(opts.wbrels, rId, \"worksheets/sheet\" + rId + \".\" + wbext, RELS.WS);\n\t}\n\n\tif(opts.Strings != null && opts.Strings.length > 0) {\n\t\tf = \"xl/sharedStrings.\" + wbext;\n\t\tzip.file(f, write_sst(opts.Strings, f, opts));\n\t\tct.strs.push(f);\n\t\tadd_rels(opts.wbrels, ++rId, \"sharedStrings.\" + wbext, RELS.SST);\n\t}\n\n\t/* TODO: something more intelligent with themes */\n\n\tf = \"xl/theme/theme1.xml\";\n\tzip.file(f, write_theme());\n\tct.themes.push(f);\n\tadd_rels(opts.wbrels, ++rId, \"theme/theme1.xml\", RELS.THEME);\n\n\t/* TODO: something more intelligent with styles */\n\n\tf = \"xl/styles.\" + wbext;\n\tzip.file(f, write_sty(wb, f, opts));\n\tct.styles.push(f);\n\tadd_rels(opts.wbrels, ++rId, \"styles.\" + wbext, RELS.STY);\n\n\tzip.file(\"[Content_Types].xml\", write_ct(ct, opts));\n\tzip.file('_rels/.rels', write_rels(opts.rels));\n\tzip.file('xl/_rels/workbook.' + wbext + '.rels', write_rels(opts.wbrels));\n\treturn zip;\n}\nfunction firstbyte(f,o) {\n\tswitch((o||{}).type || \"base64\") {\n\t\tcase 'buffer': return f[0];\n\t\tcase 'base64': return Base64.decode(f.substr(0,12)).charCodeAt(0);\n\t\tcase 'binary': return f.charCodeAt(0);\n\t\tcase 'array': return f[0];\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n}\n\nfunction read_zip(data, opts) {\n\tvar zip, d = data;\n\tvar o = opts||{};\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tswitch(o.type) {\n\t\tcase \"base64\": zip = new jszip(d, { base64:true }); break;\n\t\tcase \"binary\": case \"array\": zip = new jszip(d, { base64:false }); break;\n\t\tcase \"buffer\": zip = new jszip(d); break;\n\t\tcase \"file\": zip=new jszip(d=_fs.readFileSync(data)); break;\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\treturn parse_zip(zip, o);\n}\n\nfunction readSync(data, opts) {\n\tvar zip, d = data, isfile = false, n;\n\tvar o = opts||{};\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tif(o.type == \"file\") { isfile = true; o.type = \"buffer\"; d = _fs.readFileSync(data); }\n\tswitch((n = firstbyte(d, o))) {\n\t\tcase 0xD0:\n\t\t\tif(isfile) o.type = \"file\";\n\t\t\treturn parse_xlscfb(CFB.read(data, o), o);\n\t\tcase 0x09: return parse_xlscfb(s2a(o.type === 'base64' ? Base64.decode(data) : data), o);\n\t\tcase 0x3C: return parse_xlml(d, o);\n\t\tcase 0x50:\n\t\t\tif(isfile) o.type = \"file\";\n\t\t\treturn read_zip(data, opts);\n\t\tdefault: throw new Error(\"Unsupported file \" + n);\n\t}\n}\n\nfunction readFileSync(data, opts) {\n\tvar o = opts||{}; o.type = 'file';\n\treturn readSync(data, o);\n}\nfunction write_zip_type(wb, opts) {\n\tvar o = opts||{};\n\tvar z = write_zip(wb, o);\n\tswitch(o.type) {\n\t\tcase \"base64\": return z.generate({type:\"base64\"});\n\t\tcase \"binary\": return z.generate({type:\"string\"});\n\t\tcase \"buffer\": return z.generate({type:\"nodebuffer\"});\n\t\tcase \"file\": return _fs.writeFileSync(o.file, z.generate({type:\"nodebuffer\"}));\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n}\n\nfunction writeSync(wb, opts) {\n\tvar o = opts||{};\n\tswitch(o.bookType) {\n\t\tcase 'xml': return write_xlml(wb, o);\n\t\tdefault: return write_zip_type(wb, o);\n\t}\n}\n\nfunction writeFileSync(wb, filename, opts) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tswitch(o.file.substr(-5).toLowerCase()) {\n\t\tcase '.xlsx': o.bookType = 'xlsx'; break;\n\t\tcase '.xlsm': o.bookType = 'xlsm'; break;\n\t\tcase '.xlsb': o.bookType = 'xlsb'; break;\n\tdefault: switch(o.file.substr(-4).toLowerCase()) {\n\t\tcase '.xls': o.bookType = 'xls'; break;\n\t\tcase '.xml': o.bookType = 'xml'; break;\n\t}}\n\treturn writeSync(wb, o);\n}\n\nfunction decode_row(rowstr) { return parseInt(unfix_row(rowstr),10) - 1; }\nfunction encode_row(row) { return \"\" + (row + 1); }\nfunction fix_row(cstr) { return cstr.replace(/([A-Z]|^)(\\d+)$/,\"$1$$$2\"); }\nfunction unfix_row(cstr) { return cstr.replace(/\\$(\\d+)$/,\"$1\"); }\n\nfunction decode_col(colstr) { var c = unfix_col(colstr), d = 0, i = 0; for(; i !== c.length; ++i) d = 26*d + c.charCodeAt(i) - 64; return d - 1; }\nfunction encode_col(col) { var s=\"\"; for(++col; col; col=Math.floor((col-1)/26)) s = String.fromCharCode(((col-1)%26) + 65) + s; return s; }\nfunction fix_col(cstr) { return cstr.replace(/^([A-Z])/,\"$$$1\"); }\nfunction unfix_col(cstr) { return cstr.replace(/^\\$([A-Z])/,\"$1\"); }\n\nfunction split_cell(cstr) { return cstr.replace(/(\\$?[A-Z]*)(\\$?\\d*)/,\"$1,$2\").split(\",\"); }\nfunction decode_cell(cstr) { var splt = split_cell(cstr); return { c:decode_col(splt[0]), r:decode_row(splt[1]) }; }\nfunction encode_cell(cell) { return encode_col(cell.c) + encode_row(cell.r); }\nfunction fix_cell(cstr) { return fix_col(fix_row(cstr)); }\nfunction unfix_cell(cstr) { return unfix_col(unfix_row(cstr)); }\nfunction decode_range(range) { var x =range.split(\":\").map(decode_cell); return {s:x[0],e:x[x.length-1]}; }\nfunction encode_range(cs,ce) {\n\tif(ce === undefined || typeof ce === 'number') return encode_range(cs.s, cs.e);\n\tif(typeof cs !== 'string') cs = encode_cell(cs); if(typeof ce !== 'string') ce = encode_cell(ce);\n\treturn cs == ce ? cs : cs + \":\" + ce;\n}\n\nfunction safe_decode_range(range) {\n\tvar o = {s:{c:0,r:0},e:{c:0,r:0}};\n\tvar idx = 0, i = 0, cc = 0;\n\tvar len = range.length;\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.s.c = --idx;\n\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.s.r = --idx;\n\n\tif(i === len || range.charCodeAt(++i) === 58) { o.e.c=o.s.c; o.e.r=o.s.r; return o; }\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.e.c = --idx;\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.e.r = --idx;\n\treturn o;\n}\n\nfunction safe_format_cell(cell, v) {\n\tif(cell.z !== undefined) try { return (cell.w = SSF.format(cell.z, v)); } catch(e) { }\n\tif(!cell.XF) return v;\n\ttry { return (cell.w = SSF.format(cell.XF.ifmt||0, v)); } catch(e) { return ''+v; }\n}\n\nfunction format_cell(cell, v) {\n\tif(cell == null || cell.t == null) return \"\";\n\tif(cell.w !== undefined) return cell.w;\n\tif(v === undefined) return safe_format_cell(cell, cell.v);\n\treturn safe_format_cell(cell, v);\n}\n\nfunction sheet_to_json(sheet, opts){\n\tvar val, row, range, header = 0, offset = 1, r, hdr = [], isempty, R, C, v;\n\tvar o = opts != null ? opts : {};\n\tvar raw = o.raw;\n\tif(sheet == null || sheet[\"!ref\"] == null) return [];\n\trange = o.range !== undefined ? o.range : sheet[\"!ref\"];\n\tif(o.header === 1) header = 1;\n\telse if(o.header === \"A\") header = 2;\n\telse if(Array.isArray(o.header)) header = 3;\n\tswitch(typeof range) {\n\t\tcase 'string': r = safe_decode_range(range); break;\n\t\tcase 'number': r = safe_decode_range(sheet[\"!ref\"]); r.s.r = range; break;\n\t\tdefault: r = range;\n\t}\n\tif(header > 0) offset = 0;\n\tvar rr = encode_row(r.s.r);\n\tvar cols = new Array(r.e.c-r.s.c+1);\n\tvar out = new Array(r.e.r-r.s.r-offset+1);\n\tvar outi = 0;\n\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\tcols[C] = encode_col(C);\n\t\tval = sheet[cols[C] + rr];\n\t\tswitch(header) {\n\t\t\tcase 1: hdr[C] = C; break;\n\t\t\tcase 2: hdr[C] = cols[C]; break;\n\t\t\tcase 3: hdr[C] = o.header[C - r.s.c]; break;\n\t\t\tdefault:\n\t\t\t\tif(val === undefined) continue;\n\t\t\t\thdr[C] = format_cell(val);\n\t\t}\n\t}\n\n\tfor (R = r.s.r + offset; R <= r.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tisempty = true;\n\t\tif(header === 1) row = [];\n\t\telse {\n\t\t\trow = {};\n\t\t\tif(Object.defineProperty) Object.defineProperty(row, '__rowNum__', {value:R, enumerable:false});\n\t\t\telse row.__rowNum__ = R;\n\t\t}\n\t\tfor (C = r.s.c; C <= r.e.c; ++C) {\n\t\t\tval = sheet[cols[C] + rr];\n\t\t\tif(val === undefined || val.t === undefined) continue;\n\t\t\tv = val.v;\n\t\t\tswitch(val.t){\n\t\t\t\tcase 'e': continue;\n\t\t\t\tcase 's': break;\n\t\t\t\tcase 'b': case 'n': break;\n\t\t\t\tdefault: throw 'unrecognized type ' + val.t;\n\t\t\t}\n\t\t\tif(v !== undefined) {\n\t\t\t\trow[hdr[C]] = raw ? v : format_cell(val,v);\n\t\t\t\tisempty = false;\n\t\t\t}\n\t\t}\n\t\tif(isempty === false || header === 1) out[outi++] = row;\n\t}\n\tout.length = outi;\n\treturn out;\n}\n\nfunction sheet_to_row_object_array(sheet, opts) { return sheet_to_json(sheet, opts != null ? opts : {}); }\n\nfunction sheet_to_csv(sheet, opts) {\n\tvar out = \"\", txt = \"\", qreg = /\"/g;\n\tvar o = opts == null ? {} : opts;\n\tif(sheet == null || sheet[\"!ref\"] == null) return \"\";\n\tvar r = safe_decode_range(sheet[\"!ref\"]);\n\tvar FS = o.FS !== undefined ? o.FS : \",\", fs = FS.charCodeAt(0);\n\tvar RS = o.RS !== undefined ? o.RS : \"\\n\", rs = RS.charCodeAt(0);\n\tvar row = \"\", rr = \"\", cols = [];\n\tvar i = 0, cc = 0, val;\n\tvar R = 0, C = 0;\n\tfor(C = r.s.c; C <= r.e.c; ++C) cols[C] = encode_col(C);\n\tfor(R = r.s.r; R <= r.e.r; ++R) {\n\t\trow = \"\";\n\t\trr = encode_row(R);\n\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\tval = sheet[cols[C] + rr];\n\t\t\ttxt = val !== undefined ? ''+format_cell(val) : \"\";\n\t\t\tfor(i = 0, cc = 0; i !== txt.length; ++i) if((cc = txt.charCodeAt(i)) === fs || cc === rs || cc === 34) {\n\t\t\t\ttxt = \"\\\"\" + txt.replace(qreg, '\"\"') + \"\\\"\"; break; }\n\t\t\trow += (C === r.s.c ? \"\" : FS) + txt;\n\t\t}\n\t\tout += row + RS;\n\t}\n\treturn out;\n}\nvar make_csv = sheet_to_csv;\n\nfunction sheet_to_formulae(sheet) {\n\tvar cmds, y = \"\", x, val=\"\";\n\tif(sheet == null || sheet[\"!ref\"] == null) return \"\";\n\tvar r = safe_decode_range(sheet['!ref']), rr = \"\", cols = [], C;\n\tcmds = new Array((r.e.r-r.s.r+1)*(r.e.c-r.s.c+1));\n\tvar i = 0;\n\tfor(C = r.s.c; C <= r.e.c; ++C) cols[C] = encode_col(C);\n\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\ty = cols[C] + rr;\n\t\t\tx = sheet[y];\n\t\t\tval = \"\";\n\t\t\tif(x === undefined) continue;\n\t\t\tif(x.f != null) val = x.f;\n\t\t\telse if(x.w !== undefined) val = \"'\" + x.w;\n\t\t\telse if(x.v === undefined) continue;\n\t\t\telse val = \"\"+x.v;\n\t\t\tcmds[i++] = y + \"=\" + val;\n\t\t}\n\t}\n\tcmds.length = i;\n\treturn cmds;\n}\n\nvar utils = {\n\tencode_col: encode_col,\n\tencode_row: encode_row,\n\tencode_cell: encode_cell,\n\tencode_range: encode_range,\n\tdecode_col: decode_col,\n\tdecode_row: decode_row,\n\tsplit_cell: split_cell,\n\tdecode_cell: decode_cell,\n\tdecode_range: decode_range,\n\tformat_cell: format_cell,\n\tget_formulae: sheet_to_formulae,\n\tmake_csv: sheet_to_csv,\n\tmake_json: sheet_to_json,\n\tmake_formulae: sheet_to_formulae,\n\tsheet_to_csv: sheet_to_csv,\n\tsheet_to_json: sheet_to_json,\n\tsheet_to_formulae: sheet_to_formulae,\n\tsheet_to_row_object_array: sheet_to_row_object_array\n};\nXLSX.parse_xlscfb = parse_xlscfb;\nXLSX.parse_zip = parse_zip;\nXLSX.read = readSync; //xlsread\nXLSX.readFile = readFileSync; //readFile\nXLSX.readFileSync = readFileSync;\nXLSX.write = writeSync;\nXLSX.writeFile = writeFileSync;\nXLSX.writeFileSync = writeFileSync;\nXLSX.utils = utils;\nXLSX.CFB = CFB;\nXLSX.SSF = SSF;\n})(typeof exports !== 'undefined' ? exports : XLSX);\nvar XLS = XLSX;\n$tw.utils.extend(old_exports,exports);exports = old_exports;module.exports=exports;",
"type": "application/javascript",
"title": "$:/plugins/tiddlywiki/xlsx-utils/xlsx.js",
"module-type": "library"
},
"$:/plugins/tiddlywiki/xlsx-utils/dist/cpexcel.js": {
"text": "if($tw.browser){Buffer = undefined;};/* cpexcel.js (C) 2013-2014 SheetJS -- http://sheetjs.com */\n/*jshint -W100 */\nvar cptable = {version:\"1.3.7\"};\ncptable[874] = (function(){ var d = \"\\u0000\\u0001\\u0002\\u0003\\u0004\\u0005\\u0006\\u0007\\b\\t\\n\\u000b\\f\\r\\u000e\\u000f\\u0010\\u0011\\u0012\\u0013\\u0014\\u0015\\u0016\\u0017\\u0018\\u0019\\u001a\\u001b\\u001c\\u001d\\u001e\\u001f !\\\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\\\]^_`abcdefghijklmnopqrstuvwxyz{|}~€����…�����������‘’“”•–—�������� กขฃคฅฆงจฉชซฌญฎฏฐฑฒณดตถทธนบปผฝพฟภมยรฤลฦวศษสหฬอฮฯะัาำิีึืฺุู����฿เแโใไๅๆ็่้๊๋์ํ๎๏๐๑๒๓๔๕๖๗๘๙๚๛����\", D = [], e = {}; for(var i=0;i!=d.length;++i) { if(d.charCodeAt(i) !== 0xFFFD) e[d[i]] = i; D[i] = d.charAt(i); } return {\"enc\": e, \"dec\": D }; })();\ncptable[932] = (function(){ var d = [], e = {}, D = [], j;\nD[0] = \"\\u0000\\u0001\\u0002\\u0003\\u0004\\u0005\\u0006\\u0007\\b\\t\\n\\u000b\\f\\r\\u000e\\u000f\\u0010\\u0011\\u0012\\u0013\\u0014\\u0015\\u0016\\u0017\\u0018\\u0019\\u001a\\u001b\\u001c\\u001d\\u001e\\u001f !\\\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\\\]^_`abcdefghijklmnopqrstuvwxyz{|}~���������������������������������。「」、・ヲァィゥェォャュョッーアイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワン゙゚��������������������������������\".split(\"\");\nfor(j = 0; j != D[0].length; ++j) if(D[0][j].charCodeAt(0) !== 0xFFFD) { e[D[0][j]] = 0 + j; d[0 + j] = D[0][j];}\nD[129] = \"���������������������������������������������������������������� 、。,.・:;?!゛゜´`¨^ ̄_ヽヾゝゞ〃仝々〆〇ー―‐/\~∥|…‥‘’“”()〔〕[]{}〈〉《》「」『』【】+-±×�÷=≠<>≦≧∞∴♂♀°′″℃¥$¢£%#&*@§☆★○●◎◇◆□■△▲▽▼※〒→←↑↓〓�����������∈∋⊆⊇⊂⊃∪∩��������∧∨¬⇒⇔∀∃�����������∠⊥⌒∂∇≡≒≪≫√∽∝∵∫∬�������ʼn♯♭♪†‡¶����◯���\".split(\"\");\nfor(j = 0; j != D[129].length; ++j) if(D[129][j].charCodeAt(0) !== 0xFFFD) { e[D[129][j]] = 33024 + j; d[33024 + j] = D[129][j];}\nD[130] = \"�������������������������������������������������������������������������������0123456789�������ABCDEFGHIJKLMNOPQRSTUVWXYZ�������abcdefghijklmnopqrstuvwxyz����ぁあぃいぅうぇえぉおかがきぎくぐけげこごさざしじすずせぜそぞただちぢっつづてでとどなにぬねのはばぱひびぴふぶぷへべぺほぼぽまみむめもゃやゅゆょよらりるれろゎわゐゑをん��������������\".split(\"\");\nfor(j = 0; j != D[130].length; ++j) if(D[130][j].charCodeAt(0) !== 0xFFFD) { e[D[130][j]] = 33280 + j; d[33280 + j] = D[130][j];}\nD[131] = \"����������������������������������������������������������������ァアィイゥウェエォオカガキギクグケゲコゴサザシジスズセゼソゾタダチヂッツヅテデトドナニヌネノハバパヒビピフブプヘベペホボポマミ�ムメモャヤュユョヨラリルレロヮワヰヱヲンヴヵヶ��������ΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩ��������αβγδεζηθικλμνξοπρστυφχψω�����������������������������������������\".split(\"\");\nfor(j = 0; j != D[131].length; ++j) if(D[131][j].charCodeAt(0) !== 0xFFFD) { e[D[131][j]] = 33536 + j; d[33536 + j] = D[131][j];}\nD[132] = \"����������������������������������������������������������������АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯ���������������абвгдеёжзийклмн�опрстуфхцчшщъыьэюя�������������─│┌┐┘└├┬┤┴┼━┃┏┓┛┗┣┳┫┻╋┠┯┨┷┿┝┰┥┸╂�����������������������������������������������������������������\".split(\"\");\nfor(j = 0; j != D[132].length; ++j) if(D[132][j].charCodeAt(0) !== 0xFFFD) { e[D[132][j]] = 33792 + j; d[33792 + j] = D[132][j];}\nD[135] = \"����������������������������������������������������������������①②③④⑤⑥⑦⑧⑨⑩⑪⑫⑬⑭⑮⑯⑰⑱⑲⑳ⅠⅡⅢⅣⅤⅥⅦⅧⅨⅩ�㍉㌔㌢㍍㌘㌧㌃㌶㍑㍗㌍㌦㌣㌫㍊㌻㎜㎝㎞㎎㎏㏄㎡��������㍻�〝〟№㏍℡㊤㊥㊦㊧㊨㈱㈲㈹㍾㍽㍼≒≡∫∮∑√⊥∠∟⊿∵∩∪���������������������������������������������������������������������������������������������������\".split(\"\");\nfor(j = 0; j != D[135].length; ++j) if(D[135][j].charCodeAt(0) !== 0xFFFD) { e[D[135][j]] = 34560 + j; d[34560 + j] = D[135][j];}\nD[136] = \"���������������������������������������������������������������������������������������������������������������������������������������������������������������亜唖娃阿哀愛挨姶逢葵茜穐悪握渥旭葦芦鯵梓圧斡扱宛姐虻飴絢綾鮎或粟袷安庵按暗案闇鞍杏以伊位依偉囲夷委威尉惟意慰易椅為畏異移維緯胃萎衣謂違遺医井亥域育郁磯一壱溢逸稲茨芋鰯允印咽員因姻引飲淫胤蔭���\".split(\"\");\nfor(j = 0; j != D[136].length; ++j) if(D[136][j].charCodeAt(0) !== 0xFFFD) { e[D[136][j]] = 34816 + j; d[34816 + j] = D[136][j];}\nD[137] = \"����������������������������������������������������������������院陰隠韻吋右宇烏羽迂雨卯鵜窺丑碓臼渦嘘唄欝蔚鰻姥厩浦瓜閏噂云運雲荏餌叡営嬰影映曳栄永泳洩瑛盈穎頴英衛詠鋭液疫益駅悦謁越閲榎厭円�園堰奄宴延怨掩援沿演炎焔煙燕猿縁艶苑薗遠鉛鴛塩於汚甥凹央奥往応押旺横欧殴王翁襖鴬鴎黄岡沖荻億屋憶臆桶牡乙俺卸恩温穏音下化仮何伽価佳加可嘉夏嫁家寡科暇果架歌河火珂禍禾稼箇花苛茄荷華菓蝦課嘩貨迦過霞蚊俄峨我牙画臥芽蛾賀雅餓駕介会解回塊壊廻快怪悔恢懐戒拐改���\".split(\"\");\nfor(j = 0; j != D[137].length; ++j) if(D[137][j].charCodeAt(0) !== 0xFFFD) { e[D[137][j]] = 35072 + j; d[35072 + j] = D[137][j];}\nD[138] = \"����������������������������������������������������������������魁晦械海灰界皆絵芥蟹開階貝凱劾外咳害崖慨概涯碍蓋街該鎧骸浬馨蛙垣柿蛎鈎劃嚇各廓拡撹格核殻獲確穫覚角赫較郭閣隔革学岳楽額顎掛笠樫�橿梶鰍潟割喝恰括活渇滑葛褐轄且鰹叶椛樺鞄株兜竃蒲釜鎌噛鴨栢茅萱粥刈苅瓦乾侃冠寒刊勘勧巻喚堪姦完官寛干幹患感慣憾換敢柑桓棺款歓汗漢澗潅環甘監看竿管簡緩缶翰肝艦莞観諌貫還鑑間閑関陥韓館舘丸含岸巌玩癌眼岩翫贋雁頑顔願企伎危喜器基奇嬉寄岐希幾忌揮机旗既期棋棄���\".split(\"\");\nfor(j = 0; j != D[138].length; ++j) if(D[138][j].charCodeAt(0) !== 0xFFFD) { e[D[138][j]] = 35328 + j; d[35328 + j] = D[138][j];}\nD[139] = \"����������������������������������������������������������������機帰毅気汽畿祈季稀紀徽規記貴起軌輝飢騎鬼亀偽儀妓宜戯技擬欺犠疑祇義蟻誼議掬菊鞠吉吃喫桔橘詰砧杵黍却客脚虐逆丘久仇休及吸宮弓急救�朽求汲泣灸球究窮笈級糾給旧牛去居巨拒拠挙渠虚許距鋸漁禦魚亨享京供侠僑兇競共凶協匡卿叫喬境峡強彊怯恐恭挟教橋況狂狭矯胸脅興蕎郷鏡響饗驚仰凝尭暁業局曲極玉桐粁僅勤均巾錦斤欣欽琴禁禽筋緊芹菌衿襟謹近金吟銀九倶句区狗玖矩苦躯駆駈駒具愚虞喰空偶寓遇隅串櫛釧屑屈���\".split(\"\");\nfor(j = 0; j != D[139].length; ++j) if(D[139][j].charCodeAt(0) !== 0xFFFD) { e[D[139][j]] = 35584 + j; d[35584 + j] = D[139][j];}\nD[140] = \"����������������������������������������������������������������掘窟沓靴轡窪熊隈粂栗繰桑鍬勲君薫訓群軍郡卦袈祁係傾刑兄啓圭珪型契形径恵慶慧憩掲携敬景桂渓畦稽系経継繋罫茎荊蛍計詣警軽頚鶏芸迎鯨�劇戟撃激隙桁傑欠決潔穴結血訣月件倹倦健兼券剣喧圏堅嫌建憲懸拳捲検権牽犬献研硯絹県肩見謙賢軒遣鍵険顕験鹸元原厳幻弦減源玄現絃舷言諺限乎個古呼固姑孤己庫弧戸故枯湖狐糊袴股胡菰虎誇跨鈷雇顧鼓五互伍午呉吾娯後御悟梧檎瑚碁語誤護醐乞鯉交佼侯候倖光公功効勾厚口向���\".split(\"\");\nfor(j = 0; j != D[140].length; ++j) if(D[140][j].charCodeAt(0) !== 0xFFFD) { e[D[140][j]] = 35840 + j; d[35840 + j] = D[140][j];}\nD[141] = \"����������������������������������������������������������������后喉坑垢好孔孝宏工巧巷幸広庚康弘恒慌抗拘控攻昂晃更杭校梗構江洪浩港溝甲皇硬稿糠紅紘絞綱耕考肯肱腔膏航荒行衡講貢購郊酵鉱砿鋼閤降�項香高鴻剛劫号合壕拷濠豪轟麹克刻告国穀酷鵠黒獄漉腰甑忽惚骨狛込此頃今困坤墾婚恨懇昏昆根梱混痕紺艮魂些佐叉唆嵯左差査沙瑳砂詐鎖裟坐座挫債催再最哉塞妻宰彩才採栽歳済災采犀砕砦祭斎細菜裁載際剤在材罪財冴坂阪堺榊肴咲崎埼碕鷺作削咋搾昨朔柵窄策索錯桜鮭笹匙