1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir #include "oox/xls/tablebuffer.hxx" 29*cdf0e10cSrcweir 30*cdf0e10cSrcweir #include <com/sun/star/sheet/XDatabaseRange.hpp> 31*cdf0e10cSrcweir #include "oox/helper/attributelist.hxx" 32*cdf0e10cSrcweir #include "oox/helper/binaryinputstream.hxx" 33*cdf0e10cSrcweir #include "oox/helper/propertyset.hxx" 34*cdf0e10cSrcweir #include "oox/xls/addressconverter.hxx" 35*cdf0e10cSrcweir 36*cdf0e10cSrcweir namespace oox { 37*cdf0e10cSrcweir namespace xls { 38*cdf0e10cSrcweir 39*cdf0e10cSrcweir // ============================================================================ 40*cdf0e10cSrcweir 41*cdf0e10cSrcweir using namespace ::com::sun::star::container; 42*cdf0e10cSrcweir using namespace ::com::sun::star::sheet; 43*cdf0e10cSrcweir using namespace ::com::sun::star::uno; 44*cdf0e10cSrcweir 45*cdf0e10cSrcweir using ::rtl::OUString; 46*cdf0e10cSrcweir 47*cdf0e10cSrcweir // ============================================================================ 48*cdf0e10cSrcweir 49*cdf0e10cSrcweir TableModel::TableModel() : 50*cdf0e10cSrcweir mnId( -1 ), 51*cdf0e10cSrcweir mnType( XML_worksheet ), 52*cdf0e10cSrcweir mnHeaderRows( 1 ), 53*cdf0e10cSrcweir mnTotalsRows( 0 ) 54*cdf0e10cSrcweir { 55*cdf0e10cSrcweir } 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir // ============================================================================ 58*cdf0e10cSrcweir 59*cdf0e10cSrcweir Table::Table( const WorkbookHelper& rHelper ) : 60*cdf0e10cSrcweir WorkbookHelper( rHelper ), 61*cdf0e10cSrcweir maAutoFilters( rHelper ), 62*cdf0e10cSrcweir mnTokenIndex( -1 ) 63*cdf0e10cSrcweir { 64*cdf0e10cSrcweir } 65*cdf0e10cSrcweir 66*cdf0e10cSrcweir void Table::importTable( const AttributeList& rAttribs, sal_Int16 nSheet ) 67*cdf0e10cSrcweir { 68*cdf0e10cSrcweir getAddressConverter().convertToCellRangeUnchecked( maModel.maRange, rAttribs.getString( XML_ref, OUString() ), nSheet ); 69*cdf0e10cSrcweir maModel.maProgName = rAttribs.getXString( XML_name, OUString() ); 70*cdf0e10cSrcweir maModel.maDisplayName = rAttribs.getXString( XML_displayName, OUString() ); 71*cdf0e10cSrcweir maModel.mnId = rAttribs.getInteger( XML_id, -1 ); 72*cdf0e10cSrcweir maModel.mnType = rAttribs.getToken( XML_tableType, XML_worksheet ); 73*cdf0e10cSrcweir maModel.mnHeaderRows = rAttribs.getInteger( XML_headerRowCount, 1 ); 74*cdf0e10cSrcweir maModel.mnTotalsRows = rAttribs.getInteger( XML_totalsRowCount, 0 ); 75*cdf0e10cSrcweir } 76*cdf0e10cSrcweir 77*cdf0e10cSrcweir void Table::importTable( SequenceInputStream& rStrm, sal_Int16 nSheet ) 78*cdf0e10cSrcweir { 79*cdf0e10cSrcweir BinRange aBinRange; 80*cdf0e10cSrcweir sal_Int32 nType; 81*cdf0e10cSrcweir rStrm >> aBinRange >> nType >> maModel.mnId >> maModel.mnHeaderRows >> maModel.mnTotalsRows; 82*cdf0e10cSrcweir rStrm.skip( 32 ); 83*cdf0e10cSrcweir rStrm >> maModel.maProgName >> maModel.maDisplayName; 84*cdf0e10cSrcweir 85*cdf0e10cSrcweir getAddressConverter().convertToCellRangeUnchecked( maModel.maRange, aBinRange, nSheet ); 86*cdf0e10cSrcweir static const sal_Int32 spnTypes[] = { XML_worksheet, XML_TOKEN_INVALID, XML_TOKEN_INVALID, XML_queryTable }; 87*cdf0e10cSrcweir maModel.mnType = STATIC_ARRAY_SELECT( spnTypes, nType, XML_TOKEN_INVALID ); 88*cdf0e10cSrcweir } 89*cdf0e10cSrcweir 90*cdf0e10cSrcweir void Table::finalizeImport() 91*cdf0e10cSrcweir { 92*cdf0e10cSrcweir // create database range 93*cdf0e10cSrcweir if( (maModel.mnId > 0) && (maModel.maDisplayName.getLength() > 0) ) try 94*cdf0e10cSrcweir { 95*cdf0e10cSrcweir maDBRangeName = maModel.maDisplayName; 96*cdf0e10cSrcweir Reference< XDatabaseRange > xDatabaseRange( createDatabaseRangeObject( maDBRangeName, maModel.maRange ), UNO_SET_THROW ); 97*cdf0e10cSrcweir maDestRange = xDatabaseRange->getDataArea(); 98*cdf0e10cSrcweir 99*cdf0e10cSrcweir // get formula token index of the database range 100*cdf0e10cSrcweir PropertySet aPropSet( xDatabaseRange ); 101*cdf0e10cSrcweir if( !aPropSet.getProperty( mnTokenIndex, PROP_TokenIndex ) ) 102*cdf0e10cSrcweir mnTokenIndex = -1; 103*cdf0e10cSrcweir 104*cdf0e10cSrcweir // filter settings 105*cdf0e10cSrcweir maAutoFilters.finalizeImport( xDatabaseRange ); 106*cdf0e10cSrcweir } 107*cdf0e10cSrcweir catch( Exception& ) 108*cdf0e10cSrcweir { 109*cdf0e10cSrcweir OSL_ENSURE( false, "Table::finalizeImport - cannot create database range" ); 110*cdf0e10cSrcweir } 111*cdf0e10cSrcweir } 112*cdf0e10cSrcweir 113*cdf0e10cSrcweir // ============================================================================ 114*cdf0e10cSrcweir 115*cdf0e10cSrcweir TableBuffer::TableBuffer( const WorkbookHelper& rHelper ) : 116*cdf0e10cSrcweir WorkbookHelper( rHelper ) 117*cdf0e10cSrcweir { 118*cdf0e10cSrcweir } 119*cdf0e10cSrcweir 120*cdf0e10cSrcweir Table& TableBuffer::createTable() 121*cdf0e10cSrcweir { 122*cdf0e10cSrcweir TableVector::value_type xTable( new Table( *this ) ); 123*cdf0e10cSrcweir maTables.push_back( xTable ); 124*cdf0e10cSrcweir return *xTable; 125*cdf0e10cSrcweir } 126*cdf0e10cSrcweir 127*cdf0e10cSrcweir void TableBuffer::finalizeImport() 128*cdf0e10cSrcweir { 129*cdf0e10cSrcweir // map all tables by identifier and display name 130*cdf0e10cSrcweir for( TableVector::iterator aIt = maTables.begin(), aEnd = maTables.end(); aIt != aEnd; ++aIt ) 131*cdf0e10cSrcweir insertTableToMaps( *aIt ); 132*cdf0e10cSrcweir // finalize all valid tables 133*cdf0e10cSrcweir maIdTables.forEachMem( &Table::finalizeImport ); 134*cdf0e10cSrcweir } 135*cdf0e10cSrcweir 136*cdf0e10cSrcweir TableRef TableBuffer::getTable( sal_Int32 nTableId ) const 137*cdf0e10cSrcweir { 138*cdf0e10cSrcweir return maIdTables.get( nTableId ); 139*cdf0e10cSrcweir } 140*cdf0e10cSrcweir 141*cdf0e10cSrcweir TableRef TableBuffer::getTable( const OUString& rDispName ) const 142*cdf0e10cSrcweir { 143*cdf0e10cSrcweir return maNameTables.get( rDispName ); 144*cdf0e10cSrcweir } 145*cdf0e10cSrcweir 146*cdf0e10cSrcweir // private -------------------------------------------------------------------- 147*cdf0e10cSrcweir 148*cdf0e10cSrcweir void TableBuffer::insertTableToMaps( const TableRef& rxTable ) 149*cdf0e10cSrcweir { 150*cdf0e10cSrcweir sal_Int32 nTableId = rxTable->getTableId(); 151*cdf0e10cSrcweir const OUString& rDispName = rxTable->getDisplayName(); 152*cdf0e10cSrcweir if( (nTableId > 0) && (rDispName.getLength() > 0) ) 153*cdf0e10cSrcweir { 154*cdf0e10cSrcweir OSL_ENSURE( !maIdTables.has( nTableId ), "TableBuffer::insertTableToMaps - multiple table identifier" ); 155*cdf0e10cSrcweir maIdTables[ nTableId ] = rxTable; 156*cdf0e10cSrcweir OSL_ENSURE( !maNameTables.has( rDispName ), "TableBuffer::insertTableToMaps - multiple table name" ); 157*cdf0e10cSrcweir maNameTables[ rDispName ] = rxTable; 158*cdf0e10cSrcweir } 159*cdf0e10cSrcweir } 160*cdf0e10cSrcweir 161*cdf0e10cSrcweir // ============================================================================ 162*cdf0e10cSrcweir 163*cdf0e10cSrcweir } // namespace xls 164*cdf0e10cSrcweir } // namespace oox 165