diff options
Diffstat (limited to 'sc/source/ui/vba/vbapivottables.cxx')
-rw-r--r-- | sc/source/ui/vba/vbapivottables.cxx | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/sc/source/ui/vba/vbapivottables.cxx b/sc/source/ui/vba/vbapivottables.cxx new file mode 100644 index 000000000000..fcbf347a3cd4 --- /dev/null +++ b/sc/source/ui/vba/vbapivottables.cxx @@ -0,0 +1,94 @@ +/************************************************************************* + * + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * Copyright 2000, 2010 Oracle and/or its affiliates. + * + * OpenOffice.org - a multi-platform office productivity suite + * + * This file is part of OpenOffice.org. + * + * OpenOffice.org is free software: you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License version 3 + * only, as published by the Free Software Foundation. + * + * OpenOffice.org is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Lesser General Public License version 3 for more details + * (a copy is included in the LICENSE file that accompanied this code). + * + * You should have received a copy of the GNU Lesser General Public License + * version 3 along with OpenOffice.org. If not, see + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ +#include "vbapivottables.hxx" +#include "vbapivottable.hxx" +#include <com/sun/star/sheet/XDataPilotTable.hpp> +#include <ooo/vba/excel/XPivotTable.hpp> + + +using namespace ::com::sun::star; +using namespace ::ooo::vba; + +uno::Any DataPilotToPivotTable( const uno::Any& aSource, uno::Reference< uno::XComponentContext > & xContext ) +{ + uno::Reference< sheet::XDataPilotTable > xTable( aSource, uno::UNO_QUERY_THROW ); + return uno::makeAny( uno::Reference< excel::XPivotTable > ( new ScVbaPivotTable( xContext, xTable ) ) ); +} + +class PivotTableEnumeration : public EnumerationHelperImpl +{ +public: + PivotTableEnumeration( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext, const uno::Reference< container::XEnumeration >& xEnumeration ) throw ( uno::RuntimeException ) : EnumerationHelperImpl( xParent, xContext, xEnumeration ) {} + + virtual uno::Any SAL_CALL nextElement( ) throw (container::NoSuchElementException, lang::WrappedTargetException, uno::RuntimeException) + { + return DataPilotToPivotTable( m_xEnumeration->nextElement(), m_xContext ); + } + +}; + +ScVbaPivotTables::ScVbaPivotTables( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext > & xContext, const uno::Reference< container::XIndexAccess >& xIndexAccess ): ScVbaPivotTables_BASE( xParent, xContext, xIndexAccess ) +{ +} + +uno::Reference< container::XEnumeration > +ScVbaPivotTables::createEnumeration() throw (uno::RuntimeException) +{ + uno::Reference< container::XEnumerationAccess > xEnumAccess( m_xIndexAccess, uno::UNO_QUERY_THROW ); + return new PivotTableEnumeration( mxParent, mxContext, xEnumAccess->createEnumeration() ); +} + +uno::Any +ScVbaPivotTables::createCollectionObject( const css::uno::Any& aSource ) +{ + return DataPilotToPivotTable( aSource, mxContext ); +} + +uno::Type +ScVbaPivotTables::getElementType() throw (uno::RuntimeException) +{ + return excel::XPivotTable::static_type(0); +} + +rtl::OUString& +ScVbaPivotTables::getServiceImplName() +{ + static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaPivotTables") ); + return sImplName; +} + +css::uno::Sequence<rtl::OUString> +ScVbaPivotTables::getServiceNames() +{ + static uno::Sequence< rtl::OUString > sNames; + if ( sNames.getLength() == 0 ) + { + sNames.realloc( 1 ); + sNames[0] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.PivotTables") ); + } + return sNames; +} |