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