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
10*ca5ec200SAndrew Rist *
11*ca5ec200SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12*ca5ec200SAndrew Rist *
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.
19*ca5ec200SAndrew Rist *
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
ChartsheetFragment(const WorksheetHelper & rHelper,const OUString & rFragmentPath)44cdf0e10cSrcweir ChartsheetFragment::ChartsheetFragment( const WorksheetHelper& rHelper, const OUString& rFragmentPath ) :
45cdf0e10cSrcweir WorksheetFragmentBase( rHelper, rFragmentPath )
46cdf0e10cSrcweir {
47cdf0e10cSrcweir }
48cdf0e10cSrcweir
onCreateContext(sal_Int32 nElement,const AttributeList & rAttribs)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
onCharacters(const OUString & rChars)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
onCreateRecordContext(sal_Int32 nRecId,SequenceInputStream & rStrm)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
getRecordInfos() const136cdf0e10cSrcweir 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
initializeImport()151cdf0e10cSrcweir void ChartsheetFragment::initializeImport()
152cdf0e10cSrcweir {
153cdf0e10cSrcweir // initial processing in base class WorksheetHelper
154cdf0e10cSrcweir initializeWorksheetImport();
155cdf0e10cSrcweir }
156cdf0e10cSrcweir
finalizeImport()157cdf0e10cSrcweir void ChartsheetFragment::finalizeImport()
158cdf0e10cSrcweir {
159cdf0e10cSrcweir // final processing in base class WorksheetHelper
160cdf0e10cSrcweir finalizeWorksheetImport();
161cdf0e10cSrcweir }
162cdf0e10cSrcweir
163cdf0e10cSrcweir // private --------------------------------------------------------------------
164cdf0e10cSrcweir
importDrawing(const AttributeList & rAttribs)165cdf0e10cSrcweir void ChartsheetFragment::importDrawing( const AttributeList& rAttribs )
166cdf0e10cSrcweir {
167cdf0e10cSrcweir setDrawingPath( getFragmentPathFromRelId( rAttribs.getString( R_TOKEN( id ), OUString() ) ) );
168cdf0e10cSrcweir }
169cdf0e10cSrcweir
importDrawing(SequenceInputStream & rStrm)170cdf0e10cSrcweir void ChartsheetFragment::importDrawing( SequenceInputStream& rStrm )
171cdf0e10cSrcweir {
172cdf0e10cSrcweir setDrawingPath( getFragmentPathFromRelId( BiffHelper::readString( rStrm ) ) );
173cdf0e10cSrcweir }
174cdf0e10cSrcweir
175cdf0e10cSrcweir // ============================================================================
176cdf0e10cSrcweir
BiffChartsheetFragment(const WorksheetHelper & rHelper,const BiffWorkbookFragmentBase & rParent)177cdf0e10cSrcweir BiffChartsheetFragment::BiffChartsheetFragment( const WorksheetHelper& rHelper, const BiffWorkbookFragmentBase& rParent ) :
178cdf0e10cSrcweir BiffWorksheetFragmentBase( rHelper, rParent )
179cdf0e10cSrcweir {
180cdf0e10cSrcweir }
181cdf0e10cSrcweir
importFragment()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