/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2008 by Sun Microsystems, Inc. * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: datauno.cxx,v $ * $Revision: 1.30.32.1 $ * * 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_sc.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include "datauno.hxx" #include "dapiuno.hxx" #include "cellsuno.hxx" #include "miscuno.hxx" #include "targuno.hxx" #include "rangeutl.hxx" #include "dbcolect.hxx" #include "docsh.hxx" #include "dbdocfun.hxx" #include "unoguard.hxx" #include "unonames.hxx" #include "globstr.hrc" #ifndef SC_CONVUNO_HXX #include "convuno.hxx" #include "hints.hxx" #endif #include "attrib.hxx" #include "dpshttab.hxx" #include #include using namespace com::sun::star; SV_IMPL_PTRARR( XDBRefreshListenerArr_Impl, XDBRefreshListenerPtr ); //------------------------------------------------------------------------ // alles ohne Which-ID, Map nur fuer PropertySetInfo const SfxItemPropertyMapEntry* lcl_GetSubTotalPropertyMap() { // some old property names are for 5.2 compatibility static SfxItemPropertyMapEntry aSubTotalPropertyMap_Impl[] = { {MAP_CHAR_LEN(SC_UNONAME_BINDFMT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_CASE), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ENABSORT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ENUSLIST), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_FORMATS), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_INSBRK), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ISCASE), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_MAXFLD), 0, &getCppuType((sal_Int32*)0), beans::PropertyAttribute::READONLY, 0}, {MAP_CHAR_LEN(SC_UNONAME_SORTASC), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ULIST), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_UINDEX), 0, &getCppuType((sal_Int32*)0), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_USINDEX), 0, &getCppuType((sal_Int32*)0), 0, 0}, {0,0,0,0,0,0} }; return aSubTotalPropertyMap_Impl; } const SfxItemPropertyMapEntry* lcl_GetFilterPropertyMap() { static SfxItemPropertyMapEntry aFilterPropertyMap_Impl[] = { {MAP_CHAR_LEN(SC_UNONAME_CONTHDR), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_COPYOUT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ISCASE), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_MAXFLD), 0, &getCppuType((sal_Int32*)0), beans::PropertyAttribute::READONLY, 0}, {MAP_CHAR_LEN(SC_UNONAME_ORIENT), 0, &getCppuType((table::TableOrientation*)0), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_OUTPOS), 0, &getCppuType((table::CellAddress*)0), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_SAVEOUT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_SKIPDUP), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_USEREGEX), 0, &getBooleanCppuType(), 0, 0}, {0,0,0,0,0,0} }; return aFilterPropertyMap_Impl; } const SfxItemPropertyMapEntry* lcl_GetDBRangePropertyMap() { static SfxItemPropertyMapEntry aDBRangePropertyMap_Impl[] = { {MAP_CHAR_LEN(SC_UNONAME_AUTOFLT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_FLTCRT), 0, &getCppuType((table::CellRangeAddress*)0), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_FROMSELECT),0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_ISUSER), 0, &getBooleanCppuType(), beans::PropertyAttribute::READONLY, 0 }, {MAP_CHAR_LEN(SC_UNONAME_KEEPFORM), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNO_LINKDISPBIT), 0, &getCppuType((uno::Reference*)0), beans::PropertyAttribute::READONLY, 0 }, {MAP_CHAR_LEN(SC_UNO_LINKDISPNAME), 0, &getCppuType((rtl::OUString*)0), beans::PropertyAttribute::READONLY, 0 }, {MAP_CHAR_LEN(SC_UNONAME_MOVCELLS), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_REFPERIOD), 0, &getCppuType((sal_Int32*)0), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_STRIPDAT), 0, &getBooleanCppuType(), 0, 0}, {MAP_CHAR_LEN(SC_UNONAME_TOKENINDEX),0, &getCppuType((sal_Int32*)0), beans::PropertyAttribute::READONLY, 0 }, {MAP_CHAR_LEN(SC_UNONAME_USEFLTCRT),0, &getBooleanCppuType(), 0, 0}, {0,0,0,0,0,0} }; return aDBRangePropertyMap_Impl; } //------------------------------------------------------------------------ #define SCDATABASERANGEOBJ_SERVICE "com.sun.star.sheet.DatabaseRange" SC_SIMPLE_SERVICE_INFO( ScConsolidationDescriptor, "ScConsolidationDescriptor", "com.sun.star.sheet.ConsolidationDescriptor" ) SC_SIMPLE_SERVICE_INFO( ScDatabaseRangesObj, "ScDatabaseRangesObj", "com.sun.star.sheet.DatabaseRanges" ) SC_SIMPLE_SERVICE_INFO( ScFilterDescriptorBase, "ScFilterDescriptorBase", "com.sun.star.sheet.SheetFilterDescriptor" ) SC_SIMPLE_SERVICE_INFO( ScSubTotalDescriptorBase, "ScSubTotalDescriptorBase", "com.sun.star.sheet.SubTotalDescriptor" ) SC_SIMPLE_SERVICE_INFO( ScSubTotalFieldObj, "ScSubTotalFieldObj", "com.sun.star.sheet.SubTotalField" ) //------------------------------------------------------------------------ // static ScSubTotalFunc ScDataUnoConversion::GeneralToSubTotal( sheet::GeneralFunction eSummary ) { ScSubTotalFunc eSubTotal; switch (eSummary) { case sheet::GeneralFunction_NONE: eSubTotal = SUBTOTAL_FUNC_NONE; break; case sheet::GeneralFunction_SUM: eSubTotal = SUBTOTAL_FUNC_SUM; break; case sheet::GeneralFunction_COUNT: eSubTotal = SUBTOTAL_FUNC_CNT2; break; case sheet::GeneralFunction_AVERAGE: eSubTotal = SUBTOTAL_FUNC_AVE; break; case sheet::GeneralFunction_MAX: eSubTotal = SUBTOTAL_FUNC_MAX; break; case sheet::GeneralFunction_MIN: eSubTotal = SUBTOTAL_FUNC_MIN; break; case sheet::GeneralFunction_PRODUCT: eSubTotal = SUBTOTAL_FUNC_PROD; break; case sheet::GeneralFunction_COUNTNUMS: eSubTotal = SUBTOTAL_FUNC_CNT; break; case sheet::GeneralFunction_STDEV: eSubTotal = SUBTOTAL_FUNC_STD; break; case sheet::GeneralFunction_STDEVP: eSubTotal = SUBTOTAL_FUNC_STDP; break; case sheet::GeneralFunction_VAR: eSubTotal = SUBTOTAL_FUNC_VAR; break; case sheet::GeneralFunction_VARP: eSubTotal = SUBTOTAL_FUNC_VARP; break; case sheet::GeneralFunction_AUTO: default: DBG_ERROR("GeneralToSubTotal: falscher enum"); eSubTotal = SUBTOTAL_FUNC_NONE; } return eSubTotal; } // static sheet::GeneralFunction ScDataUnoConversion::SubTotalToGeneral( ScSubTotalFunc eSubTotal ) { sheet::GeneralFunction eGeneral; switch (eSubTotal) { case SUBTOTAL_FUNC_NONE: eGeneral = sheet::GeneralFunction_NONE; break; case SUBTOTAL_FUNC_AVE: eGeneral = sheet::GeneralFunction_AVERAGE; break; case SUBTOTAL_FUNC_CNT: eGeneral = sheet::GeneralFunction_COUNTNUMS; break; case SUBTOTAL_FUNC_CNT2: eGeneral = sheet::GeneralFunction_COUNT; break; case SUBTOTAL_FUNC_MAX: eGeneral = sheet::GeneralFunction_MAX; break; case SUBTOTAL_FUNC_MIN: eGeneral = sheet::GeneralFunction_MIN; break; case SUBTOTAL_FUNC_PROD: eGeneral = sheet::GeneralFunction_PRODUCT; break; case SUBTOTAL_FUNC_STD: eGeneral = sheet::GeneralFunction_STDEV; break; case SUBTOTAL_FUNC_STDP: eGeneral = sheet::GeneralFunction_STDEVP; break; case SUBTOTAL_FUNC_SUM: eGeneral = sheet::GeneralFunction_SUM; break; case SUBTOTAL_FUNC_VAR: eGeneral = sheet::GeneralFunction_VAR; break; case SUBTOTAL_FUNC_VARP: eGeneral = sheet::GeneralFunction_VARP; break; default: DBG_ERROR("SubTotalToGeneral: falscher enum"); eGeneral = sheet::GeneralFunction_NONE; break; } return eGeneral; } //------------------------------------------------------------------------ // ScImportDescriptor: alles static long ScImportDescriptor::GetPropertyCount() { return 4; } void ScImportDescriptor::FillProperties( uno::Sequence& rSeq, const ScImportParam& rParam ) { DBG_ASSERT( rSeq.getLength() == GetPropertyCount(), "falscher Count" ); beans::PropertyValue* pArray = rSeq.getArray(); sheet::DataImportMode eMode = sheet::DataImportMode_NONE; if ( rParam.bImport ) { if ( rParam.bSql ) eMode = sheet::DataImportMode_SQL; else if ( rParam.nType == ScDbQuery ) eMode = sheet::DataImportMode_QUERY; else eMode = sheet::DataImportMode_TABLE; // Type ist immer ScDbQuery oder ScDbTable } ::svx::ODataAccessDescriptor aDescriptor; aDescriptor.setDataSource(rParam.aDBName); if (aDescriptor.has( svx::daDataSource )) { pArray[0].Name = rtl::OUString::createFromAscii( SC_UNONAME_DBNAME ); pArray[0].Value <<= rtl::OUString( rParam.aDBName ); } else if (aDescriptor.has( svx::daConnectionResource )) { pArray[0].Name = rtl::OUString::createFromAscii( SC_UNONAME_CONRES ); pArray[0].Value <<= rtl::OUString( rParam.aDBName ); } pArray[1].Name = rtl::OUString::createFromAscii( SC_UNONAME_SRCTYPE ); pArray[1].Value <<= eMode; pArray[2].Name = rtl::OUString::createFromAscii( SC_UNONAME_SRCOBJ ); pArray[2].Value <<= rtl::OUString( rParam.aStatement ); pArray[3].Name = rtl::OUString::createFromAscii( SC_UNONAME_ISNATIVE ); ScUnoHelpFunctions::SetBoolInAny( pArray[3].Value, rParam.bNative ); } void ScImportDescriptor::FillImportParam( ScImportParam& rParam, const uno::Sequence& rSeq ) { rtl::OUString aStrVal; const beans::PropertyValue* pPropArray = rSeq.getConstArray(); long nPropCount = rSeq.getLength(); for (long i = 0; i < nPropCount; i++) { const beans::PropertyValue& rProp = pPropArray[i]; String aPropName(rProp.Name); if (aPropName.EqualsAscii( SC_UNONAME_ISNATIVE )) rParam.bNative = ScUnoHelpFunctions::GetBoolFromAny( rProp.Value ); else if (aPropName.EqualsAscii( SC_UNONAME_DBNAME )) { if ( rProp.Value >>= aStrVal ) rParam.aDBName = String( aStrVal ); } else if (aPropName.EqualsAscii( SC_UNONAME_CONRES )) { if ( rProp.Value >>= aStrVal ) rParam.aDBName = String( aStrVal ); } else if (aPropName.EqualsAscii( SC_UNONAME_SRCOBJ )) { if ( rProp.Value >>= aStrVal ) rParam.aStatement = String( aStrVal ); } else if (aPropName.EqualsAscii( SC_UNONAME_SRCTYPE )) { //! test for correct enum type? sheet::DataImportMode eMode = (sheet::DataImportMode) ScUnoHelpFunctions::GetEnumFromAny( rProp.Value ); switch (eMode) { case sheet::DataImportMode_NONE: rParam.bImport = FALSE; break; case sheet::DataImportMode_SQL: rParam.bImport = TRUE; rParam.bSql = TRUE; break; case sheet::DataImportMode_TABLE: rParam.bImport = TRUE; rParam.bSql = FALSE; rParam.nType = ScDbTable; break; case sheet::DataImportMode_QUERY: rParam.bImport = TRUE; rParam.bSql = FALSE; rParam.nType = ScDbQuery; break; default: DBG_ERROR("falscher Mode"); rParam.bImport = FALSE; } } } } //------------------------------------------------------------------------ // ScSortDescriptor: alles static //! SortAscending muss aus der SheetSortDescriptor service-Beschreibung raus long ScSortDescriptor::GetPropertyCount() { return 9; // TableSortDescriptor and SheetSortDescriptor } void ScSortDescriptor::FillProperties( uno::Sequence& rSeq, const ScSortParam& rParam ) { DBG_ASSERT( rSeq.getLength() == GetPropertyCount(), "falscher Count" ); beans::PropertyValue* pArray = rSeq.getArray(); // Uno-Werte zusammensuchen table::CellAddress aOutPos; aOutPos.Sheet = rParam.nDestTab; aOutPos.Column = rParam.nDestCol; aOutPos.Row = rParam.nDestRow; USHORT nSortCount = 0; while ( nSortCount < MAXSORT && rParam.bDoSort[nSortCount] ) ++nSortCount; uno::Sequence aFields(nSortCount); if (nSortCount) { table::TableSortField* pFieldArray = aFields.getArray(); for (USHORT i=0; i& rSeq ) { sal_Bool bOldSortDescriptor(sal_False); sal_Bool bNewSortDescriptor(sal_False); const beans::PropertyValue* pPropArray = rSeq.getConstArray(); long nPropCount = rSeq.getLength(); for (long nProp = 0; nProp < nPropCount; nProp++) { const beans::PropertyValue& rProp = pPropArray[nProp]; String aPropName(rProp.Name); if (aPropName.EqualsAscii( SC_UNONAME_ORIENT )) { bOldSortDescriptor = sal_True; //! test for correct enum type? table::TableOrientation eOrient = (table::TableOrientation) ScUnoHelpFunctions::GetEnumFromAny( rProp.Value ); rParam.bByRow = ( eOrient != table::TableOrientation_COLUMNS ); } else if (aPropName.EqualsAscii( SC_UNONAME_ISSORTCOLUMNS )) { bNewSortDescriptor = sal_True; rParam.bByRow = !::cppu::any2bool(rProp.Value); } else if (aPropName.EqualsAscii( SC_UNONAME_CONTHDR )) rParam.bHasHeader = ScUnoHelpFunctions::GetBoolFromAny( rProp.Value ); else if (aPropName.EqualsAscii( SC_UNONAME_MAXFLD )) { sal_Int32 nVal; if ( (rProp.Value >>= nVal) && nVal > MAXSORT ) { //! specify exceptions //! throw lang::IllegalArgumentException(); } } else if (aPropName.EqualsAscii( SC_UNONAME_SORTFLD )) { uno::Sequence aSeq; uno::Sequence aNewSeq; if ( rProp.Value >>= aSeq ) { bOldSortDescriptor = sal_True; INT32 nCount = aSeq.getLength(); INT32 i; if ( nCount > MAXSORT ) { DBG_ERROR("Zu viele Sortierfelder"); nCount = MAXSORT; } const util::SortField* pFieldArray = aSeq.getConstArray(); for (i=0; i>= aNewSeq ) { bNewSortDescriptor = sal_True; INT32 nCount = aNewSeq.getLength(); INT32 i; if ( nCount > MAXSORT ) { DBG_ERROR("Zu viele Sortierfelder"); nCount = MAXSORT; } const table::TableSortField* pFieldArray = aNewSeq.getConstArray(); for (i=0; i>= aAddress ) { rParam.nDestTab = aAddress.Sheet; rParam.nDestCol = (SCCOL)aAddress.Column; rParam.nDestRow = (SCROW)aAddress.Row; } } else if (aPropName.EqualsAscii( SC_UNONAME_ISULIST )) rParam.bUserDef = ScUnoHelpFunctions::GetBoolFromAny( rProp.Value ); else if (aPropName.EqualsAscii( SC_UNONAME_UINDEX )) { sal_Int32 nVal = 0; if ( rProp.Value >>= nVal ) rParam.nUserIndex = (USHORT)nVal; } else if (aPropName.EqualsAscii( SC_UNONAME_COLLLOC )) { bOldSortDescriptor = sal_True; rProp.Value >>= rParam.aCollatorLocale; } else if (aPropName.EqualsAscii( SC_UNONAME_COLLALG )) { bOldSortDescriptor = sal_True; rtl::OUString sStr; if ( rProp.Value >>= sStr ) rParam.aCollatorAlgorithm = sStr; } } } //------------------------------------------------------------------------ ScSubTotalFieldObj::ScSubTotalFieldObj( ScSubTotalDescriptorBase* pDesc, USHORT nP ) : xRef( pDesc ), // Objekt festhalten rParent( *pDesc ), nPos( nP ) { DBG_ASSERT(pDesc, "ScSubTotalFieldObj: Parent ist 0"); } ScSubTotalFieldObj::~ScSubTotalFieldObj() { } // XSubTotalField sal_Int32 SAL_CALL ScSubTotalFieldObj::getGroupColumn() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; rParent.GetData(aParam); return aParam.nField[nPos]; } void SAL_CALL ScSubTotalFieldObj::setGroupColumn( sal_Int32 nGroupColumn ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; rParent.GetData(aParam); aParam.nField[nPos] = (SCCOL)nGroupColumn; rParent.PutData(aParam); } uno::Sequence SAL_CALL ScSubTotalFieldObj::getSubTotalColumns() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; rParent.GetData(aParam); SCCOL nCount = aParam.nSubTotals[nPos]; uno::Sequence aSeq(nCount); sheet::SubTotalColumn* pAry = aSeq.getArray(); for (SCCOL i=0; i& aSubTotalColumns ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; rParent.GetData(aParam); UINT32 nColCount = aSubTotalColumns.getLength(); if ( nColCount <= sal::static_int_cast(SCCOL_MAX) ) { SCCOL nCount = static_cast(nColCount); aParam.nSubTotals[nPos] = nCount; if (nCount != 0) { aParam.pSubTotals[nPos] = new SCCOL[nCount]; aParam.pFunctions[nPos] = new ScSubTotalFunc[nCount]; const sheet::SubTotalColumn* pAry = aSubTotalColumns.getConstArray(); for (SCCOL i=0; i(pAry[i].Column); aParam.pFunctions[nPos][i] = ScDataUnoConversion::GeneralToSubTotal( pAry[i].Function ); } } else { aParam.pSubTotals[nPos] = NULL; aParam.pFunctions[nPos] = NULL; } } //! sonst Exception oder so? (zuviele Spalten) rParent.PutData(aParam); } //------------------------------------------------------------------------ ScSubTotalDescriptorBase::ScSubTotalDescriptorBase() : aPropSet( lcl_GetSubTotalPropertyMap() ) { } ScSubTotalDescriptorBase::~ScSubTotalDescriptorBase() { } // GetData/PutData hier nur wegen NewInstance-Krempel implementiert... void ScSubTotalDescriptorBase::GetData( ScSubTotalParam& /* rParam */ ) const { DBG_ERROR("ScSubTotalDescriptorBase::GetData soll nicht gerufen werden"); } void ScSubTotalDescriptorBase::PutData( const ScSubTotalParam& /* rParam */ ) { DBG_ERROR("ScSubTotalDescriptorBase::PutData soll nicht gerufen werden"); } // XSubTotalDesctiptor ScSubTotalFieldObj* ScSubTotalDescriptorBase::GetObjectByIndex_Impl(USHORT nIndex) { if ( nIndex < getCount() ) return new ScSubTotalFieldObj( this, nIndex ); return NULL; } void SAL_CALL ScSubTotalDescriptorBase::clear() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; GetData(aParam); for (USHORT i=0; i& aSubTotalColumns, sal_Int32 nGroupColumn ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; GetData(aParam); USHORT nPos = 0; while ( nPos < MAXSUBTOTAL && aParam.bGroupActive[nPos] ) ++nPos; UINT32 nColCount = aSubTotalColumns.getLength(); if ( nPos < MAXSUBTOTAL && nColCount <= sal::static_int_cast(SCCOL_MAX) ) { aParam.bGroupActive[nPos] = TRUE; aParam.nField[nPos] = static_cast(nGroupColumn); delete aParam.pSubTotals[nPos]; delete aParam.pFunctions[nPos]; SCCOL nCount = static_cast(nColCount); aParam.nSubTotals[nPos] = nCount; if (nCount != 0) { aParam.pSubTotals[nPos] = new SCCOL[nCount]; aParam.pFunctions[nPos] = new ScSubTotalFunc[nCount]; const sheet::SubTotalColumn* pAry = aSubTotalColumns.getConstArray(); for (SCCOL i=0; i(pAry[i].Column); aParam.pFunctions[nPos][i] = ScDataUnoConversion::GeneralToSubTotal( pAry[i].Function ); } } else { aParam.pSubTotals[nPos] = NULL; aParam.pFunctions[nPos] = NULL; } } else // too many fields / columns throw uno::RuntimeException(); // no other exceptions specified PutData(aParam); } // Flags/Einstellungen als Properties // XEnumerationAccess uno::Reference SAL_CALL ScSubTotalDescriptorBase::createEnumeration() throw(uno::RuntimeException) { ScUnoGuard aGuard; return new ScIndexEnumeration(this, rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("com.sun.star.sheet.SubTotalFieldsEnumeration"))); } // XIndexAccess sal_Int32 SAL_CALL ScSubTotalDescriptorBase::getCount() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; GetData(aParam); USHORT nCount = 0; while ( nCount < MAXSUBTOTAL && aParam.bGroupActive[nCount] ) ++nCount; return nCount; } uno::Any SAL_CALL ScSubTotalDescriptorBase::getByIndex( sal_Int32 nIndex ) throw(lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; uno::Reference xField(GetObjectByIndex_Impl((USHORT)nIndex)); if (xField.is()) return uno::makeAny(xField); else throw lang::IndexOutOfBoundsException(); // return uno::Any(); } uno::Type SAL_CALL ScSubTotalDescriptorBase::getElementType() throw(uno::RuntimeException) { ScUnoGuard aGuard; return getCppuType((uno::Reference*)0); } sal_Bool SAL_CALL ScSubTotalDescriptorBase::hasElements() throw(uno::RuntimeException) { ScUnoGuard aGuard; return ( getCount() != 0 ); } // XPropertySet uno::Reference SAL_CALL ScSubTotalDescriptorBase::getPropertySetInfo() throw(uno::RuntimeException) { ScUnoGuard aGuard; static uno::Reference aRef( new SfxItemPropertySetInfo( aPropSet.getPropertyMap() )); return aRef; } void SAL_CALL ScSubTotalDescriptorBase::setPropertyValue( const rtl::OUString& aPropertyName, const uno::Any& aValue ) throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; GetData(aParam); String aString(aPropertyName); // some old property names are for 5.2 compatibility if (aString.EqualsAscii( SC_UNONAME_CASE ) || aString.EqualsAscii( SC_UNONAME_ISCASE )) aParam.bCaseSens = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_FORMATS ) || aString.EqualsAscii( SC_UNONAME_BINDFMT )) aParam.bIncludePattern = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_ENABSORT )) aParam.bDoSort = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_SORTASC )) aParam.bAscending = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_INSBRK )) aParam.bPagebreak = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_ULIST ) || aString.EqualsAscii( SC_UNONAME_ENUSLIST )) aParam.bUserDef = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_UINDEX ) || aString.EqualsAscii( SC_UNONAME_USINDEX )) { sal_Int32 nVal = 0; if ( aValue >>= nVal ) aParam.nUserIndex = (USHORT)nVal; } else if (aString.EqualsAscii( SC_UNONAME_MAXFLD )) { sal_Int32 nVal = 0; if ( (aValue >>= nVal) && nVal > sal::static_int_cast(MAXSUBTOTAL) ) { throw lang::IllegalArgumentException(); } } PutData(aParam); } uno::Any SAL_CALL ScSubTotalDescriptorBase::getPropertyValue( const rtl::OUString& aPropertyName ) throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; ScSubTotalParam aParam; GetData(aParam); String aString(aPropertyName); uno::Any aRet; // some old property names are for 5.2 compatibility if (aString.EqualsAscii( SC_UNONAME_CASE ) || aString.EqualsAscii( SC_UNONAME_ISCASE )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bCaseSens ); else if (aString.EqualsAscii( SC_UNONAME_FORMATS ) || aString.EqualsAscii( SC_UNONAME_BINDFMT )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bIncludePattern ); else if (aString.EqualsAscii( SC_UNONAME_ENABSORT )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bDoSort ); else if (aString.EqualsAscii( SC_UNONAME_SORTASC )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bAscending ); else if (aString.EqualsAscii( SC_UNONAME_INSBRK )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bPagebreak ); else if (aString.EqualsAscii( SC_UNONAME_ULIST ) || aString.EqualsAscii( SC_UNONAME_ENUSLIST )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bUserDef ); else if (aString.EqualsAscii( SC_UNONAME_UINDEX ) || aString.EqualsAscii( SC_UNONAME_USINDEX )) aRet <<= (sal_Int32) aParam.nUserIndex; else if (aString.EqualsAscii( SC_UNONAME_MAXFLD )) aRet <<= (sal_Int32) MAXSUBTOTAL; return aRet; } SC_IMPL_DUMMY_PROPERTY_LISTENER( ScSubTotalDescriptorBase ) // XUnoTunnel sal_Int64 SAL_CALL ScSubTotalDescriptorBase::getSomething( const uno::Sequence& rId ) throw(uno::RuntimeException) { if ( rId.getLength() == 16 && 0 == rtl_compareMemory( getUnoTunnelId().getConstArray(), rId.getConstArray(), 16 ) ) { return sal::static_int_cast(reinterpret_cast(this)); } return 0; } // static const uno::Sequence& ScSubTotalDescriptorBase::getUnoTunnelId() { static uno::Sequence * pSeq = 0; if( !pSeq ) { osl::Guard< osl::Mutex > aGuard( osl::Mutex::getGlobalMutex() ); if( !pSeq ) { static uno::Sequence< sal_Int8 > aSeq( 16 ); rtl_createUuid( (sal_uInt8*)aSeq.getArray(), 0, sal_True ); pSeq = &aSeq; } } return *pSeq; } // static ScSubTotalDescriptorBase* ScSubTotalDescriptorBase::getImplementation( const uno::Reference xObj ) { ScSubTotalDescriptorBase* pRet = NULL; uno::Reference xUT( xObj, uno::UNO_QUERY ); if (xUT.is()) pRet = reinterpret_cast(sal::static_int_cast(xUT->getSomething(getUnoTunnelId()))); return pRet; } //------------------------------------------------------------------------ ScSubTotalDescriptor::ScSubTotalDescriptor() { } ScSubTotalDescriptor::~ScSubTotalDescriptor() { } void ScSubTotalDescriptor::GetData( ScSubTotalParam& rParam ) const { rParam = aStoredParam; // Abfrage fuer Interface } void ScSubTotalDescriptor::PutData( const ScSubTotalParam& rParam ) { aStoredParam = rParam; // vom Interface gesetzt } void ScSubTotalDescriptor::SetParam( const ScSubTotalParam& rNew ) { aStoredParam = rNew; // von aussen gesetzt } //------------------------------------------------------------------------ ScRangeSubTotalDescriptor::ScRangeSubTotalDescriptor(ScDatabaseRangeObj* pPar) : pParent(pPar) { if (pParent) pParent->acquire(); } ScRangeSubTotalDescriptor::~ScRangeSubTotalDescriptor() { if (pParent) pParent->release(); } void ScRangeSubTotalDescriptor::GetData( ScSubTotalParam& rParam ) const { if (pParent) pParent->GetSubTotalParam( rParam ); } void ScRangeSubTotalDescriptor::PutData( const ScSubTotalParam& rParam ) { if (pParent) pParent->SetSubTotalParam( rParam ); } //------------------------------------------------------------------------ ScConsolidationDescriptor::ScConsolidationDescriptor() { } ScConsolidationDescriptor::~ScConsolidationDescriptor() { } void ScConsolidationDescriptor::SetParam( const ScConsolidateParam& rNew ) { aParam = rNew; } // XConsolidationDescriptor sheet::GeneralFunction SAL_CALL ScConsolidationDescriptor::getFunction() throw(uno::RuntimeException) { ScUnoGuard aGuard; return ScDataUnoConversion::SubTotalToGeneral(aParam.eFunction); } void SAL_CALL ScConsolidationDescriptor::setFunction( sheet::GeneralFunction nFunction ) throw(uno::RuntimeException) { ScUnoGuard aGuard; aParam.eFunction = ScDataUnoConversion::GeneralToSubTotal(nFunction); } uno::Sequence SAL_CALL ScConsolidationDescriptor::getSources() throw(uno::RuntimeException) { ScUnoGuard aGuard; USHORT nCount = aParam.nDataAreaCount; if (!aParam.ppDataAreas) nCount = 0; table::CellRangeAddress aRange; uno::Sequence aSeq(nCount); table::CellRangeAddress* pAry = aSeq.getArray(); for (USHORT i=0; inTab; aRange.StartColumn = pArea->nColStart; aRange.StartRow = pArea->nRowStart; aRange.EndColumn = pArea->nColEnd; aRange.EndRow = pArea->nRowEnd; } pAry[i] = aRange; } return aSeq; } void SAL_CALL ScConsolidationDescriptor::setSources( const uno::Sequence& aSources ) throw(uno::RuntimeException) { ScUnoGuard aGuard; USHORT nCount = (USHORT)aSources.getLength(); if (nCount) { const table::CellRangeAddress* pAry = aSources.getConstArray(); ScArea** pNew = new ScArea*[nCount]; USHORT i; for (i=0; i(pAry[i].StartColumn), pAry[i].StartRow, static_cast(pAry[i].EndColumn), pAry[i].EndRow ); aParam.SetAreas( pNew, nCount ); // kopiert alles for (i=0; iGetDocument()->AddUnoObject(*this); } ScFilterDescriptorBase::~ScFilterDescriptorBase() { if (pDocSh) pDocSh->GetDocument()->RemoveUnoObject(*this); } void ScFilterDescriptorBase::Notify( SfxBroadcaster&, const SfxHint& rHint ) { if ( rHint.ISA( SfxSimpleHint ) ) { ULONG nId = ((const SfxSimpleHint&)rHint).GetId(); if ( nId == SFX_HINT_DYING ) { pDocSh = NULL; // invalid } } } // XSheetFilterDescriptor and XSheetFilterDescriptor2 uno::Sequence SAL_CALL ScFilterDescriptorBase::getFilterFields() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); SCSIZE nEntries = aParam.GetEntryCount(); // allozierte Eintraege im Param SCSIZE nCount = 0; // aktive while ( nCount < nEntries && aParam.GetEntry(nCount).bDoQuery ) ++nCount; sheet::TableFilterField aField; uno::Sequence aSeq(static_cast(nCount)); sheet::TableFilterField* pAry = aSeq.getArray(); for (SCSIZE i=0; i SAL_CALL ScFilterDescriptorBase::getFilterFields2() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); SCSIZE nEntries = aParam.GetEntryCount(); // allozierte Eintraege im Param SCSIZE nCount = 0; // aktive while ( nCount < nEntries && aParam.GetEntry(nCount).bDoQuery ) ++nCount; sheet::TableFilterField2 aField; uno::Sequence aSeq(static_cast(nCount)); sheet::TableFilterField2* pAry = aSeq.getArray(); for (SCSIZE i=0; i& aFilterFields ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); SCSIZE nCount = static_cast(aFilterFields.getLength()); DBG_ASSERT( nCount <= MAXQUERY, "setFilterFields: zu viele" ); aParam.Resize( nCount ); const sheet::TableFilterField* pAry = aFilterFields.getConstArray(); SCSIZE i; for (i=0; iGetDocument()->GetFormatTable()->GetInputLineString(rEntry.nVal, 0, *rEntry.pStr); } switch (pAry[i].Operator) // FilterOperator { case sheet::FilterOperator_EQUAL: rEntry.eOp = SC_EQUAL; break; case sheet::FilterOperator_LESS: rEntry.eOp = SC_LESS; break; case sheet::FilterOperator_GREATER: rEntry.eOp = SC_GREATER; break; case sheet::FilterOperator_LESS_EQUAL: rEntry.eOp = SC_LESS_EQUAL; break; case sheet::FilterOperator_GREATER_EQUAL: rEntry.eOp = SC_GREATER_EQUAL; break; case sheet::FilterOperator_NOT_EQUAL: rEntry.eOp = SC_NOT_EQUAL; break; case sheet::FilterOperator_TOP_VALUES: rEntry.eOp = SC_TOPVAL; break; case sheet::FilterOperator_BOTTOM_VALUES: rEntry.eOp = SC_BOTVAL; break; case sheet::FilterOperator_TOP_PERCENT: rEntry.eOp = SC_TOPPERC; break; case sheet::FilterOperator_BOTTOM_PERCENT: rEntry.eOp = SC_BOTPERC; break; case sheet::FilterOperator_EMPTY: { rEntry.eOp = SC_EQUAL; rEntry.nVal = SC_EMPTYFIELDS; rEntry.bQueryByString = FALSE; *rEntry.pStr = EMPTY_STRING; } break; case sheet::FilterOperator_NOT_EMPTY: { rEntry.eOp = SC_EQUAL; rEntry.nVal = SC_NONEMPTYFIELDS; rEntry.bQueryByString = FALSE; *rEntry.pStr = EMPTY_STRING; } break; default: DBG_ERROR("Falscher Query-enum"); rEntry.eOp = SC_EQUAL; } } SCSIZE nParamCount = aParam.GetEntryCount(); // Param wird nicht unter 8 resized for (i=nCount; i& aFilterFields ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); SCSIZE nCount = static_cast(aFilterFields.getLength()); DBG_ASSERT( nCount <= MAXQUERY, "setFilterFields: zu viele" ); aParam.Resize( nCount ); const sheet::TableFilterField2* pAry = aFilterFields.getConstArray(); SCSIZE i; for (i=0; iGetDocument()->GetFormatTable()->GetInputLineString(rEntry.nVal, 0, *rEntry.pStr); } switch (pAry[i].Operator) // FilterOperator { case sheet::FilterOperator2::EQUAL: rEntry.eOp = SC_EQUAL; break; case sheet::FilterOperator2::LESS: rEntry.eOp = SC_LESS; break; case sheet::FilterOperator2::GREATER: rEntry.eOp = SC_GREATER; break; case sheet::FilterOperator2::LESS_EQUAL: rEntry.eOp = SC_LESS_EQUAL; break; case sheet::FilterOperator2::GREATER_EQUAL: rEntry.eOp = SC_GREATER_EQUAL; break; case sheet::FilterOperator2::NOT_EQUAL: rEntry.eOp = SC_NOT_EQUAL; break; case sheet::FilterOperator2::TOP_VALUES: rEntry.eOp = SC_TOPVAL; break; case sheet::FilterOperator2::BOTTOM_VALUES: rEntry.eOp = SC_BOTVAL; break; case sheet::FilterOperator2::TOP_PERCENT: rEntry.eOp = SC_TOPPERC; break; case sheet::FilterOperator2::BOTTOM_PERCENT: rEntry.eOp = SC_BOTPERC; break; case sheet::FilterOperator2::CONTAINS: rEntry.eOp = SC_CONTAINS; break; case sheet::FilterOperator2::DOES_NOT_CONTAIN: rEntry.eOp = SC_DOES_NOT_CONTAIN; break; case sheet::FilterOperator2::BEGINS_WITH: rEntry.eOp = SC_BEGINS_WITH; break; case sheet::FilterOperator2::DOES_NOT_BEGIN_WITH: rEntry.eOp = SC_DOES_NOT_BEGIN_WITH;break; case sheet::FilterOperator2::ENDS_WITH: rEntry.eOp = SC_ENDS_WITH; break; case sheet::FilterOperator2::DOES_NOT_END_WITH: rEntry.eOp = SC_DOES_NOT_END_WITH; break; case sheet::FilterOperator2::EMPTY: { rEntry.eOp = SC_EQUAL; rEntry.nVal = SC_EMPTYFIELDS; rEntry.bQueryByString = FALSE; *rEntry.pStr = EMPTY_STRING; } break; case sheet::FilterOperator2::NOT_EMPTY: { rEntry.eOp = SC_EQUAL; rEntry.nVal = SC_NONEMPTYFIELDS; rEntry.bQueryByString = FALSE; *rEntry.pStr = EMPTY_STRING; } break; default: DBG_ERROR("Falscher Query-enum"); rEntry.eOp = SC_EQUAL; } } SCSIZE nParamCount = aParam.GetEntryCount(); // Param wird nicht unter 8 resized for (i=nCount; i SAL_CALL ScFilterDescriptorBase::getPropertySetInfo() throw(uno::RuntimeException) { ScUnoGuard aGuard; static uno::Reference aRef( new SfxItemPropertySetInfo( aPropSet.getPropertyMap() )); return aRef; } void SAL_CALL ScFilterDescriptorBase::setPropertyValue( const rtl::OUString& aPropertyName, const uno::Any& aValue ) throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); String aString(aPropertyName); if (aString.EqualsAscii( SC_UNONAME_CONTHDR )) aParam.bHasHeader = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_COPYOUT )) aParam.bInplace = !(ScUnoHelpFunctions::GetBoolFromAny( aValue )); else if (aString.EqualsAscii( SC_UNONAME_ISCASE )) aParam.bCaseSens = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_MAXFLD )) { sal_Int32 nVal = 0; if ( (aValue >>= nVal) && nVal > sal::static_int_cast(MAXQUERY) ) { throw lang::IllegalArgumentException(); } } else if (aString.EqualsAscii( SC_UNONAME_ORIENT )) { //! test for correct enum type? table::TableOrientation eOrient = (table::TableOrientation) ScUnoHelpFunctions::GetEnumFromAny( aValue ); aParam.bByRow = ( eOrient != table::TableOrientation_COLUMNS ); } else if (aString.EqualsAscii( SC_UNONAME_OUTPOS )) { table::CellAddress aAddress; if ( aValue >>= aAddress ) { aParam.nDestTab = aAddress.Sheet; aParam.nDestCol = (SCCOL)aAddress.Column; aParam.nDestRow = (SCROW)aAddress.Row; } } else if (aString.EqualsAscii( SC_UNONAME_SAVEOUT )) aParam.bDestPers = ScUnoHelpFunctions::GetBoolFromAny( aValue ); else if (aString.EqualsAscii( SC_UNONAME_SKIPDUP )) aParam.bDuplicate = !(ScUnoHelpFunctions::GetBoolFromAny( aValue )); else if (aString.EqualsAscii( SC_UNONAME_USEREGEX )) aParam.bRegExp = ScUnoHelpFunctions::GetBoolFromAny( aValue ); PutData(aParam); } uno::Any SAL_CALL ScFilterDescriptorBase::getPropertyValue( const rtl::OUString& aPropertyName ) throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; ScQueryParam aParam; GetData(aParam); String aString(aPropertyName); uno::Any aRet; if (aString.EqualsAscii( SC_UNONAME_CONTHDR )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bHasHeader ); else if (aString.EqualsAscii( SC_UNONAME_COPYOUT )) ScUnoHelpFunctions::SetBoolInAny( aRet, !(aParam.bInplace) ); else if (aString.EqualsAscii( SC_UNONAME_ISCASE )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bCaseSens ); else if (aString.EqualsAscii( SC_UNONAME_MAXFLD )) aRet <<= (sal_Int32) MAXQUERY; else if (aString.EqualsAscii( SC_UNONAME_ORIENT )) { table::TableOrientation eOrient = aParam.bByRow ? table::TableOrientation_ROWS : table::TableOrientation_COLUMNS; aRet <<= eOrient; } else if (aString.EqualsAscii( SC_UNONAME_OUTPOS )) { table::CellAddress aOutPos; aOutPos.Sheet = aParam.nDestTab; aOutPos.Column = aParam.nDestCol; aOutPos.Row = aParam.nDestRow; aRet <<= aOutPos; } else if (aString.EqualsAscii( SC_UNONAME_SAVEOUT )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bDestPers ); else if (aString.EqualsAscii( SC_UNONAME_SKIPDUP )) ScUnoHelpFunctions::SetBoolInAny( aRet, !(aParam.bDuplicate) ); else if (aString.EqualsAscii( SC_UNONAME_USEREGEX )) ScUnoHelpFunctions::SetBoolInAny( aRet, aParam.bRegExp ); return aRet; } SC_IMPL_DUMMY_PROPERTY_LISTENER( ScFilterDescriptorBase ) //------------------------------------------------------------------------ ScFilterDescriptor::ScFilterDescriptor(ScDocShell* pDocShell) : ScFilterDescriptorBase(pDocShell) { } ScFilterDescriptor::~ScFilterDescriptor() { } void ScFilterDescriptor::GetData( ScQueryParam& rParam ) const { rParam = aStoredParam; // Abfrage fuer Interface } void ScFilterDescriptor::PutData( const ScQueryParam& rParam ) { aStoredParam = rParam; // vom Interface gesetzt } void ScFilterDescriptor::SetParam( const ScQueryParam& rNew ) { aStoredParam = rNew; // von aussen gesetzt } //------------------------------------------------------------------------ ScRangeFilterDescriptor::ScRangeFilterDescriptor(ScDocShell* pDocShell, ScDatabaseRangeObj* pPar) : ScFilterDescriptorBase(pDocShell), pParent(pPar) { if (pParent) pParent->acquire(); } ScRangeFilterDescriptor::~ScRangeFilterDescriptor() { if (pParent) pParent->release(); } void ScRangeFilterDescriptor::GetData( ScQueryParam& rParam ) const { if (pParent) pParent->GetQueryParam( rParam ); } void ScRangeFilterDescriptor::PutData( const ScQueryParam& rParam ) { if (pParent) pParent->SetQueryParam( rParam ); } //------------------------------------------------------------------------ ScDataPilotFilterDescriptor::ScDataPilotFilterDescriptor(ScDocShell* pDocShell, ScDataPilotDescriptorBase* pPar) : ScFilterDescriptorBase(pDocShell), pParent(pPar) { if (pParent) pParent->acquire(); } ScDataPilotFilterDescriptor::~ScDataPilotFilterDescriptor() { if (pParent) pParent->release(); } void ScDataPilotFilterDescriptor::GetData( ScQueryParam& rParam ) const { if (pParent) { ScDPObject* pDPObj = pParent->GetDPObject(); if (pDPObj && pDPObj->IsSheetData()) rParam = pDPObj->GetSheetDesc()->aQueryParam; } } void ScDataPilotFilterDescriptor::PutData( const ScQueryParam& rParam ) { if (pParent) { ScDPObject* pDPObj = pParent->GetDPObject(); if (pDPObj) { ScSheetSourceDesc aSheetDesc; if (pDPObj->IsSheetData()) aSheetDesc = *pDPObj->GetSheetDesc(); aSheetDesc.aQueryParam = rParam; pDPObj->SetSheetDesc(aSheetDesc); pParent->SetDPObject(pDPObj); } } } //------------------------------------------------------------------------ ScDatabaseRangeObj::ScDatabaseRangeObj(ScDocShell* pDocSh, const String& rNm) : pDocShell( pDocSh ), aName( rNm ), aPropSet( lcl_GetDBRangePropertyMap() ) { pDocShell->GetDocument()->AddUnoObject(*this); } ScDatabaseRangeObj::~ScDatabaseRangeObj() { if (pDocShell) pDocShell->GetDocument()->RemoveUnoObject(*this); } void ScDatabaseRangeObj::Notify( SfxBroadcaster&, const SfxHint& rHint ) { if ( rHint.ISA( SfxSimpleHint ) && ((const SfxSimpleHint&)rHint).GetId() == SFX_HINT_DYING ) pDocShell = NULL; // ungueltig geworden else if ( rHint.ISA (ScDBRangeRefreshedHint) ) { ScDBData* pDBData = GetDBData_Impl(); const ScDBRangeRefreshedHint& rRef = (const ScDBRangeRefreshedHint&)rHint; ScImportParam aParam; pDBData->GetImportParam(aParam); if (aParam == rRef.GetImportParam()) Refreshed_Impl(); } } // Hilfsfuntionen ScDBData* ScDatabaseRangeObj::GetDBData_Impl() const { ScDBData* pRet = NULL; if (pDocShell) { ScDBCollection* pNames = pDocShell->GetDocument()->GetDBCollection(); if (pNames) { USHORT nPos = 0; if (pNames->SearchName( aName, nPos )) pRet = (*pNames)[nPos]; } } return pRet; } // XNamed rtl::OUString SAL_CALL ScDatabaseRangeObj::getName() throw(uno::RuntimeException) { ScUnoGuard aGuard; return aName; } void SAL_CALL ScDatabaseRangeObj::setName( const rtl::OUString& aNewName ) throw(uno::RuntimeException) { ScUnoGuard aGuard; if (pDocShell) { ScDBDocFunc aFunc(*pDocShell); String aNewStr(aNewName); BOOL bOk = aFunc.RenameDBRange( aName, aNewStr, TRUE ); if (bOk) aName = aNewStr; } } // XDatabaseRange table::CellRangeAddress SAL_CALL ScDatabaseRangeObj::getDataArea() throw(uno::RuntimeException) { ScUnoGuard aGuard; table::CellRangeAddress aAddress; ScDBData* pData = GetDBData_Impl(); if (pData) { ScRange aRange; pData->GetArea(aRange); aAddress.Sheet = aRange.aStart.Tab(); aAddress.StartColumn = aRange.aStart.Col(); aAddress.StartRow = aRange.aStart.Row(); aAddress.EndColumn = aRange.aEnd.Col(); aAddress.EndRow = aRange.aEnd.Row(); } return aAddress; } void SAL_CALL ScDatabaseRangeObj::setDataArea( const table::CellRangeAddress& aDataArea ) throw(uno::RuntimeException) { ScUnoGuard aGuard; ScDBData* pData = GetDBData_Impl(); if ( pDocShell && pData ) { ScDBData aNewData( *pData ); //! MoveTo ??? aNewData.SetArea( aDataArea.Sheet, (SCCOL)aDataArea.StartColumn, (SCROW)aDataArea.StartRow, (SCCOL)aDataArea.EndColumn, (SCROW)aDataArea.EndRow ); ScDBDocFunc aFunc(*pDocShell); aFunc.ModifyDBData(aNewData, TRUE); } } uno::Sequence SAL_CALL ScDatabaseRangeObj::getSortDescriptor() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScSortParam aParam; const ScDBData* pData = GetDBData_Impl(); if (pData) { pData->GetSortParam(aParam); // im SortDescriptor sind die Fields innerhalb des Bereichs gezaehlt ScRange aDBRange; pData->GetArea(aDBRange); SCCOLROW nFieldStart = aParam.bByRow ? static_cast(aDBRange.aStart.Col()) : static_cast(aDBRange.aStart.Row()); for (USHORT i=0; i= nFieldStart ) aParam.nField[i] -= nFieldStart; } uno::Sequence aSeq( ScSortDescriptor::GetPropertyCount() ); ScSortDescriptor::FillProperties( aSeq, aParam ); return aSeq; } void ScDatabaseRangeObj::GetQueryParam(ScQueryParam& rQueryParam) const { const ScDBData* pData = GetDBData_Impl(); if (pData) { pData->GetQueryParam(rQueryParam); // im FilterDescriptor sind die Fields innerhalb des Bereichs gezaehlt ScRange aDBRange; pData->GetArea(aDBRange); SCCOLROW nFieldStart = rQueryParam.bByRow ? static_cast(aDBRange.aStart.Col()) : static_cast(aDBRange.aStart.Row()); SCSIZE nCount = rQueryParam.GetEntryCount(); for (SCSIZE i=0; i= nFieldStart) rEntry.nField -= nFieldStart; } } } void ScDatabaseRangeObj::SetQueryParam(const ScQueryParam& rQueryParam) { const ScDBData* pData = GetDBData_Impl(); if (pData) { // im FilterDescriptor sind die Fields innerhalb des Bereichs gezaehlt ScQueryParam aParam(rQueryParam); ScRange aDBRange; pData->GetArea(aDBRange); SCCOLROW nFieldStart = aParam.bByRow ? static_cast(aDBRange.aStart.Col()) : static_cast(aDBRange.aStart.Row()); SCSIZE nCount = aParam.GetEntryCount(); for (SCSIZE i=0; i SAL_CALL ScDatabaseRangeObj::getFilterDescriptor() throw(uno::RuntimeException) { ScUnoGuard aGuard; return new ScRangeFilterDescriptor(pDocShell, this); } void ScDatabaseRangeObj::GetSubTotalParam(ScSubTotalParam& rSubTotalParam) const { const ScDBData* pData = GetDBData_Impl(); if (pData) { pData->GetSubTotalParam(rSubTotalParam); // im FilterDescriptor sind die Fields innerhalb des Bereichs gezaehlt ScRange aDBRange; pData->GetArea(aDBRange); SCCOL nFieldStart = aDBRange.aStart.Col(); for (USHORT i=0; i= nFieldStart ) rSubTotalParam.nField[i] = sal::static_int_cast( rSubTotalParam.nField[i] - nFieldStart ); for (SCCOL j=0; j= nFieldStart ) rSubTotalParam.pSubTotals[i][j] = sal::static_int_cast( rSubTotalParam.pSubTotals[i][j] - nFieldStart ); } } } } void ScDatabaseRangeObj::SetSubTotalParam(const ScSubTotalParam& rSubTotalParam) { const ScDBData* pData = GetDBData_Impl(); if (pData) { // im FilterDescriptor sind die Fields innerhalb des Bereichs gezaehlt ScSubTotalParam aParam(rSubTotalParam); ScRange aDBRange; pData->GetArea(aDBRange); SCCOL nFieldStart = aDBRange.aStart.Col(); for (USHORT i=0; i( aParam.nField[i] + nFieldStart ); for (SCCOL j=0; j( aParam.pSubTotals[i][j] + nFieldStart ); } } ScDBData aNewData( *pData ); aNewData.SetSubTotalParam(aParam); ScDBDocFunc aFunc(*pDocShell); aFunc.ModifyDBData(aNewData, TRUE); } } uno::Reference SAL_CALL ScDatabaseRangeObj::getSubTotalDescriptor() throw(uno::RuntimeException) { ScUnoGuard aGuard; return new ScRangeSubTotalDescriptor(this); } uno::Sequence SAL_CALL ScDatabaseRangeObj::getImportDescriptor() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScImportParam aParam; const ScDBData* pData = GetDBData_Impl(); if (pData) pData->GetImportParam(aParam); uno::Sequence aSeq( ScImportDescriptor::GetPropertyCount() ); ScImportDescriptor::FillProperties( aSeq, aParam ); return aSeq; } // XRefreshable void SAL_CALL ScDatabaseRangeObj::refresh() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScDBData* pData = GetDBData_Impl(); if ( pDocShell && pData ) { ScDBDocFunc aFunc(*pDocShell); // Import zu wiederholen? BOOL bContinue = TRUE; ScImportParam aImportParam; pData->GetImportParam( aImportParam ); if (aImportParam.bImport && !pData->HasImportSelection()) { SCTAB nTab; SCCOL nDummyCol; SCROW nDummyRow; pData->GetArea( nTab, nDummyCol,nDummyRow,nDummyCol,nDummyRow ); uno::Reference< sdbc::XResultSet > xResultSet; bContinue = aFunc.DoImport( nTab, aImportParam, xResultSet, NULL, TRUE, FALSE ); //! Api-Flag als Parameter } // interne Operationen (sort, query, subtotal) nur, wenn kein Fehler if (bContinue) aFunc.RepeatDB( pData->GetName(), TRUE, TRUE ); } } void SAL_CALL ScDatabaseRangeObj::addRefreshListener( const uno::Reference& xListener ) throw(uno::RuntimeException) { ScUnoGuard aGuard; uno::Reference* pObj = new uno::Reference( xListener ); aRefreshListeners.Insert( pObj, aRefreshListeners.Count() ); // hold one additional ref to keep this object alive as long as there are listeners if ( aRefreshListeners.Count() == 1 ) acquire(); } void SAL_CALL ScDatabaseRangeObj::removeRefreshListener( const uno::Reference& xListener ) throw(uno::RuntimeException) { ScUnoGuard aGuard; USHORT nCount = aRefreshListeners.Count(); for ( USHORT n=nCount; n--; ) { uno::Reference* pObj = aRefreshListeners[n]; if ( *pObj == xListener ) { aRefreshListeners.DeleteAndDestroy( n ); if ( aRefreshListeners.Count() == 0 ) release(); // release ref for listeners break; } } } void ScDatabaseRangeObj::Refreshed_Impl() { lang::EventObject aEvent; aEvent.Source = (cppu::OWeakObject*)this; for ( USHORT n=0; nrefreshed( aEvent ); } // XCellRangeSource uno::Reference SAL_CALL ScDatabaseRangeObj::getReferredCells() throw(uno::RuntimeException) { ScUnoGuard aGuard; ScRange aRange; ScDBData* pData = GetDBData_Impl(); if ( pData ) { //! static Funktion um ScCellObj/ScCellRangeObj zu erzeugen am ScCellRangeObj ??? pData->GetArea(aRange); if ( aRange.aStart == aRange.aEnd ) return new ScCellObj( pDocShell, aRange.aStart ); else return new ScCellRangeObj( pDocShell, aRange ); } return NULL; } // XPropertySet uno::Reference SAL_CALL ScDatabaseRangeObj::getPropertySetInfo() throw(uno::RuntimeException) { ScUnoGuard aGuard; static uno::Reference aRef( new SfxItemPropertySetInfo( aPropSet.getPropertyMap() )); return aRef; } void SAL_CALL ScDatabaseRangeObj::setPropertyValue( const rtl::OUString& aPropertyName, const uno::Any& aValue ) throw(beans::UnknownPropertyException, beans::PropertyVetoException, lang::IllegalArgumentException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; ScDBData* pData = GetDBData_Impl(); if ( pDocShell && pData ) { ScDBData aNewData( *pData ); BOOL bDo = TRUE; String aString(aPropertyName); if ( aString.EqualsAscii( SC_UNONAME_KEEPFORM ) ) aNewData.SetKeepFmt( ScUnoHelpFunctions::GetBoolFromAny( aValue ) ); else if ( aString.EqualsAscii( SC_UNONAME_MOVCELLS ) ) aNewData.SetDoSize( ScUnoHelpFunctions::GetBoolFromAny( aValue ) ); else if ( aString.EqualsAscii( SC_UNONAME_STRIPDAT ) ) aNewData.SetStripData( ScUnoHelpFunctions::GetBoolFromAny( aValue ) ); else if (aString.EqualsAscii( SC_UNONAME_AUTOFLT )) { sal_Bool bAutoFilter(ScUnoHelpFunctions::GetBoolFromAny( aValue )); aNewData.SetAutoFilter(bAutoFilter); ScRange aRange; aNewData.GetArea(aRange); ScDocument* pDoc = pDocShell->GetDocument(); if (bAutoFilter && pDoc) pDoc->ApplyFlagsTab( aRange.aStart.Col(), aRange.aStart.Row(), aRange.aEnd.Col(), aRange.aStart.Row(), aRange.aStart.Tab(), SC_MF_AUTO ); else if (!bAutoFilter && pDoc) pDoc->RemoveFlagsTab(aRange.aStart.Col(), aRange.aStart.Row(), aRange.aEnd.Col(), aRange.aStart.Row(), aRange.aStart.Tab(), SC_MF_AUTO ); ScRange aPaintRange(aRange.aStart, aRange.aEnd); aPaintRange.aEnd.SetRow(aPaintRange.aStart.Row()); pDocShell->PostPaint(aPaintRange, PAINT_GRID); } else if (aString.EqualsAscii( SC_UNONAME_USEFLTCRT )) { if (ScUnoHelpFunctions::GetBoolFromAny( aValue )) { ScRange aRange; aNewData.GetAdvancedQuerySource(aRange); aNewData.SetAdvancedQuerySource(&aRange); } else aNewData.SetAdvancedQuerySource(NULL); } else if (aString.EqualsAscii( SC_UNONAME_FLTCRT )) { table::CellRangeAddress aRange; if (aValue >>= aRange) { ScRange aCoreRange; ScUnoConversion::FillScRange(aCoreRange, aRange); aNewData.SetAdvancedQuerySource(&aCoreRange); } } else if (aString.EqualsAscii( SC_UNONAME_FROMSELECT )) { aNewData.SetImportSelection(::cppu::any2bool(aValue)); } else if (aString.EqualsAscii( SC_UNONAME_REFPERIOD )) { sal_Int32 nRefresh = 0; if (aValue >>= nRefresh) { ScDocument* pDoc = pDocShell->GetDocument(); aNewData.SetRefreshDelay(nRefresh); if (pDoc && pDoc->GetDBCollection()) { aNewData.SetRefreshHandler( pDoc->GetDBCollection()->GetRefreshHandler() ); aNewData.SetRefreshControl( pDoc->GetRefreshTimerControlAddress() ); } } } else if (aString.EqualsAscii( SC_UNONAME_CONRES )) { } else bDo = FALSE; if (bDo) { ScDBDocFunc aFunc(*pDocShell); aFunc.ModifyDBData(aNewData, TRUE); } } } uno::Any SAL_CALL ScDatabaseRangeObj::getPropertyValue( const rtl::OUString& aPropertyName ) throw(beans::UnknownPropertyException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; uno::Any aRet; ScDBData* pData = GetDBData_Impl(); if ( pData ) { String aString(aPropertyName); if ( aString.EqualsAscii( SC_UNONAME_KEEPFORM ) ) ScUnoHelpFunctions::SetBoolInAny( aRet, pData->IsKeepFmt() ); else if ( aString.EqualsAscii( SC_UNONAME_MOVCELLS ) ) ScUnoHelpFunctions::SetBoolInAny( aRet, pData->IsDoSize() ); else if ( aString.EqualsAscii( SC_UNONAME_STRIPDAT ) ) ScUnoHelpFunctions::SetBoolInAny( aRet, pData->IsStripData() ); else if ( aString.EqualsAscii( SC_UNONAME_ISUSER ) ) { // all database ranges except "unnamed" are user defined ScUnoHelpFunctions::SetBoolInAny( aRet, ( pData->GetName() != ScGlobal::GetRscString(STR_DB_NONAME) ) ); } else if ( aString.EqualsAscii( SC_UNO_LINKDISPBIT ) ) { // no target bitmaps for individual entries (would be all equal) // ScLinkTargetTypeObj::SetLinkTargetBitmap( aRet, SC_LINKTARGETTYPE_DBAREA ); } else if ( aString.EqualsAscii( SC_UNO_LINKDISPNAME ) ) aRet <<= rtl::OUString( aName ); else if (aString.EqualsAscii( SC_UNONAME_AUTOFLT )) { sal_Bool bAutoFilter(GetDBData_Impl()->HasAutoFilter()); ScUnoHelpFunctions::SetBoolInAny( aRet, bAutoFilter ); } else if (aString.EqualsAscii( SC_UNONAME_USEFLTCRT )) { ScRange aRange; sal_Bool bIsAdvancedSource(GetDBData_Impl()->GetAdvancedQuerySource(aRange)); ScUnoHelpFunctions::SetBoolInAny( aRet, bIsAdvancedSource ); } else if (aString.EqualsAscii( SC_UNONAME_FLTCRT )) { table::CellRangeAddress aRange; ScRange aCoreRange; if (GetDBData_Impl()->GetAdvancedQuerySource(aCoreRange)) ScUnoConversion::FillApiRange(aRange, aCoreRange); aRet <<= aRange; } else if (aString.EqualsAscii( SC_UNONAME_FROMSELECT )) { ScUnoHelpFunctions::SetBoolInAny( aRet, GetDBData_Impl()->HasImportSelection() ); } else if (aString.EqualsAscii( SC_UNONAME_REFPERIOD )) { sal_Int32 nRefresh(GetDBData_Impl()->GetRefreshDelay()); aRet <<= nRefresh; } else if (aString.EqualsAscii( SC_UNONAME_CONRES )) { } else if (aString.EqualsAscii( SC_UNONAME_TOKENINDEX )) { // get index for use in formula tokens (read-only) aRet <<= static_cast(GetDBData_Impl()->GetIndex()); } } return aRet; } SC_IMPL_DUMMY_PROPERTY_LISTENER( ScDatabaseRangeObj ) // XServiceInfo rtl::OUString SAL_CALL ScDatabaseRangeObj::getImplementationName() throw(uno::RuntimeException) { return rtl::OUString::createFromAscii( "ScDatabaseRangeObj" ); } sal_Bool SAL_CALL ScDatabaseRangeObj::supportsService( const rtl::OUString& rServiceName ) throw(uno::RuntimeException) { String aServiceStr( rServiceName ); return aServiceStr.EqualsAscii( SCDATABASERANGEOBJ_SERVICE ) || aServiceStr.EqualsAscii( SCLINKTARGET_SERVICE ); } uno::Sequence SAL_CALL ScDatabaseRangeObj::getSupportedServiceNames() throw(uno::RuntimeException) { uno::Sequence aRet(2); rtl::OUString* pArray = aRet.getArray(); pArray[0] = rtl::OUString::createFromAscii( SCDATABASERANGEOBJ_SERVICE ); pArray[1] = rtl::OUString::createFromAscii( SCLINKTARGET_SERVICE ); return aRet; } //------------------------------------------------------------------------ ScDatabaseRangesObj::ScDatabaseRangesObj(ScDocShell* pDocSh) : pDocShell( pDocSh ) { pDocShell->GetDocument()->AddUnoObject(*this); } ScDatabaseRangesObj::~ScDatabaseRangesObj() { if (pDocShell) pDocShell->GetDocument()->RemoveUnoObject(*this); } void ScDatabaseRangesObj::Notify( SfxBroadcaster&, const SfxHint& rHint ) { // Referenz-Update interessiert hier nicht if ( rHint.ISA( SfxSimpleHint ) && ((const SfxSimpleHint&)rHint).GetId() == SFX_HINT_DYING ) { pDocShell = NULL; // ungueltig geworden } } // XDatabaseRanges ScDatabaseRangeObj* ScDatabaseRangesObj::GetObjectByIndex_Impl(USHORT nIndex) { if (pDocShell) { ScDBCollection* pNames = pDocShell->GetDocument()->GetDBCollection(); if (pNames && nIndex < pNames->GetCount()) return new ScDatabaseRangeObj( pDocShell, (*pNames)[nIndex]->GetName() ); } return NULL; } ScDatabaseRangeObj* ScDatabaseRangesObj::GetObjectByName_Impl(const rtl::OUString& aName) { if ( pDocShell && hasByName(aName) ) { String aString(aName); return new ScDatabaseRangeObj( pDocShell, aString ); } return NULL; } void SAL_CALL ScDatabaseRangesObj::addNewByName( const rtl::OUString& aName, const table::CellRangeAddress& aRange ) throw(uno::RuntimeException) { ScUnoGuard aGuard; BOOL bDone = FALSE; if (pDocShell) { ScDBDocFunc aFunc(*pDocShell); String aString(aName); ScRange aNameRange( (SCCOL)aRange.StartColumn, (SCROW)aRange.StartRow, aRange.Sheet, (SCCOL)aRange.EndColumn, (SCROW)aRange.EndRow, aRange.Sheet ); bDone = aFunc.AddDBRange( aString, aNameRange, TRUE ); } if (!bDone) throw uno::RuntimeException(); // no other exceptions specified } void SAL_CALL ScDatabaseRangesObj::removeByName( const rtl::OUString& aName ) throw(uno::RuntimeException) { ScUnoGuard aGuard; BOOL bDone = FALSE; if (pDocShell) { ScDBDocFunc aFunc(*pDocShell); String aString(aName); bDone = aFunc.DeleteDBRange( aString, TRUE ); } if (!bDone) throw uno::RuntimeException(); // no other exceptions specified } // XEnumerationAccess uno::Reference SAL_CALL ScDatabaseRangesObj::createEnumeration() throw(uno::RuntimeException) { ScUnoGuard aGuard; return new ScIndexEnumeration(this, rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("com.sun.star.sheet.DatabaseRangesEnumeration"))); } // XIndexAccess sal_Int32 SAL_CALL ScDatabaseRangesObj::getCount() throw(uno::RuntimeException) { ScUnoGuard aGuard; //! "unbenannt" weglassen ? if (pDocShell) { ScDBCollection* pNames = pDocShell->GetDocument()->GetDBCollection(); if (pNames) return pNames->GetCount(); } return 0; } uno::Any SAL_CALL ScDatabaseRangesObj::getByIndex( sal_Int32 nIndex ) throw(lang::IndexOutOfBoundsException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; uno::Reference xRange(GetObjectByIndex_Impl((USHORT)nIndex)); if (xRange.is()) return uno::makeAny(xRange); else throw lang::IndexOutOfBoundsException(); // return uno::Any(); } uno::Type SAL_CALL ScDatabaseRangesObj::getElementType() throw(uno::RuntimeException) { ScUnoGuard aGuard; return getCppuType((uno::Reference*)0); } sal_Bool SAL_CALL ScDatabaseRangesObj::hasElements() throw(uno::RuntimeException) { ScUnoGuard aGuard; return ( getCount() != 0 ); } // XNameAccess uno::Any SAL_CALL ScDatabaseRangesObj::getByName( const rtl::OUString& aName ) throw(container::NoSuchElementException, lang::WrappedTargetException, uno::RuntimeException) { ScUnoGuard aGuard; uno::Reference xRange(GetObjectByName_Impl(aName)); if (xRange.is()) return uno::makeAny(xRange); else throw container::NoSuchElementException(); // return uno::Any(); } uno::Sequence SAL_CALL ScDatabaseRangesObj::getElementNames() throw(uno::RuntimeException) { ScUnoGuard aGuard; //! "unbenannt" weglassen ? if (pDocShell) { ScDBCollection* pNames = pDocShell->GetDocument()->GetDBCollection(); if (pNames) { USHORT nCount = pNames->GetCount(); String aName; uno::Sequence aSeq(nCount); rtl::OUString* pAry = aSeq.getArray(); for (USHORT i=0; iGetName(); return aSeq; } } return uno::Sequence(0); } sal_Bool SAL_CALL ScDatabaseRangesObj::hasByName( const rtl::OUString& aName ) throw(uno::RuntimeException) { ScUnoGuard aGuard; //! "unbenannt" weglassen ? if (pDocShell) { ScDBCollection* pNames = pDocShell->GetDocument()->GetDBCollection(); if (pNames) { String aString(aName); USHORT nPos = 0; if (pNames->SearchName( aString, nPos )) return TRUE; } } return FALSE; } //------------------------------------------------------------------------