1*ca5ec200SAndrew Rist /************************************************************** 2cdf0e10cSrcweir * 3*ca5ec200SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one 4*ca5ec200SAndrew Rist * or more contributor license agreements. See the NOTICE file 5*ca5ec200SAndrew Rist * distributed with this work for additional information 6*ca5ec200SAndrew Rist * regarding copyright ownership. The ASF licenses this file 7*ca5ec200SAndrew Rist * to you under the Apache License, Version 2.0 (the 8*ca5ec200SAndrew Rist * "License"); you may not use this file except in compliance 9*ca5ec200SAndrew Rist * with the License. You may obtain a copy of the License at 10cdf0e10cSrcweir * 11*ca5ec200SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0 12cdf0e10cSrcweir * 13*ca5ec200SAndrew Rist * Unless required by applicable law or agreed to in writing, 14*ca5ec200SAndrew Rist * software distributed under the License is distributed on an 15*ca5ec200SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16*ca5ec200SAndrew Rist * KIND, either express or implied. See the License for the 17*ca5ec200SAndrew Rist * specific language governing permissions and limitations 18*ca5ec200SAndrew Rist * under the License. 19cdf0e10cSrcweir * 20*ca5ec200SAndrew Rist *************************************************************/ 21*ca5ec200SAndrew Rist 22*ca5ec200SAndrew Rist 23cdf0e10cSrcweir 24cdf0e10cSrcweir #include "oox/xls/chartsheetfragment.hxx" 25cdf0e10cSrcweir 26cdf0e10cSrcweir #include "oox/helper/attributelist.hxx" 27cdf0e10cSrcweir #include "oox/xls/biffinputstream.hxx" 28cdf0e10cSrcweir #include "oox/xls/pagesettings.hxx" 29cdf0e10cSrcweir #include "oox/xls/viewsettings.hxx" 30cdf0e10cSrcweir #include "oox/xls/workbooksettings.hxx" 31cdf0e10cSrcweir #include "oox/xls/worksheetsettings.hxx" 32cdf0e10cSrcweir 33cdf0e10cSrcweir namespace oox { 34cdf0e10cSrcweir namespace xls { 35cdf0e10cSrcweir 36cdf0e10cSrcweir // ============================================================================ 37cdf0e10cSrcweir 38cdf0e10cSrcweir using namespace ::oox::core; 39cdf0e10cSrcweir 40cdf0e10cSrcweir using ::rtl::OUString; 41cdf0e10cSrcweir 42cdf0e10cSrcweir // ============================================================================ 43cdf0e10cSrcweir 44cdf0e10cSrcweir ChartsheetFragment::ChartsheetFragment( const WorksheetHelper& rHelper, const OUString& rFragmentPath ) : 45cdf0e10cSrcweir WorksheetFragmentBase( rHelper, rFragmentPath ) 46cdf0e10cSrcweir { 47cdf0e10cSrcweir } 48cdf0e10cSrcweir 49cdf0e10cSrcweir ContextHandlerRef ChartsheetFragment::onCreateContext( sal_Int32 nElement, const AttributeList& rAttribs ) 50cdf0e10cSrcweir { 51cdf0e10cSrcweir switch( getCurrentElement() ) 52cdf0e10cSrcweir { 53cdf0e10cSrcweir case XML_ROOT_CONTEXT: 54cdf0e10cSrcweir if( nElement == XLS_TOKEN( chartsheet ) ) return this; 55cdf0e10cSrcweir break; 56cdf0e10cSrcweir 57cdf0e10cSrcweir case XLS_TOKEN( chartsheet ): 58cdf0e10cSrcweir switch( nElement ) 59cdf0e10cSrcweir { 60cdf0e10cSrcweir case XLS_TOKEN( sheetViews ): return this; 61cdf0e10cSrcweir 62cdf0e10cSrcweir case XLS_TOKEN( sheetPr ): getWorksheetSettings().importChartSheetPr( rAttribs ); break; 63cdf0e10cSrcweir case XLS_TOKEN( sheetProtection ): getWorksheetSettings().importChartProtection( rAttribs ); break; 64cdf0e10cSrcweir case XLS_TOKEN( pageMargins ): getPageSettings().importPageMargins( rAttribs ); break; 65cdf0e10cSrcweir case XLS_TOKEN( pageSetup ): getPageSettings().importChartPageSetup( getRelations(), rAttribs ); break; 66cdf0e10cSrcweir case XLS_TOKEN( headerFooter ): getPageSettings().importHeaderFooter( rAttribs ); return this; 67cdf0e10cSrcweir case XLS_TOKEN( picture ): getPageSettings().importPicture( getRelations(), rAttribs ); break; 68cdf0e10cSrcweir case XLS_TOKEN( drawing ): importDrawing( rAttribs ); break; 69cdf0e10cSrcweir } 70cdf0e10cSrcweir break; 71cdf0e10cSrcweir 72cdf0e10cSrcweir case XLS_TOKEN( sheetViews ): 73cdf0e10cSrcweir if( nElement == XLS_TOKEN( sheetView ) ) getSheetViewSettings().importChartSheetView( rAttribs ); 74cdf0e10cSrcweir break; 75cdf0e10cSrcweir 76cdf0e10cSrcweir case XLS_TOKEN( headerFooter ): 77cdf0e10cSrcweir switch( nElement ) 78cdf0e10cSrcweir { 79cdf0e10cSrcweir case XLS_TOKEN( firstHeader ): 80cdf0e10cSrcweir case XLS_TOKEN( firstFooter ): 81cdf0e10cSrcweir case XLS_TOKEN( oddHeader ): 82cdf0e10cSrcweir case XLS_TOKEN( oddFooter ): 83cdf0e10cSrcweir case XLS_TOKEN( evenHeader ): 84cdf0e10cSrcweir case XLS_TOKEN( evenFooter ): return this; // collect contents in onCharacters() 85cdf0e10cSrcweir } 86cdf0e10cSrcweir break; 87cdf0e10cSrcweir } 88cdf0e10cSrcweir return 0; 89cdf0e10cSrcweir } 90cdf0e10cSrcweir 91cdf0e10cSrcweir void ChartsheetFragment::onCharacters( const OUString& rChars ) 92cdf0e10cSrcweir { 93cdf0e10cSrcweir switch( getCurrentElement() ) 94cdf0e10cSrcweir { 95cdf0e10cSrcweir case XLS_TOKEN( firstHeader ): 96cdf0e10cSrcweir case XLS_TOKEN( firstFooter ): 97cdf0e10cSrcweir case XLS_TOKEN( oddHeader ): 98cdf0e10cSrcweir case XLS_TOKEN( oddFooter ): 99cdf0e10cSrcweir case XLS_TOKEN( evenHeader ): 100cdf0e10cSrcweir case XLS_TOKEN( evenFooter ): 101cdf0e10cSrcweir getPageSettings().importHeaderFooterCharacters( rChars, getCurrentElement() ); 102cdf0e10cSrcweir break; 103cdf0e10cSrcweir } 104cdf0e10cSrcweir } 105cdf0e10cSrcweir 106cdf0e10cSrcweir ContextHandlerRef ChartsheetFragment::onCreateRecordContext( sal_Int32 nRecId, SequenceInputStream& rStrm ) 107cdf0e10cSrcweir { 108cdf0e10cSrcweir switch( getCurrentElement() ) 109cdf0e10cSrcweir { 110cdf0e10cSrcweir case XML_ROOT_CONTEXT: 111cdf0e10cSrcweir if( nRecId == BIFF12_ID_WORKSHEET ) return this; 112cdf0e10cSrcweir break; 113cdf0e10cSrcweir 114cdf0e10cSrcweir case BIFF12_ID_WORKSHEET: 115cdf0e10cSrcweir switch( nRecId ) 116cdf0e10cSrcweir { 117cdf0e10cSrcweir case BIFF12_ID_CHARTSHEETVIEWS: return this; 118cdf0e10cSrcweir 119cdf0e10cSrcweir case BIFF12_ID_CHARTSHEETPR: getWorksheetSettings().importChartSheetPr( rStrm ); break; 120cdf0e10cSrcweir case BIFF12_ID_CHARTPROTECTION: getWorksheetSettings().importChartProtection( rStrm ); break; 121cdf0e10cSrcweir case BIFF12_ID_PAGEMARGINS: getPageSettings().importPageMargins( rStrm ); break; 122cdf0e10cSrcweir case BIFF12_ID_CHARTPAGESETUP: getPageSettings().importChartPageSetup( getRelations(), rStrm ); break; 123cdf0e10cSrcweir case BIFF12_ID_HEADERFOOTER: getPageSettings().importHeaderFooter( rStrm ); break; 124cdf0e10cSrcweir case BIFF12_ID_PICTURE: getPageSettings().importPicture( getRelations(), rStrm ); break; 125cdf0e10cSrcweir case BIFF12_ID_DRAWING: importDrawing( rStrm ); break; 126cdf0e10cSrcweir } 127cdf0e10cSrcweir break; 128cdf0e10cSrcweir 129cdf0e10cSrcweir case BIFF12_ID_CHARTSHEETVIEWS: 130cdf0e10cSrcweir if( nRecId == BIFF12_ID_CHARTSHEETVIEW ) getSheetViewSettings().importChartSheetView( rStrm ); 131cdf0e10cSrcweir break; 132cdf0e10cSrcweir } 133cdf0e10cSrcweir return 0; 134cdf0e10cSrcweir } 135cdf0e10cSrcweir 136cdf0e10cSrcweir const RecordInfo* ChartsheetFragment::getRecordInfos() const 137cdf0e10cSrcweir { 138cdf0e10cSrcweir static const RecordInfo spRecInfos[] = 139cdf0e10cSrcweir { 140cdf0e10cSrcweir { BIFF12_ID_CHARTSHEETVIEW, BIFF12_ID_CHARTSHEETVIEW + 1 }, 141cdf0e10cSrcweir { BIFF12_ID_CHARTSHEETVIEWS, BIFF12_ID_CHARTSHEETVIEWS + 1 }, 142cdf0e10cSrcweir { BIFF12_ID_CUSTOMCHARTVIEW, BIFF12_ID_CUSTOMCHARTVIEW + 1 }, 143cdf0e10cSrcweir { BIFF12_ID_CUSTOMCHARTVIEWS, BIFF12_ID_CUSTOMCHARTVIEWS + 1 }, 144cdf0e10cSrcweir { BIFF12_ID_HEADERFOOTER, BIFF12_ID_HEADERFOOTER + 1 }, 145cdf0e10cSrcweir { BIFF12_ID_WORKSHEET, BIFF12_ID_WORKSHEET + 1 }, 146cdf0e10cSrcweir { -1, -1 } 147cdf0e10cSrcweir }; 148cdf0e10cSrcweir return spRecInfos; 149cdf0e10cSrcweir } 150cdf0e10cSrcweir 151cdf0e10cSrcweir void ChartsheetFragment::initializeImport() 152cdf0e10cSrcweir { 153cdf0e10cSrcweir // initial processing in base class WorksheetHelper 154cdf0e10cSrcweir initializeWorksheetImport(); 155cdf0e10cSrcweir } 156cdf0e10cSrcweir 157cdf0e10cSrcweir void ChartsheetFragment::finalizeImport() 158cdf0e10cSrcweir { 159cdf0e10cSrcweir // final processing in base class WorksheetHelper 160cdf0e10cSrcweir finalizeWorksheetImport(); 161cdf0e10cSrcweir } 162cdf0e10cSrcweir 163cdf0e10cSrcweir // private -------------------------------------------------------------------- 164cdf0e10cSrcweir 165cdf0e10cSrcweir void ChartsheetFragment::importDrawing( const AttributeList& rAttribs ) 166cdf0e10cSrcweir { 167cdf0e10cSrcweir setDrawingPath( getFragmentPathFromRelId( rAttribs.getString( R_TOKEN( id ), OUString() ) ) ); 168cdf0e10cSrcweir } 169cdf0e10cSrcweir 170cdf0e10cSrcweir void ChartsheetFragment::importDrawing( SequenceInputStream& rStrm ) 171cdf0e10cSrcweir { 172cdf0e10cSrcweir setDrawingPath( getFragmentPathFromRelId( BiffHelper::readString( rStrm ) ) ); 173cdf0e10cSrcweir } 174cdf0e10cSrcweir 175cdf0e10cSrcweir // ============================================================================ 176cdf0e10cSrcweir 177cdf0e10cSrcweir BiffChartsheetFragment::BiffChartsheetFragment( const WorksheetHelper& rHelper, const BiffWorkbookFragmentBase& rParent ) : 178cdf0e10cSrcweir BiffWorksheetFragmentBase( rHelper, rParent ) 179cdf0e10cSrcweir { 180cdf0e10cSrcweir } 181cdf0e10cSrcweir 182cdf0e10cSrcweir bool BiffChartsheetFragment::importFragment() 183cdf0e10cSrcweir { 184cdf0e10cSrcweir // initial processing in base class WorksheetHelper 185cdf0e10cSrcweir initializeWorksheetImport(); 186cdf0e10cSrcweir 187cdf0e10cSrcweir WorksheetSettings& rWorksheetSett = getWorksheetSettings(); 188cdf0e10cSrcweir SheetViewSettings& rSheetViewSett = getSheetViewSettings(); 189cdf0e10cSrcweir PageSettings& rPageSett = getPageSettings(); 190cdf0e10cSrcweir 191cdf0e10cSrcweir // process all record in this sheet fragment 192cdf0e10cSrcweir BiffInputStream& rStrm = getInputStream(); 193cdf0e10cSrcweir while( rStrm.startNextRecord() && (rStrm.getRecId() != BIFF_ID_EOF) ) 194cdf0e10cSrcweir { 195cdf0e10cSrcweir if( BiffHelper::isBofRecord( rStrm ) ) 196cdf0e10cSrcweir { 197cdf0e10cSrcweir // skip unknown embedded fragments (BOF/EOF blocks) 198cdf0e10cSrcweir skipFragment(); 199cdf0e10cSrcweir } 200cdf0e10cSrcweir else 201cdf0e10cSrcweir { 202cdf0e10cSrcweir sal_uInt16 nRecId = rStrm.getRecId(); 203cdf0e10cSrcweir switch( nRecId ) 204cdf0e10cSrcweir { 205cdf0e10cSrcweir // records in all BIFF versions 206cdf0e10cSrcweir case BIFF_ID_BOTTOMMARGIN: rPageSett.importBottomMargin( rStrm ); break; 207cdf0e10cSrcweir case BIFF_ID_CHBEGIN: BiffHelper::skipRecordBlock( rStrm, BIFF_ID_CHEND ); break; 208cdf0e10cSrcweir case BIFF_ID_FOOTER: rPageSett.importFooter( rStrm ); break; 209cdf0e10cSrcweir case BIFF_ID_HEADER: rPageSett.importHeader( rStrm ); break; 210cdf0e10cSrcweir case BIFF_ID_LEFTMARGIN: rPageSett.importLeftMargin( rStrm ); break; 211cdf0e10cSrcweir case BIFF_ID_PASSWORD: rWorksheetSett.importPassword( rStrm ); break; 212cdf0e10cSrcweir case BIFF_ID_PROTECT: rWorksheetSett.importProtect( rStrm ); break; 213cdf0e10cSrcweir case BIFF_ID_RIGHTMARGIN: rPageSett.importRightMargin( rStrm ); break; 214cdf0e10cSrcweir case BIFF_ID_TOPMARGIN: rPageSett.importTopMargin( rStrm ); break; 215cdf0e10cSrcweir 216cdf0e10cSrcweir // BIFF specific records 217cdf0e10cSrcweir default: switch( getBiff() ) 218cdf0e10cSrcweir { 219cdf0e10cSrcweir case BIFF2: switch( nRecId ) 220cdf0e10cSrcweir { 221cdf0e10cSrcweir case BIFF2_ID_WINDOW2: rSheetViewSett.importWindow2( rStrm ); break; 222cdf0e10cSrcweir } 223cdf0e10cSrcweir break; 224cdf0e10cSrcweir 225cdf0e10cSrcweir case BIFF3: switch( nRecId ) 226cdf0e10cSrcweir { 227cdf0e10cSrcweir case BIFF_ID_HCENTER: rPageSett.importHorCenter( rStrm ); break; 228cdf0e10cSrcweir case BIFF_ID_OBJECTPROTECT: rWorksheetSett.importObjectProtect( rStrm ); break; 229cdf0e10cSrcweir case BIFF_ID_VCENTER: rPageSett.importVerCenter( rStrm ); break; 230cdf0e10cSrcweir case BIFF3_ID_WINDOW2: rSheetViewSett.importWindow2( rStrm ); break; 231cdf0e10cSrcweir 232cdf0e10cSrcweir } 233cdf0e10cSrcweir break; 234cdf0e10cSrcweir 235cdf0e10cSrcweir case BIFF4: switch( nRecId ) 236cdf0e10cSrcweir { 237cdf0e10cSrcweir case BIFF_ID_HCENTER: rPageSett.importHorCenter( rStrm ); break; 238cdf0e10cSrcweir case BIFF_ID_OBJECTPROTECT: rWorksheetSett.importObjectProtect( rStrm ); break; 239cdf0e10cSrcweir case BIFF_ID_PAGESETUP: rPageSett.importPageSetup( rStrm ); break; 240cdf0e10cSrcweir case BIFF_ID_VCENTER: rPageSett.importVerCenter( rStrm ); break; 241cdf0e10cSrcweir case BIFF3_ID_WINDOW2: rSheetViewSett.importWindow2( rStrm ); break; 242cdf0e10cSrcweir } 243cdf0e10cSrcweir break; 244cdf0e10cSrcweir 245cdf0e10cSrcweir case BIFF5: switch( nRecId ) 246cdf0e10cSrcweir { 247cdf0e10cSrcweir case BIFF_ID_HCENTER: rPageSett.importHorCenter( rStrm ); break; 248cdf0e10cSrcweir case BIFF_ID_OBJECTPROTECT: rWorksheetSett.importObjectProtect( rStrm ); break; 249cdf0e10cSrcweir case BIFF_ID_PAGESETUP: rPageSett.importPageSetup( rStrm ); break; 250cdf0e10cSrcweir case BIFF_ID_SCENPROTECT: rWorksheetSett.importScenProtect( rStrm ); break; 251cdf0e10cSrcweir case BIFF_ID_SCL: rSheetViewSett.importScl( rStrm ); break; 252cdf0e10cSrcweir case BIFF_ID_VCENTER: rPageSett.importVerCenter( rStrm ); break; 253cdf0e10cSrcweir case BIFF3_ID_WINDOW2: rSheetViewSett.importWindow2( rStrm ); break; 254cdf0e10cSrcweir } 255cdf0e10cSrcweir break; 256cdf0e10cSrcweir 257cdf0e10cSrcweir case BIFF8: switch( nRecId ) 258cdf0e10cSrcweir { 259cdf0e10cSrcweir case BIFF_ID_CODENAME: rWorksheetSett.importCodeName( rStrm ); break; 260cdf0e10cSrcweir case BIFF_ID_HCENTER: rPageSett.importHorCenter( rStrm ); break; 261cdf0e10cSrcweir case BIFF_ID_OBJECTPROTECT: rWorksheetSett.importObjectProtect( rStrm ); break; 262cdf0e10cSrcweir case BIFF_ID_PICTURE: rPageSett.importPicture( rStrm ); break; 263cdf0e10cSrcweir case BIFF_ID_PAGESETUP: rPageSett.importPageSetup( rStrm ); break; 264cdf0e10cSrcweir case BIFF_ID_SCL: rSheetViewSett.importScl( rStrm ); break; 265cdf0e10cSrcweir case BIFF_ID_SHEETEXT: rWorksheetSett.importSheetExt( rStrm ); break; 266cdf0e10cSrcweir case BIFF_ID_VCENTER: rPageSett.importVerCenter( rStrm ); break; 267cdf0e10cSrcweir case BIFF3_ID_WINDOW2: rSheetViewSett.importWindow2( rStrm ); break; 268cdf0e10cSrcweir } 269cdf0e10cSrcweir break; 270cdf0e10cSrcweir 271cdf0e10cSrcweir case BIFF_UNKNOWN: break; 272cdf0e10cSrcweir } 273cdf0e10cSrcweir } 274cdf0e10cSrcweir } 275cdf0e10cSrcweir } 276cdf0e10cSrcweir 277cdf0e10cSrcweir // final processing in base class WorksheetHelper 278cdf0e10cSrcweir finalizeWorksheetImport(); 279cdf0e10cSrcweir return rStrm.getRecId() == BIFF_ID_EOF; 280cdf0e10cSrcweir } 281cdf0e10cSrcweir 282cdf0e10cSrcweir // ============================================================================ 283cdf0e10cSrcweir 284cdf0e10cSrcweir } // namespace xls 285cdf0e10cSrcweir } // namespace oox 286