diff options
Diffstat (limited to 'binfilter/bf_sw/source/core/unocore/sw_unostyle.cxx')
-rw-r--r-- | binfilter/bf_sw/source/core/unocore/sw_unostyle.cxx | 3333 |
1 files changed, 3333 insertions, 0 deletions
diff --git a/binfilter/bf_sw/source/core/unocore/sw_unostyle.cxx b/binfilter/bf_sw/source/core/unocore/sw_unostyle.cxx new file mode 100644 index 000000000000..f2dcbc592b6c --- /dev/null +++ b/binfilter/bf_sw/source/core/unocore/sw_unostyle.cxx @@ -0,0 +1,3333 @@ +/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/************************************************************************* + * + * 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. + * + ************************************************************************/ + + +#ifdef _MSC_VER +#pragma hdrstop +#endif + +#include <hintids.hxx> + +#include <osl/mutex.hxx> +#include <vcl/svapp.hxx> +#include <bf_svtools/smplhint.hxx> +#include <bf_svtools/ctrltool.hxx> +#include <bf_svtools/style.hxx> +#include <bf_so3/svstor.hxx> + +#ifndef _SVX_PAGEITEM_HXX //autogen +#define ITEMID_SETITEM +#include <bf_svx/pageitem.hxx> +#endif +#ifndef _SVX_SIZEITEM_HXX //autogen +#define ITEMID_SIZE SID_ATTR_PAGE_SIZE +#include <bf_svx/sizeitem.hxx> +#endif +#include <bf_svx/ulspitem.hxx> +#include <bf_svx/lrspitem.hxx> +#include <bf_svx/boxitem.hxx> +#include <bf_svx/shaditem.hxx> +#include <bf_svx/brshitem.hxx> +#include <bf_svx/flstitem.hxx> +#include <bf_svx/svxids.hrc> +#include <bf_svx/paperinf.hxx> +#include <pagedesc.hxx> + +#include <horiornt.hxx> + +#include <doc.hxx> +#include <docary.hxx> +#include <charfmt.hxx> +#include <cmdid.h> + +#include <cppuhelper/implbase4.hxx> + +#include <unostyle.hxx> +#include <unomap.hxx> +#include <unosett.hxx> +#include <docsh.hxx> +#include <swstyle.h> +#include <paratr.hxx> +#include <unomid.h> +#include <unoprnms.hxx> +#include <shellio.hxx> +#include <docstyle.hxx> + +#include <errhdl.hxx> + +#include <unoobj.hxx> +#include <fmthdft.hxx> +#include <fmtpdsc.hxx> +#include <tools/urlobj.hxx> +#include <poolfmt.hrc> +#include <poolfmt.hxx> +#include "unoevent.hxx" +#include <fmtruby.hxx> +#include <com/sun/star/style/ParagraphStyleCategory.hpp> +#include <SwStyleNameMapper.hxx> +#include <bf_sfx2/printer.hxx> +#include <com/sun/star/frame/XModel.hpp> +#include <com/sun/star/style/XStyleFamiliesSupplier.hpp> +#include <com/sun/star/beans/PropertyAttribute.hpp> +#include <GetMetricVal.hxx> +#include <fmtfsize.hxx> +#define STYLE_FAMILY_COUNT 5 // we have 5 style families +#define TYPE_BOOL 0 +#define TYPE_SIZE 1 +#define TYPE_BRUSH 2 +#define TYPE_ULSPACE 3 +#define TYPE_SHADOW 4 +#define TYPE_LRSPACE 5 +#define TYPE_BOX 6 +namespace binfilter { + +const unsigned short aStyleByIndex[] = +{ + SFX_STYLE_FAMILY_CHAR, + SFX_STYLE_FAMILY_PARA, + SFX_STYLE_FAMILY_PAGE , + SFX_STYLE_FAMILY_FRAME , + SFX_STYLE_FAMILY_PSEUDO +}; + +using namespace ::com::sun::star; +using namespace ::com::sun::star::lang; +using namespace ::com::sun::star::uno; +using namespace ::com::sun::star::style; +using namespace ::com::sun::star::beans; +using namespace ::com::sun::star::document; +using namespace ::com::sun::star::container; +using ::com::sun::star::frame::XModel; + +using rtl::OUString; +/****************************************************************************** + * + ******************************************************************************/ +//convert FN_... to RES_ in header and footer itemset +sal_uInt16 lcl_ConvertFNToRES(sal_uInt16 nFNId) +{ + sal_uInt16 nRes = USHRT_MAX; + switch(nFNId) + { + case FN_UNO_FOOTER_ON: + case FN_UNO_HEADER_ON: + break; + case FN_UNO_FOOTER_BACKGROUND: + case FN_UNO_HEADER_BACKGROUND: nRes = RES_BACKGROUND; + break; + case FN_UNO_FOOTER_BOX: + case FN_UNO_HEADER_BOX: nRes = RES_BOX; + break; + case FN_UNO_FOOTER_LR_SPACE: + case FN_UNO_HEADER_LR_SPACE: nRes = RES_LR_SPACE; + break; + case FN_UNO_FOOTER_SHADOW: + case FN_UNO_HEADER_SHADOW: nRes = RES_SHADOW; + break; + case FN_UNO_FOOTER_BODY_DISTANCE: + case FN_UNO_HEADER_BODY_DISTANCE: nRes = RES_UL_SPACE; + break; + case FN_UNO_FOOTER_IS_DYNAMIC_DISTANCE: + case FN_UNO_HEADER_IS_DYNAMIC_DISTANCE: nRes = SID_ATTR_PAGE_DYNAMIC; + break; + case FN_UNO_FOOTER_SHARE_CONTENT: + case FN_UNO_HEADER_SHARE_CONTENT: nRes = SID_ATTR_PAGE_SHARED; + break; + case FN_UNO_FOOTER_HEIGHT: + case FN_UNO_HEADER_HEIGHT: nRes = SID_ATTR_PAGE_SIZE; + break; + case FN_UNO_FOOTER_EAT_SPACING: + case FN_UNO_HEADER_EAT_SPACING: nRes = RES_HEADER_FOOTER_EAT_SPACING; + break; + } + return nRes; + +} + +SwGetPoolIdFromName lcl_GetSwEnumFromSfxEnum ( SfxStyleFamily eFamily ) +{ + switch ( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + return GET_POOLID_CHRFMT; + case SFX_STYLE_FAMILY_PARA: + return GET_POOLID_TXTCOLL; + case SFX_STYLE_FAMILY_FRAME: + return GET_POOLID_FRMFMT; + case SFX_STYLE_FAMILY_PAGE: + return GET_POOLID_PAGEDESC; + case SFX_STYLE_FAMILY_PSEUDO: + return GET_POOLID_NUMRULE; + default: + DBG_ASSERT(sal_False, "someone asking for all styles in unostyle.cxx!" ); + return GET_POOLID_CHRFMT; + } +} + +/****************************************************************** + * SwXStyleFamilies + ******************************************************************/ +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +OUString SwXStyleFamilies::getImplementationName(void) throw( RuntimeException ) +{ + return C2U("SwXStyleFamilies"); +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +BOOL SwXStyleFamilies::supportsService(const OUString& rServiceName) throw( RuntimeException ) +{ + return C2U("com.sun.star.style.StyleFamilies") == rServiceName; +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< OUString > SwXStyleFamilies::getSupportedServiceNames(void) throw( RuntimeException ) +{ + Sequence< OUString > aRet(1); + OUString* pArray = aRet.getArray(); + pArray[0] = C2U("com.sun.star.style.StyleFamilies"); + return aRet; +} +/*-- 16.12.98 15:13:26--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyleFamilies::SwXStyleFamilies(SwDocShell& rDocShell) : + SwUnoCollection(rDocShell.GetDoc()), + pxCharStyles(0), + pxParaStyles(0), + pxFrameStyles(0), + pxPageStyles(0), + pxNumberingStyles(0), + pDocShell(&rDocShell) +{ + +} +/*-- 16.12.98 15:13:26--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyleFamilies::~SwXStyleFamilies() +{ + delete pxCharStyles; + delete pxParaStyles; + delete pxFrameStyles; + delete pxPageStyles; + delete pxNumberingStyles; +} +/*-- 21.12.98 12:05:22--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SAL_CALL SwXStyleFamilies::getByName(const OUString& Name) + throw( + container::NoSuchElementException, + lang::WrappedTargetException, + RuntimeException ) +{ + SolarMutexGuard aGuard; +// der Index kommt aus const unsigned short aStyleByIndex[] = + Any aRet; + if(!IsValid()) + throw RuntimeException(); + if(Name.compareToAscii("CharacterStyles") == 0 ) + aRet = getByIndex(0); + else if(Name.compareToAscii("ParagraphStyles") == 0) + aRet = getByIndex(1); + else if(Name.compareToAscii("FrameStyles") == 0 ) + aRet = getByIndex(3); + else if(Name.compareToAscii("PageStyles") == 0 ) + aRet = getByIndex(2); + else if(Name.compareToAscii("NumberingStyles") == 0 ) + aRet = getByIndex(4); + else + throw container::NoSuchElementException(); + return aRet; +} +/*-- 21.12.98 12:05:22--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Sequence< OUString > SwXStyleFamilies::getElementNames(void) throw( RuntimeException ) +{ + Sequence< OUString > aNames(STYLE_FAMILY_COUNT); + OUString* pNames = aNames.getArray(); + pNames[0] = C2U("CharacterStyles"); + pNames[1] = C2U("ParagraphStyles"); + pNames[2] = C2U("FrameStyles"); + pNames[3] = C2U("PageStyles"); + pNames[4] = C2U("NumberingStyles"); + return aNames; +} +/*-- 21.12.98 12:05:22--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyleFamilies::hasByName(const OUString& Name) throw( RuntimeException ) +{ + if( Name.compareToAscii("CharacterStyles") == 0 || + Name.compareToAscii("ParagraphStyles") == 0 || + Name.compareToAscii("FrameStyles") == 0 || + Name.compareToAscii("PageStyles") == 0 || + Name.compareToAscii("NumberingStyles") == 0 ) + return sal_True; + else + return sal_False; +} +/*-- 16.12.98 15:13:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Int32 SwXStyleFamilies::getCount(void) throw( RuntimeException ) +{ + return STYLE_FAMILY_COUNT; +} +/*-- 16.12.98 15:13:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXStyleFamilies::getByIndex(sal_Int32 nIndex) + throw( lang::IndexOutOfBoundsException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + Any aRet; + if(nIndex >= STYLE_FAMILY_COUNT) + throw lang::IndexOutOfBoundsException(); + if(IsValid()) + { + Reference< container::XNameContainer > aRef; + sal_uInt16 nType = aStyleByIndex[nIndex]; + switch( nType ) + { + case SFX_STYLE_FAMILY_CHAR: + { + if(!pxCharStyles) + { + ((SwXStyleFamilies*)this)->pxCharStyles = new Reference< container::XNameContainer > (); + *pxCharStyles = new SwXStyleFamily(pDocShell, nType); + } + aRef = *pxCharStyles; + } + break; + case SFX_STYLE_FAMILY_PARA: + { + if(!pxParaStyles) + { + ((SwXStyleFamilies*)this)->pxParaStyles = new Reference< container::XNameContainer > (); + *pxParaStyles = new SwXStyleFamily(pDocShell, nType); + } + aRef = *pxParaStyles; + } + break; + case SFX_STYLE_FAMILY_PAGE : + { + if(!pxPageStyles) + { + ((SwXStyleFamilies*)this)->pxPageStyles = new Reference< container::XNameContainer > (); + *pxPageStyles = new SwXStyleFamily(pDocShell, nType); + } + aRef = *pxPageStyles; + } + break; + case SFX_STYLE_FAMILY_FRAME : + { + if(!pxFrameStyles) + { + ((SwXStyleFamilies*)this)->pxFrameStyles = new Reference< container::XNameContainer > (); + *pxFrameStyles = new SwXStyleFamily(pDocShell, nType); + } + aRef = *pxFrameStyles; + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + { + if(!pxNumberingStyles) + { + ((SwXStyleFamilies*)this)->pxNumberingStyles = new Reference< container::XNameContainer > (); + *pxNumberingStyles = new SwXStyleFamily(pDocShell, nType); + } + aRef = *pxNumberingStyles; + } + break; + } + aRet.setValue(&aRef, ::getCppuType((const Reference<container::XNameContainer>*)0)); + } + else + throw RuntimeException(); + return aRet; +} +/*-- 16.12.98 15:13:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Type SwXStyleFamilies::getElementType(void) + throw( RuntimeException ) +{ + return ::getCppuType((const Reference<container::XNameContainer>*)0); + +} +/*-- 16.12.98 15:13:28--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyleFamilies::hasElements(void) throw( RuntimeException ) +{ + return sal_True; +} +/*-- 16.12.98 15:13:28--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyleFamilies::loadStylesFromURL(const OUString& rURL, + const Sequence< PropertyValue >& aOptions) + throw( io::IOException, RuntimeException ) +{ + SolarMutexGuard aGuard; + sal_Bool bLoadStyleText = sal_True; + sal_Bool LoadStyleFrame = sal_True; + sal_Bool bLoadStylePage = sal_True; + sal_Bool bLoadStyleOverwrite = sal_True; + sal_Bool bLoadStyleNumbering = sal_True; + sal_Bool bLoadStyleFrame = sal_True; + if(IsValid() && rURL.getLength()) + { + const Any* pVal; + int nCount = aOptions.getLength(); + const PropertyValue* pArray = aOptions.getConstArray(); + for(int i = 0; i < nCount; i++) + if( ( pVal = &pArray[i].Value)->getValueType() == + ::getBooleanCppuType() ) + { + String sName = pArray[i].Name; + sal_Bool bVal = *(sal_Bool*)pVal->getValue(); + if( sName.EqualsAscii(SW_PROP_NAME_STR(UNO_NAME_OVERWRITE_STYLES ))) + bLoadStyleOverwrite = bVal; + else if( sName.EqualsAscii(SW_PROP_NAME_STR(UNO_NAME_LOAD_NUMBERING_STYLES ))) + bLoadStyleNumbering = bVal; + else if( sName.EqualsAscii(SW_PROP_NAME_STR(UNO_NAME_LOAD_PAGE_STYLES ))) + bLoadStylePage = bVal; + else if( sName.EqualsAscii(SW_PROP_NAME_STR(UNO_NAME_LOAD_FRAME_STYLES ))) + bLoadStyleFrame = bVal; + else if( sName.EqualsAscii(SW_PROP_NAME_STR(UNO_NAME_LOAD_TEXT_STYLES ))) + bLoadStyleText = bVal; + } + + SwgReaderOption aOpt; + aOpt.SetFrmFmts( bLoadStyleFrame ); + aOpt.SetTxtFmts( bLoadStyleText ); + aOpt.SetPageDescs( bLoadStylePage ); + aOpt.SetNumRules( bLoadStyleNumbering ); + aOpt.SetMerge( !bLoadStyleOverwrite ); + + ULONG nErr = pDocShell->LoadStylesFromFile( rURL, aOpt, TRUE ); + if( nErr ) + throw io::IOException(); + } + else + throw RuntimeException(); +} +/*-- 16.12.98 15:13:28--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Sequence< PropertyValue > SwXStyleFamilies::getStyleLoaderOptions(void) + throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + Sequence< PropertyValue > aSeq(5); + PropertyValue* pArray = aSeq.getArray(); + Any aVal; + sal_Bool bTemp = sal_True; + aVal.setValue(&bTemp, ::getCppuBooleanType()); + pArray[0] = PropertyValue(C2U(SW_PROP_NAME_STR(UNO_NAME_LOAD_TEXT_STYLES)), -1, aVal, PropertyState_DIRECT_VALUE); + aVal.setValue(&bTemp, ::getCppuBooleanType()); + pArray[1] = PropertyValue(C2U(SW_PROP_NAME_STR(UNO_NAME_LOAD_FRAME_STYLES)), -1, aVal, PropertyState_DIRECT_VALUE); + aVal.setValue(&bTemp, ::getCppuBooleanType()); + pArray[2] = PropertyValue(C2U(SW_PROP_NAME_STR(UNO_NAME_LOAD_PAGE_STYLES)), -1, aVal, PropertyState_DIRECT_VALUE); + aVal.setValue(&bTemp, ::getCppuBooleanType()); + pArray[3] = PropertyValue(C2U(SW_PROP_NAME_STR(UNO_NAME_LOAD_NUMBERING_STYLES)), -1, aVal, PropertyState_DIRECT_VALUE); + aVal.setValue(&bTemp, ::getCppuBooleanType()); + pArray[4] = PropertyValue(C2U(SW_PROP_NAME_STR(UNO_NAME_OVERWRITE_STYLES)), -1, aVal, PropertyState_DIRECT_VALUE); + return aSeq; +} + +/****************************************************************** + * SwXStyleFamily + ******************************************************************/ +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +OUString SwXStyleFamily::getImplementationName(void) throw( RuntimeException ) +{ + return C2U("SwXStyleFamily"); +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +BOOL SwXStyleFamily::supportsService(const OUString& rServiceName) throw( RuntimeException ) +{ + return C2U("com.sun.star.style.StyleFamily") == rServiceName; +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< OUString > SwXStyleFamily::getSupportedServiceNames(void) throw( RuntimeException ) +{ + Sequence< OUString > aRet(1); + OUString* pArray = aRet.getArray(); + pArray[0] = C2U("com.sun.star.style.StyleFamily"); + return aRet; +} +/*-- 16.12.98 16:03:56--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyleFamily::SwXStyleFamily(SwDocShell* pDocSh, sal_uInt16 nFamily) : + pBasePool(pDocSh->GetStyleSheetPool()), + pDocShell(pDocSh), + eFamily((SfxStyleFamily)nFamily) +{ +/* switch( nFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + _pPropMap = aSwMapProvider.GetPropertyMap(PROPERTY_MAP_CHAR_STYLE); + break; + case SFX_STYLE_FAMILY_PARA: + _pPropMap = aSwMapProvider.GetPropertyMap(PROPERTY_MAP_PARA_STYLE); + break; + case SFX_STYLE_FAMILY_PAGE: + _pPropMap = aSwMapProvider.GetPropertyMap(PROPERTY_MAP_PAGE_STYLE); + break; + case SFX_STYLE_FAMILY_FRAME: + _pPropMap = aSwMapProvider.GetPropertyMap(PROPERTY_MAP_FRAME_STYLE); + break; + case SFX_STYLE_FAMILY_PSEUDO: + _pPropMap = aSwMapProvider.GetPropertyMap(PROPERTY_MAP_NUM_STYLE); + break; + }*/ + StartListening(*pBasePool); +} +/*-- 16.12.98 16:03:56--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyleFamily::~SwXStyleFamily() +{ + +} +sal_Int32 lcl_GetCountOrName ( const SwDoc &rDoc, SfxStyleFamily eFamily, String *pString, sal_uInt16 nIndex = USHRT_MAX ) +{ + sal_Int32 nCount = 0; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + { + sal_uInt16 nBaseCount = RES_POOLCHR_HTML_END - RES_POOLCHR_HTML_BEGIN + + RES_POOLCHR_NORMAL_END - RES_POOLCHR_NORMAL_BEGIN; + nIndex -= nBaseCount; + const sal_uInt16 nArrLen = rDoc.GetCharFmts()->Count(); + for( sal_uInt16 i = 0; i < nArrLen; i++ ) + { + SwCharFmt* pFmt = (*rDoc.GetCharFmts())[ i ]; + if( pFmt->IsDefault() && pFmt != rDoc.GetDfltCharFmt() ) + continue; + if ( IsPoolUserFmt ( pFmt->GetPoolFmtId() ) ) + { + if ( nIndex == nCount ) + { + // the default character format needs to be set to "Default!" + if(rDoc.GetDfltCharFmt() == pFmt) + SwStyleNameMapper::FillUIName( + RES_POOLCOLL_STANDARD, *pString ); + else + *pString = pFmt->GetName(); + break; + } + nCount++; + } + } + nCount += nBaseCount; + } + break; + case SFX_STYLE_FAMILY_PARA: + { + sal_uInt16 nBaseCount = RES_POOLCOLL_HTML_END - RES_POOLCOLL_HTML_BEGIN + + RES_POOLCOLL_DOC_END - RES_POOLCOLL_DOC_BEGIN + + RES_POOLCOLL_REGISTER_END - RES_POOLCOLL_REGISTER_BEGIN + + RES_POOLCOLL_EXTRA_END - RES_POOLCOLL_EXTRA_BEGIN + + RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN; + nIndex -= nBaseCount; + const sal_uInt16 nArrLen = rDoc.GetTxtFmtColls()->Count(); + for ( sal_uInt16 i = 0; i < nArrLen; i++ ) + { + SwTxtFmtColl * pColl = (*rDoc.GetTxtFmtColls())[i]; + if ( pColl->IsDefault() ) + continue; + if ( IsPoolUserFmt ( pColl->GetPoolFmtId() ) ) + { + if ( nIndex == nCount ) + { + *pString = pColl->GetName(); + break; + } + nCount++; + } + } + nCount += nBaseCount; + } + break; + case SFX_STYLE_FAMILY_FRAME: + { + sal_uInt16 nBaseCount = RES_POOLFRM_END - RES_POOLFRM_BEGIN; + nIndex -= nBaseCount; + const sal_uInt16 nArrLen = rDoc.GetFrmFmts()->Count(); + for( sal_uInt16 i = 0; i < nArrLen; i++ ) + { + SwFrmFmt* pFmt = (*rDoc.GetFrmFmts())[ i ]; + if(pFmt->IsDefault() || pFmt->IsAuto()) + continue; + if ( IsPoolUserFmt ( pFmt->GetPoolFmtId() ) ) + { + if ( nIndex == nCount ) + { + *pString = pFmt->GetName(); + break; + } + nCount++; + } + } + nCount += nBaseCount; + } + break; + case SFX_STYLE_FAMILY_PAGE: + { + sal_uInt16 nBaseCount = RES_POOLPAGE_END - RES_POOLPAGE_BEGIN; + nIndex -= nBaseCount; + const sal_uInt16 nArrLen = rDoc.GetPageDescCnt(); + for(sal_uInt16 i = 0; i < nArrLen; ++i) + { + const SwPageDesc& rDesc = rDoc.GetPageDesc(i); + + /*if(rDesc.IsDefault() || rDesc.IsAuto()) + continue;*/ + if ( IsPoolUserFmt ( rDesc.GetPoolFmtId() ) ) + { + if ( nIndex == nCount ) + { + *pString = rDesc.GetName(); + break; + } + nCount++; + } + } + nCount += nBaseCount; + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + { + sal_uInt16 nBaseCount = RES_POOLNUMRULE_END - RES_POOLNUMRULE_BEGIN; + nIndex -= nBaseCount; + const SwNumRuleTbl& rNumTbl = rDoc.GetNumRuleTbl(); + for(USHORT i = 0; i < rNumTbl.Count(); ++i) + { + const SwNumRule& rRule = *rNumTbl[ i ]; + if( rRule.IsAutoRule() ) + continue; + if ( IsPoolUserFmt ( rRule.GetPoolFmtId() ) ) + { + if ( nIndex == nCount ) + { + *pString = rRule.GetName(); + break; + } + nCount++; + } + } + nCount += nBaseCount; + } + break; + } + return nCount; +} +/*-- 16.12.98 16:03:57--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Int32 SwXStyleFamily::getCount(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + return lcl_GetCountOrName ( *pDocShell->GetDoc(), eFamily, NULL ); +} +/*-- 16.12.98 16:03:57--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXStyleFamily::getByIndex(sal_Int32 nTempIndex) + throw( lang::IndexOutOfBoundsException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + Any aRet; + if ( nTempIndex >= 0 && nTempIndex < USHRT_MAX ) + { + sal_uInt16 nIndex = static_cast < sal_uInt16 > ( nTempIndex ); + if(pBasePool) + { + String sStyleName; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + { + if ( nIndex < ( RES_POOLCHR_NORMAL_END - RES_POOLCHR_NORMAL_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCHR_NORMAL_BEGIN + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCHR_HTML_END - RES_POOLCHR_HTML_BEGIN + + RES_POOLCHR_NORMAL_END - RES_POOLCHR_NORMAL_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCHR_HTML_BEGIN + - RES_POOLCHR_NORMAL_END + RES_POOLCHR_NORMAL_BEGIN + + nIndex, sStyleName ); + } + break; + case SFX_STYLE_FAMILY_PARA: + { + if ( nIndex < ( RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_TEXT_BEGIN + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_LISTS_BEGIN + - RES_POOLCOLL_TEXT_END + RES_POOLCOLL_TEXT_BEGIN + + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCOLL_EXTRA_END - RES_POOLCOLL_EXTRA_BEGIN + + RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_EXTRA_BEGIN + - RES_POOLCOLL_LISTS_END + RES_POOLCOLL_LISTS_BEGIN + - RES_POOLCOLL_TEXT_END + RES_POOLCOLL_TEXT_BEGIN + + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCOLL_REGISTER_END - RES_POOLCOLL_REGISTER_BEGIN + + RES_POOLCOLL_EXTRA_END - RES_POOLCOLL_EXTRA_BEGIN + + RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_REGISTER_BEGIN + - RES_POOLCOLL_EXTRA_END + RES_POOLCOLL_EXTRA_BEGIN + - RES_POOLCOLL_LISTS_END + RES_POOLCOLL_LISTS_BEGIN + - RES_POOLCOLL_TEXT_END + RES_POOLCOLL_TEXT_BEGIN + + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCOLL_DOC_END - RES_POOLCOLL_DOC_BEGIN + + RES_POOLCOLL_REGISTER_END - RES_POOLCOLL_REGISTER_BEGIN + + RES_POOLCOLL_EXTRA_END - RES_POOLCOLL_EXTRA_BEGIN + + RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_DOC_BEGIN + - RES_POOLCOLL_REGISTER_END + RES_POOLCOLL_REGISTER_BEGIN + - RES_POOLCOLL_EXTRA_END + RES_POOLCOLL_EXTRA_BEGIN + - RES_POOLCOLL_LISTS_END + RES_POOLCOLL_LISTS_BEGIN + - RES_POOLCOLL_TEXT_END + RES_POOLCOLL_TEXT_BEGIN + + nIndex, sStyleName ); + else if ( nIndex < ( RES_POOLCOLL_HTML_END - RES_POOLCOLL_HTML_BEGIN + + RES_POOLCOLL_DOC_END - RES_POOLCOLL_DOC_BEGIN + + RES_POOLCOLL_REGISTER_END - RES_POOLCOLL_REGISTER_BEGIN + + RES_POOLCOLL_EXTRA_END - RES_POOLCOLL_EXTRA_BEGIN + + RES_POOLCOLL_LISTS_END - RES_POOLCOLL_LISTS_BEGIN + + RES_POOLCOLL_TEXT_END - RES_POOLCOLL_TEXT_BEGIN ) ) + SwStyleNameMapper::FillUIName ( RES_POOLCOLL_HTML_BEGIN + - RES_POOLCOLL_DOC_END + RES_POOLCOLL_DOC_BEGIN + - RES_POOLCOLL_REGISTER_END + RES_POOLCOLL_REGISTER_BEGIN + - RES_POOLCOLL_EXTRA_END + RES_POOLCOLL_EXTRA_BEGIN + - RES_POOLCOLL_LISTS_END + RES_POOLCOLL_LISTS_BEGIN + - RES_POOLCOLL_TEXT_END + RES_POOLCOLL_TEXT_BEGIN + + nIndex, sStyleName ); + } + break; + case SFX_STYLE_FAMILY_FRAME: + { + if ( nIndex < ( RES_POOLFRM_END - RES_POOLFRM_BEGIN ) ) + { + SwStyleNameMapper::FillUIName ( RES_POOLFRM_BEGIN + nIndex, sStyleName ); + } + } + break; + case SFX_STYLE_FAMILY_PAGE: + { + if ( nIndex < ( RES_POOLPAGE_END - RES_POOLPAGE_BEGIN ) ) + { + SwStyleNameMapper::FillUIName ( RES_POOLPAGE_BEGIN + nIndex, sStyleName ); + } + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + { + if ( nIndex < ( RES_POOLNUMRULE_END - RES_POOLNUMRULE_BEGIN ) ) + { + SwStyleNameMapper::FillUIName ( RES_POOLNUMRULE_BEGIN + nIndex, sStyleName ); + } + } + break; + } + if ( !sStyleName.Len() ) + lcl_GetCountOrName ( *pDocShell->GetDoc(), eFamily, &sStyleName, nIndex ); + + if ( sStyleName.Len() ) + { + SfxStyleSheetBase* pBase = pBasePool->Find( sStyleName, eFamily ); + if(pBase) + { + Reference< style::XStyle > xStyle = _FindStyle(sStyleName); + if(!xStyle.is()) + { + xStyle = eFamily == SFX_STYLE_FAMILY_PAGE ? + new SwXPageStyle(*pBasePool, pDocShell, eFamily, sStyleName) : + eFamily == SFX_STYLE_FAMILY_FRAME ? + new SwXFrameStyle(*pBasePool, pDocShell->GetDoc(), pBase->GetName()): + new SwXStyle(*pBasePool, eFamily, pDocShell->GetDoc(), sStyleName); + } + aRet.setValue(&xStyle, ::getCppuType((Reference<style::XStyle>*)0)); + } + else + throw container::NoSuchElementException(); + } + else + throw lang::IndexOutOfBoundsException(); + } + else + throw RuntimeException(); + } + else + throw lang::IndexOutOfBoundsException(); + + return aRet; +} +/*-- 16.12.98 16:03:57--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXStyleFamily::getByName(const OUString& rName) + throw( container::NoSuchElementException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + Any aRet; + String sStyleName; + SwStyleNameMapper::FillUIName(rName, sStyleName, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + if(pBase) + { + Reference< style::XStyle > xStyle = _FindStyle(sStyleName); + if(!xStyle.is()) + { + xStyle = eFamily == SFX_STYLE_FAMILY_PAGE ? + new SwXPageStyle(*pBasePool, pDocShell, eFamily, sStyleName) : + eFamily == SFX_STYLE_FAMILY_FRAME ? + new SwXFrameStyle(*pBasePool, pDocShell->GetDoc(), pBase->GetName()): + new SwXStyle(*pBasePool, eFamily, pDocShell->GetDoc(), sStyleName); + } + aRet.setValue(&xStyle, ::getCppuType((Reference<style::XStyle>*)0)); + } + else + throw container::NoSuchElementException(); + } + else + throw RuntimeException(); + return aRet; + +} +/*-- 16.12.98 16:03:57--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Sequence< OUString > SwXStyleFamily::getElementNames(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + Sequence< OUString > aRet; + if(pBasePool) + { + SfxStyleSheetIterator* pIterator = pBasePool->CreateIterator(eFamily, 0xffff); + sal_uInt16 nCount = pIterator->Count(); + aRet.realloc(nCount); + OUString* pArray = aRet.getArray(); + String aString; + for(sal_uInt16 i = 0; i < nCount; i++) + { + SwStyleNameMapper::FillProgName((*pIterator)[i]->GetName(), aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + pArray[i] = OUString ( aString ); + } + delete pIterator; + } + else + throw RuntimeException(); + return aRet; +} +/*-- 16.12.98 16:03:57--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyleFamily::hasByName(const OUString& rName) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + sal_Bool bRet = sal_False; + if(pBasePool) + { + String sStyleName; + SwStyleNameMapper::FillUIName(rName, sStyleName, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + bRet = 0 != pBase; + } + else + throw RuntimeException(); + return bRet; + +} +/*-- 16.12.98 16:03:58--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Type SwXStyleFamily::getElementType(void) throw( RuntimeException ) +{ + return ::getCppuType((const Reference<style::XStyle>*)0); + +} +/*-- 16.12.98 16:03:58--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyleFamily::hasElements(void) throw( RuntimeException ) +{ + if(!pBasePool) + throw RuntimeException(); + return sal_True; +} +/*-- 16.12.98 16:03:58--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyleFamily::insertByName(const OUString& rName, const Any& rElement) + throw( lang::IllegalArgumentException, container::ElementExistException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + if(pBasePool) + { + String sStyleName; + SwStyleNameMapper::FillUIName(rName, sStyleName, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True); + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + SfxStyleSheetBase* pUINameBase = pBasePool->Find( sStyleName ); + if(pBase || pUINameBase) + throw container::ElementExistException(); + else + { + if(rElement.getValueType().getTypeClass() == + TypeClass_INTERFACE) + { + Reference< XInterface > * pxRef = + (Reference< XInterface > *)rElement.getValue(); + + Reference<lang::XUnoTunnel> xStyleTunnel( *pxRef, UNO_QUERY); + + SwXStyle* pNewStyle = 0; + if(xStyleTunnel.is()) + { + pNewStyle = (SwXStyle*)xStyleTunnel->getSomething( + SwXStyle::getUnoTunnelId()); + } + if(!pNewStyle || !pNewStyle->IsDescriptor() || + pNewStyle->GetFamily() != eFamily) + throw lang::IllegalArgumentException(); + if(pNewStyle) + { + sal_uInt16 nMask = 0xffff; + if(eFamily == SFX_STYLE_FAMILY_PARA && !pNewStyle->IsConditional()) + nMask &= ~SWSTYLEBIT_CONDCOLL; + SfxStyleSheetBase& rNewBase = pBasePool->Make(sStyleName, eFamily, nMask); + pNewStyle->SetDoc(pDocShell->GetDoc(), pBasePool); + pNewStyle->SetStyleName(sStyleName); + String sParentStyleName(pNewStyle->GetParentStyleName()); + if(sParentStyleName.Len()) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pParentBase = pBasePool->Find(sParentStyleName); + if(pParentBase && pParentBase->GetFamily() == eFamily && + &pParentBase->GetPool() == pBasePool) + pBasePool->SetParent( eFamily, sStyleName, sParentStyleName ); + + } + //so, jetzt sollten noch die Properties des Descriptors angewandt werden + pNewStyle->ApplyDescriptorProperties(); + } + else + throw lang::IllegalArgumentException(); + } + else + throw lang::IllegalArgumentException(); + } + } + else + throw RuntimeException(); +} +/*-- 16.12.98 16:03:59--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyleFamily::replaceByName(const OUString& rName, const Any& rElement) + throw( lang::IllegalArgumentException, container::NoSuchElementException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily); + SfxStyleSheetBase* pBase = pBasePool->Find(rName); + //Ersetzung geht nur fuer benutzerdefinierte Styles + if(!pBase) + throw container::NoSuchElementException(); + if(!pBase->IsUserDefined()) + throw lang::IllegalArgumentException(); + //if theres an object available to this style then it must be invalidated + Reference< style::XStyle > xStyle = _FindStyle(pBase->GetName()); + if(xStyle.is()) + { + Reference<XUnoTunnel> xTunnel( xStyle, UNO_QUERY); + if(xTunnel.is()) + { + SwXStyle* pStyle = (SwXStyle*)xTunnel->getSomething( + SwXStyle::getUnoTunnelId()); + pStyle->Invalidate(); + } + } + + pBasePool->Erase(pBase); + insertByName(rName, rElement); + } + else + throw RuntimeException(); +} +/*-- 16.12.98 16:03:59--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyleFamily::removeByName(const OUString& rName) throw( container::NoSuchElementException, lang::WrappedTargetException, RuntimeException ) +{ + SolarMutexGuard aGuard; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + String aString; + SwStyleNameMapper::FillUIName(rName, aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + + SfxStyleSheetBase* pBase = pBasePool->Find( aString ); + if(pBase) + pBasePool->Erase(pBase); + else + throw container::NoSuchElementException(); + } + else + throw RuntimeException(); +} +/*-- 16.12.98 16:03:59--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyleFamily::Notify( SfxBroadcaster& rBC, const SfxHint& rHint ) +{ + SfxSimpleHint *pHint = PTR_CAST( SfxSimpleHint, &rHint ); + if( pHint && ( pHint->GetId() & SFX_HINT_DYING ) ) + { + pBasePool = 0; + pDocShell = 0; + EndListening(rBC); + } +} +/*-- 16.12.98 16:03:59--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyle* SwXStyleFamily::_FindStyle(const String& rStyleName)const +{ + sal_uInt16 nLCount = pBasePool->GetListenerCount(); + SfxListener* pListener = 0; + for( sal_uInt16 i = 0; i < nLCount; i++) + { + pListener = pBasePool->GetListener( i ); + if(PTR_CAST(SwXStyle, pListener) && ((SwXStyle*)pListener)->GetFamily() == eFamily && ((SwXStyle*)pListener)->GetStyleName() == rStyleName) + { + return (SwXStyle*)pListener; + } + } + return 0; +} +/****************************************************************** + * + ******************************************************************/ +class SwStyleProperties_Impl +{ + const SfxItemPropertyMap* _pMap; + Any** pAnyArr; + sal_uInt16 nArrLen; + +public: + SwStyleProperties_Impl(const SfxItemPropertyMap* _pMap); + ~SwStyleProperties_Impl(); + + sal_Bool SetProperty(const String& rName, Any aVal); + sal_Bool GetProperty(const String& rName, Any*& rpAny); + sal_Bool ClearProperty( const OUString& rPropertyName ); + void ClearAllProperties( ); + void GetProperty(const OUString &rPropertyName, const Reference < XPropertySet > &rxPropertySet, uno::Any& rAny ); + + + const SfxItemPropertyMap* GetPropertyMap() const {return _pMap;} +}; +//-------------------------------------------------------------------- +//-------------------------------------------------------------------- +SwStyleProperties_Impl::SwStyleProperties_Impl(const SfxItemPropertyMap* pMap) : + _pMap(pMap), + nArrLen(0) +{ + const SfxItemPropertyMap* pTmp = _pMap; + while(pTmp[nArrLen].nWID) + nArrLen++; + pAnyArr = new Any* [nArrLen]; + for ( sal_uInt16 i =0 ; i < nArrLen; i++ ) + pAnyArr[i] = 0; +} +//-------------------------------------------------------------------- +//-------------------------------------------------------------------- +SwStyleProperties_Impl::~SwStyleProperties_Impl() +{ + for ( sal_uInt16 i =0 ; i < nArrLen; i++ ) + delete pAnyArr[i]; + delete[] pAnyArr; +} + +//-------------------------------------------------------------------- +//-------------------------------------------------------------------- +sal_Bool SwStyleProperties_Impl::SetProperty(const String& rName, Any aVal) +{ + sal_uInt16 nPos = 0; + const SfxItemPropertyMap* pTemp = _pMap; + while( pTemp->pName ) + { + if(rName.EqualsAscii(pTemp->pName)) + break; + ++nPos; + ++pTemp; + } + if(nPos < nArrLen) + { + delete pAnyArr[nPos]; + pAnyArr[nPos] = new Any ( aVal ); + } + return nPos < nArrLen; +} + +sal_Bool SwStyleProperties_Impl::ClearProperty( const OUString& rName ) +{ + sal_uInt16 nPos = 0; + const SfxItemPropertyMap* pTemp = _pMap; + while( pTemp->pName ) + { + if( rName.equalsAsciiL ( pTemp->pName, pTemp->nNameLen ) ) + break; + ++nPos; + ++pTemp; + } + if( nPos < nArrLen ) + { + delete pAnyArr[nPos]; + pAnyArr[ nPos ] = 0; + } + return nPos < nArrLen; +} +void SwStyleProperties_Impl::ClearAllProperties( ) +{ + for ( sal_uInt16 i = 0; i < nArrLen; i++ ) + { + delete pAnyArr[i]; + pAnyArr[ i ] = 0; + } +} +//-------------------------------------------------------------------- +//-------------------------------------------------------------------- +sal_Bool SwStyleProperties_Impl::GetProperty(const String& rName, Any*& rpAny ) +{ + sal_uInt16 nPos = 0; + const SfxItemPropertyMap* pTemp = _pMap; + while( pTemp->pName ) + { + if(rName.EqualsAscii(pTemp->pName)) + break; + ++nPos; + ++pTemp; + } + if(nPos < nArrLen) + rpAny = pAnyArr[nPos]; + return nPos < nArrLen; +} + +void SwStyleProperties_Impl::GetProperty( const OUString &rPropertyName, const Reference < XPropertySet > &rxPropertySet, uno::Any & rAny ) +{ + rAny = rxPropertySet->getPropertyValue( rPropertyName ); +} + +/****************************************************************** + * + ******************************************************************/ +/* -----------------------------10.03.00 18:02-------------------------------- + + ---------------------------------------------------------------------------*/ +const Sequence< sal_Int8 > & SwXStyle::getUnoTunnelId() +{ + static Sequence< sal_Int8 > aSeq = ::binfilter::CreateUnoTunnelId(); + return aSeq; +} +/* -----------------------------10.03.00 18:04-------------------------------- + + ---------------------------------------------------------------------------*/ +sal_Int64 SAL_CALL SwXStyle::getSomething( const Sequence< sal_Int8 >& rId ) + throw(RuntimeException) +{ + if( rId.getLength() == 16 + && 0 == rtl_compareMemory( getUnoTunnelId().getConstArray(), + rId.getConstArray(), 16 ) ) + { + return (sal_Int64)this; + } + return 0; +} + +TYPEINIT1(SwXStyle, SfxListener); +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +OUString SwXStyle::getImplementationName(void) throw( RuntimeException ) +{ + return C2U("SwXStyle"); +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +BOOL SwXStyle::supportsService(const OUString& rServiceName) throw( RuntimeException ) +{ + BOOL bRet = C2U("com.sun.star.style.Style") == rServiceName; + if(!bRet && SFX_STYLE_FAMILY_CHAR == eFamily) + bRet = !rServiceName.compareToAscii("com.sun.star.style.CharacterProperties")|| + !rServiceName.compareToAscii("com.sun.star.style.CharacterPropertiesAsian")|| + !rServiceName.compareToAscii("com.sun.star.style.CharacterPropertiesComplex"); + if(!bRet && SFX_STYLE_FAMILY_PARA == eFamily) + bRet = (C2U("com.sun.star.style.ParagraphStyle") == rServiceName)|| + (C2U("com.sun.star.style.ParagraphProperties") == rServiceName) || + (C2U("com.sun.star.style.ParagraphPropertiesAsian") == rServiceName) || + (C2U("com.sun.star.style.ParagraphPropertiesComplex") == rServiceName); + if(!bRet && SFX_STYLE_FAMILY_PAGE == eFamily) + bRet = (C2U("com.sun.star.style.PageProperties") == rServiceName); + + return bRet; +} +/* -----------------------------06.04.00 11:24-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< OUString > SwXStyle::getSupportedServiceNames(void) throw( RuntimeException ) +{ + long nCount = 1; + if(SFX_STYLE_FAMILY_PARA == eFamily) + { + nCount = 5; + if(bIsConditional) + nCount++; + } + else if(SFX_STYLE_FAMILY_CHAR == eFamily) + nCount = 4; + else if(SFX_STYLE_FAMILY_PAGE == eFamily) + nCount = 2; + Sequence< OUString > aRet(nCount); + OUString* pArray = aRet.getArray(); + pArray[0] = C2U("com.sun.star.style.Style"); + switch(eFamily) + { + case SFX_STYLE_FAMILY_CHAR: + pArray[1] = C2U("com.sun.star.style.CharacterProperties"); + pArray[2] = C2U("com.sun.star.style.CharacterPropertiesAsian"); + pArray[3] = C2U("com.sun.star.style.CharacterPropertiesComplex"); + break; + case SFX_STYLE_FAMILY_PAGE: + pArray[1] = C2U("com.sun.star.style.PageProperties"); + break; + case SFX_STYLE_FAMILY_PARA: + pArray[1] = C2U("com.sun.star.style.ParagraphStyle"); + pArray[2] = C2U("com.sun.star.style.ParagraphProperties"); + pArray[3] = C2U("com.sun.star.style.ParagraphPropertiesAsian"); + pArray[4] = C2U("com.sun.star.style.ParagraphPropertiesComplex"); + if(bIsConditional) + pArray[5] = C2U("com.sun.star.style.ConditionalParagraphStyle"); + break; + } + return aRet; +} +/*-- 17.12.98 08:26:49--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyle::SwXStyle( SwDoc *pDoc, SfxStyleFamily eFam, BOOL bConditional) : + m_pDoc( pDoc ), + bIsDescriptor(sal_True), + bIsConditional(bConditional), + eFamily(eFam), + pBasePool(0) +{ + // Register ourselves as a listener to the document (via the page descriptor) + pDoc->GetPageDescFromPool(RES_POOLPAGE_STANDARD)->Add(this); + // get the property set for the default style data + // First get the model + Reference < XModel > xModel = pDoc->GetDocShell()->GetBaseModel(); + // Ask the model for it's family supplier interface + Reference < XStyleFamiliesSupplier > xFamilySupplier ( xModel, UNO_QUERY ); + // Get the style families + Reference < XNameAccess > xFamilies = xFamilySupplier->getStyleFamilies(); + + Any aAny; + sal_uInt16 nMapId; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + { + nMapId = PROPERTY_MAP_CHAR_STYLE; + } + break; + case SFX_STYLE_FAMILY_PARA: + { + nMapId = PROPERTY_MAP_PARA_STYLE; + aAny = xFamilies->getByName ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "ParagraphStyles" ) ) ); + // Get the Frame family (and keep it for later) + aAny >>= mxStyleFamily; + aAny = mxStyleFamily->getByName ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Standard" ) ) ); + aAny >>= mxStyleData; + } + break; + case SFX_STYLE_FAMILY_PAGE: + { + nMapId = PROPERTY_MAP_PAGE_STYLE; + aAny = xFamilies->getByName ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "PageStyles" ) ) ); + // Get the Frame family (and keep it for later) + aAny >>= mxStyleFamily; + aAny = mxStyleFamily->getByName ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Standard" ) ) ); + aAny >>= mxStyleData; + } + break; + case SFX_STYLE_FAMILY_FRAME : + { + nMapId = PROPERTY_MAP_FRAME_STYLE; + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + { + nMapId = PROPERTY_MAP_NUM_STYLE; + } + break; + } + pPropImpl = new SwStyleProperties_Impl(aSwMapProvider.GetPropertyMap(nMapId)); +} + + +SwXStyle::SwXStyle(SfxStyleSheetBasePool& rPool, SfxStyleFamily eFam, + SwDoc* pDoc, const String& rStyleName) : + sStyleName(rStyleName), + pBasePool(&rPool), + eFamily(eFam), + m_pDoc(pDoc), + bIsDescriptor(sal_False), + bIsConditional(sal_False), + pPropImpl(0) +{ + StartListening(rPool); + if(eFam == SFX_STYLE_FAMILY_PARA) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "where is the style?" ); + if(pBase) + { + const sal_uInt16 nId = SwStyleNameMapper::GetPoolIdFromUIName(sStyleName, GET_POOLID_TXTCOLL); + if(nId != USHRT_MAX) + ::binfilter::IsConditionalByPoolId( nId ); + else + bIsConditional = RES_CONDTXTFMTCOLL == ((SwDocStyleSheet*)pBase)->GetCollection()->Which(); + } + } +} +/*-- 17.12.98 08:26:50--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXStyle::~SwXStyle() +{ + if(pBasePool) + EndListening(*pBasePool); + delete pPropImpl; +} +/*-- 17.12.98 08:26:51--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::Modify( SfxPoolItem *pOld, SfxPoolItem *pNew) +{ + ClientModify(this, pOld, pNew); + if(!GetRegisteredIn()) + { + m_pDoc = 0; + mxStyleData.clear(); + mxStyleFamily.clear(); + } +} +OUString SwXStyle::getName(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + String aString; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "where is the style?" ); + if(!pBase) + throw RuntimeException(); + SwStyleNameMapper::FillProgName(pBase->GetName(), aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True); + } + else + aString = sStyleName; + return OUString (aString); +} +/*-- 17.12.98 08:26:51--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::setName(const OUString& rName) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "where is the style?" ); + sal_Bool bExcept = sal_True; + if(pBase && pBase->IsUserDefined()) + { + SwDocStyleSheet aTmp( *(SwDocStyleSheet*)pBase ); + bExcept = !aTmp.SetName(rName); + if(!bExcept) + sStyleName = String(rName); + } + if(bExcept) + throw RuntimeException(); + } + else + sStyleName = String(rName); +} +/*-- 17.12.98 08:26:51--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyle::isUserDefined(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + sal_Bool bRet = sal_False; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + //if it is not found it must be non user defined + if(pBase) + bRet = pBase->IsUserDefined(); + } + else + throw RuntimeException(); + return bRet; +} +/*-- 17.12.98 08:26:51--------------------------------------------------- + + -----------------------------------------------------------------------*/ +sal_Bool SwXStyle::isInUse(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + sal_Bool bRet = sal_False; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_USED); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + if(pBase) + bRet = pBase->IsUsed(); + } + else + throw RuntimeException(); + return bRet; +} +/*-- 17.12.98 08:26:52--------------------------------------------------- + + -----------------------------------------------------------------------*/ +OUString SwXStyle::getParentStyle(void) throw( RuntimeException ) +{ + SolarMutexGuard aGuard; + String aString; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + if(pBase) + aString = pBase->GetParent(); + } + else if(bIsDescriptor) + aString = sParentStyleName; + else + throw RuntimeException(); + SwStyleNameMapper::FillProgName(aString, aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + return OUString ( aString ); +} +/*-- 17.12.98 08:26:52--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::setParentStyle(const OUString& rParentStyle) + throw( container::NoSuchElementException, RuntimeException ) +{ + SolarMutexGuard aGuard; + String sParentStyle; + SwStyleNameMapper::FillUIName(rParentStyle, sParentStyle, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ); + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily); + BOOL bExcept = FALSE; + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + if(pBase) + { + SwDocStyleSheet aBase(*(SwDocStyleSheet*)pBase); + if(aBase.GetParent() != sParentStyle) + { + bExcept = !aBase.SetParent(sParentStyle); + } + } + else + bExcept = TRUE; + if(bExcept) + throw RuntimeException(); + } + else if(bIsDescriptor) + { + sParentStyleName = String(sParentStyle); + try + { + Any aAny = mxStyleFamily->getByName ( sParentStyle ); + aAny >>= mxStyleData; + } + catch ( container::NoSuchElementException& ) + { + } + catch ( WrappedTargetException& ) + { + } + catch ( RuntimeException& ) + { + } + } + else + throw RuntimeException(); +} +/*-- 17.12.98 08:26:52--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Reference< XPropertySetInfo > SwXStyle::getPropertySetInfo(void) + throw( RuntimeException ) +{ + Reference< XPropertySetInfo > xRet; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR: + { + static Reference< XPropertySetInfo > xCharRef; + if(!xCharRef.is()) + { + SfxItemPropertySet aPropSet( + aSwMapProvider.GetPropertyMap(PROPERTY_MAP_CHAR_STYLE)); + xCharRef = aPropSet.getPropertySetInfo(); + } + xRet = xCharRef; + } + break; + case SFX_STYLE_FAMILY_PARA: + { + static Reference< XPropertySetInfo > xParaRef; + if(!xParaRef.is()) + { + SfxItemPropertySet aPropSet( + aSwMapProvider.GetPropertyMap(PROPERTY_MAP_PARA_STYLE)); + xParaRef = aPropSet.getPropertySetInfo(); + } + xRet = xParaRef; + } + break; + case SFX_STYLE_FAMILY_PAGE : + { + static Reference< XPropertySetInfo > xPageRef; + if(!xPageRef.is()) + { + SfxItemPropertySet aPropSet( + aSwMapProvider.GetPropertyMap(PROPERTY_MAP_PAGE_STYLE) ); + xPageRef = aPropSet.getPropertySetInfo(); + } + xRet = xPageRef; + } + break; + case SFX_STYLE_FAMILY_FRAME : + { + static Reference< XPropertySetInfo > xFrameRef; + if(!xFrameRef.is()) + { + SfxItemPropertySet aPropSet( + aSwMapProvider.GetPropertyMap(PROPERTY_MAP_FRAME_STYLE)); + xFrameRef = aPropSet.getPropertySetInfo(); + } + xRet = xFrameRef; + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + { + static Reference< XPropertySetInfo > xNumRef; + if(!xNumRef.is()) + { + SfxItemPropertySet aPropSet( + aSwMapProvider.GetPropertyMap(PROPERTY_MAP_NUM_STYLE)); + xNumRef = aPropSet.getPropertySetInfo(); + } + xRet = xNumRef; + } + break; + } + return xRet; +} +/* -----------------23.04.99 13:28------------------- + * + * --------------------------------------------------*/ +void SwXStyle::ApplyDescriptorProperties() +{ + bIsDescriptor = sal_False; + mxStyleData.clear(); + mxStyleFamily.clear(); + + const SfxItemPropertyMap* pTemp = pPropImpl->GetPropertyMap(); + while(pTemp->nWID) + { + Any* pAny; + String sPropName(C2S(pTemp->pName)); + OUString sUPropName(sPropName); + pPropImpl->GetProperty(sPropName, pAny); + if(pAny) + setPropertyValue(sUPropName, *pAny); + pTemp++; + } +} + +/*-- 18.04.01 13:07:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +struct SwStyleBase_Impl +{ + SwDoc& rDoc; + + const SwPageDesc* pOldPageDesc; + + SwDocStyleSheet* pNewBase; + SfxItemSet* pItemSet; + + const String& rStyleName; + sal_uInt16 nPDescPos; + + SwStyleBase_Impl(SwDoc& rSwDoc, const String& rName) : + rDoc(rSwDoc), + rStyleName(rName), + pNewBase(0), + pItemSet(0), + pOldPageDesc(0), + nPDescPos(0xffff) + {} + ~SwStyleBase_Impl(){delete pNewBase; delete pItemSet; } + + sal_Bool HasItemSet() {return 0 != pNewBase;} + SfxItemSet& GetItemSet() + { + DBG_ASSERT(pNewBase, "no SwDocStyleSheet available"); + if(!pItemSet) + pItemSet = new SfxItemSet(pNewBase->GetItemSet()); + return *pItemSet; + } + + const SwPageDesc& GetOldPageDesc(); +}; +/* -----------------------------25.04.01 12:44-------------------------------- + + ---------------------------------------------------------------------------*/ +const SwPageDesc& SwStyleBase_Impl::GetOldPageDesc() +{ + if(!pOldPageDesc) + { + sal_uInt16 i; + sal_uInt16 nPDescCount = rDoc.GetPageDescCnt(); + for(i = 0; i < nPDescCount; i++) + { + const SwPageDesc& rDesc = rDoc.GetPageDesc( i ); + if(rDesc.GetName() == rStyleName) + { + pOldPageDesc = & rDesc; + nPDescPos = i; + break; + } + } + if(!pOldPageDesc) + { + for(i = RC_POOLPAGEDESC_BEGIN; i <= STR_POOLPAGE_ENDNOTE; ++i) + { + const String aFmtName(SW_RES(i)); + if(aFmtName == rStyleName) + { + pOldPageDesc = rDoc.GetPageDescFromPool( RES_POOLPAGE_BEGIN + i - RC_POOLPAGEDESC_BEGIN ); + break; + } + } + for(i = 0; i < nPDescCount + 1; i++) + { + const SwPageDesc& rDesc = rDoc.GetPageDesc( i ); + if(rDesc.GetName() == rStyleName) + { + nPDescPos = i; + break; + } + } + } + } + return *pOldPageDesc; +} + +/* -----------------------------19.04.01 09:44-------------------------------- + + ---------------------------------------------------------------------------*/ +void lcl_SetStyleProperty(const SfxItemPropertyMap* pMap, + SfxItemPropertySet& rPropSet, + const Any& rValue, + SwStyleBase_Impl& rBase, + SfxStyleSheetBasePool* pBasePool, + SwDoc* pDoc, + SfxStyleFamily eFamily) + throw(PropertyVetoException, IllegalArgumentException, + WrappedTargetException, RuntimeException) + +{ + switch(pMap->nWID) + { + case RES_PAPER_BIN: + { + SfxPrinter *pPrinter = pDoc->GetPrt(); + OUString sTmp; + sal_uInt16 nBin = USHRT_MAX; + if ( !( rValue >>= sTmp ) ) + throw IllegalArgumentException(); + if ( sTmp.equalsAsciiL ( RTL_CONSTASCII_STRINGPARAM ( "[From printer settings]" ) ) ) + nBin = USHRT_MAX-1; + else if ( pPrinter ) + { + for (sal_uInt16 i=0, nEnd = pPrinter->GetPaperBinCount(); i < nEnd; i++ ) + { + if (sTmp == OUString ( pPrinter->GetPaperBinName ( i ) ) ) + { + nBin = i; + break; + } + } + } + if ( nBin == USHRT_MAX ) + throw IllegalArgumentException(); + else + { + SfxItemSet& rStyleSet = rBase.GetItemSet(); + SfxItemSet aSet(*rStyleSet.GetPool(), pMap->nWID, pMap->nWID); + aSet.SetParent(&rStyleSet); + rPropSet.setPropertyValue(*pMap, makeAny ( static_cast < sal_Int8 > ( nBin == USHRT_MAX-1 ? -1 : nBin ) ), aSet); + rStyleSet.Put(aSet); + } + } + break; + case FN_UNO_NUM_RULES: //Sonderbehandlung fuer das SvxNumRuleItem: + { + if(rValue.getValueType() == ::getCppuType((Reference< container::XIndexReplace>*)0) ) + { + Reference< container::XIndexReplace > * pxRulesRef = + (Reference< container::XIndexReplace > *)rValue.getValue(); + + Reference<lang::XUnoTunnel> xNumberTunnel( *pxRulesRef, UNO_QUERY); + + SwXNumberingRules* pSwXRules = 0; + if(xNumberTunnel.is()) + { + pSwXRules = (SwXNumberingRules*) + xNumberTunnel->getSomething( + SwXNumberingRules::getUnoTunnelId()); + } + if(pSwXRules) + { + const String* pCharStyleNames = pSwXRules->GetNewCharStyleNames(); + const String* pBulletFontNames = pSwXRules->GetBulletFontNames(); + + SwNumRule aSetRule(*pSwXRules->GetNumRule()); + const SwCharFmts* pFmts = pDoc->GetCharFmts(); + sal_uInt16 nChCount = pFmts->Count(); + for(sal_uInt16 i = 0; i < MAXLEVEL; i++) + { + + const SwNumFmt* pFmt = aSetRule.GetNumFmt( i ); + if(pFmt) + { + SwNumFmt aFmt(*pFmt); + if( + pCharStyleNames[i] != SwXNumberingRules::GetInvalidStyle() && + ((pCharStyleNames[i].Len() && !pFmt->GetCharFmt()) || + pCharStyleNames[i].Len() && + pFmt->GetCharFmt()->GetName() != pCharStyleNames[i] )) + { + + SwCharFmt* pCharFmt = 0; + if(pCharStyleNames[i].Len()) + { + for(sal_uInt16 j = 0; j< nChCount; j++) + { + SwCharFmt* pTmp = (*pFmts)[j]; + if(pTmp->GetName() == pCharStyleNames[i]) + { + pCharFmt = pTmp; + break; + } + } + if(!pCharFmt) + { + + SfxStyleSheetBase* pBase; + pBase = ((SfxStyleSheetBasePool*)pBasePool)->Find(pCharStyleNames[i], SFX_STYLE_FAMILY_CHAR); + if(!pBase) + pBase = &pBasePool->Make(pCharStyleNames[i], SFX_STYLE_FAMILY_CHAR); + pCharFmt = ((SwDocStyleSheet*)pBase)->GetCharFmt(); + + } + + aFmt.SetCharFmt( pCharFmt ); + } + } + //jetzt nochmal fuer Fonts + if(pBulletFontNames[i] != SwXNumberingRules::GetInvalidStyle() && + ((pBulletFontNames[i].Len() && !pFmt->GetBulletFont()) || + pBulletFontNames[i].Len() && + pFmt->GetBulletFont()->GetName() != pBulletFontNames[i] )) + { + const SvxFontListItem* pFontListItem = + (const SvxFontListItem* )pDoc->GetDocShell() + ->GetItem( SID_ATTR_CHAR_FONTLIST ); + const FontList* pList = pFontListItem->GetFontList(); + FontInfo aInfo = pList->Get( + pBulletFontNames[i],WEIGHT_NORMAL, ITALIC_NONE); + Font aFont(aInfo); + aFmt.SetBulletFont(&aFont); + } + aSetRule.Set( i, &aFmt ); + } + } + rBase.pNewBase->SetNumRule(aSetRule); + } + } + else + throw lang::IllegalArgumentException(); + } + break; + case FN_UNO_FOLLOW_STYLE: + { + OUString sTmp; + rValue >>= sTmp; + String aString; + SwStyleNameMapper::FillUIName(sTmp, aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True ) ; + rBase.pNewBase->SetFollow( aString ); + } + break; + case RES_PAGEDESC : + if( MID_PAGEDESC_PAGEDESCNAME != pMap->nMemberId) + goto put_itemset; + { + // Sonderbehandlung RES_PAGEDESC + if(rValue.getValueType() != ::getCppuType((const OUString*)0)) + throw lang::IllegalArgumentException(); + SfxItemSet& rStyleSet = rBase.GetItemSet(); + + SwFmtPageDesc* pNewDesc = 0; + const SfxPoolItem* pItem; + if(SFX_ITEM_SET == rStyleSet.GetItemState( RES_PAGEDESC, sal_True, &pItem ) ) + { + pNewDesc = new SwFmtPageDesc(*((SwFmtPageDesc*)pItem)); + } + if(!pNewDesc) + pNewDesc = new SwFmtPageDesc(); + OUString uDescName; + rValue >>= uDescName; + String sDescName; + SwStyleNameMapper::FillUIName(uDescName, sDescName, GET_POOLID_PAGEDESC, sal_True ); + if(!pNewDesc->GetPageDesc() || pNewDesc->GetPageDesc()->GetName() != sDescName) + { + sal_uInt16 nCount = pDoc->GetPageDescCnt(); + sal_Bool bPut = sal_False; + if(sDescName.Len()) + { + SwPageDesc* pPageDesc = ::binfilter::GetPageDescByName_Impl(*pDoc, sDescName); + if(pPageDesc) + { + pPageDesc->Add( pNewDesc ); + bPut = sal_True; + } + else + { + throw lang::IllegalArgumentException(); + } + } + if(!bPut) + { + rStyleSet.ClearItem(RES_BREAK); + rStyleSet.Put(SwFmtPageDesc()); + } + else + rStyleSet.Put(*pNewDesc); + } + delete pNewDesc; + } + break; + case FN_UNO_IS_AUTO_UPDATE: + { + BOOL bAuto = *(sal_Bool*)rValue.getValue(); + if(SFX_STYLE_FAMILY_PARA == eFamily) + rBase.pNewBase->GetCollection()->SetAutoUpdateFmt(bAuto); + else if(SFX_STYLE_FAMILY_FRAME == eFamily) + rBase.pNewBase->GetFrmFmt()->SetAutoUpdateFmt(bAuto); + } + break; + case FN_UNO_CATEGORY: + { + if(!rBase.pNewBase->IsUserDefined()) + throw lang::IllegalArgumentException(); + short nSet; + rValue >>= nSet; + + sal_uInt16 nId; + switch( nSet ) + { + case ParagraphStyleCategory::TEXT: + nId = SWSTYLEBIT_TEXT; + break; + case ParagraphStyleCategory::CHAPTER: + nId = SWSTYLEBIT_CHAPTER; + break; + case ParagraphStyleCategory::LIST: + nId = SWSTYLEBIT_LIST; + break; + case ParagraphStyleCategory::INDEX: + nId = SWSTYLEBIT_IDX; + break; + case ParagraphStyleCategory::EXTRA: + nId = SWSTYLEBIT_EXTRA; + break; + case ParagraphStyleCategory::HTML: + nId = SWSTYLEBIT_HTML; + break; + default: throw lang::IllegalArgumentException(); + } + rBase.pNewBase->SetMask( nId|SFXSTYLEBIT_USERDEF ); + } + break; + case SID_SWREGISTER_COLLECTION: + { + OUString sName; + rValue >>= sName; + SwRegisterItem aReg( sName.getLength() != 0); + aReg.SetWhich(SID_SWREGISTER_MODE); + rBase.GetItemSet().Put(aReg); + String aString; + SwStyleNameMapper::FillUIName(sName, aString, GET_POOLID_TXTCOLL, sal_True); + + rBase.GetItemSet().Put(SfxStringItem(SID_SWREGISTER_COLLECTION, aString ) ); + } + break; + case RES_TXTATR_CJK_RUBY: + if(MID_RUBY_CHARSTYLE == pMap->nMemberId ) + { + OUString sTmp; + if(rValue >>= sTmp) + { + SfxItemSet& rStyleSet = rBase.GetItemSet(); + SwFmtRuby* pRuby = 0; + const SfxPoolItem* pItem; + if(SFX_ITEM_SET == rStyleSet.GetItemState( RES_TXTATR_CJK_RUBY, sal_True, &pItem ) ) + pRuby = new SwFmtRuby(*((SwFmtRuby*)pItem)); + if(!pRuby) + pRuby = new SwFmtRuby(aEmptyStr); + String sStyle; + SwStyleNameMapper::FillUIName(sTmp, sStyle, GET_POOLID_CHRFMT, sal_True ); + pRuby->SetCharFmtName( sTmp ); + pRuby->SetCharFmtId( 0 ); + if(sTmp.getLength()) + { + sal_uInt16 nId = SwStyleNameMapper::GetPoolIdFromUIName( sTmp, GET_POOLID_CHRFMT ); + pRuby->SetCharFmtId(nId); + } + rStyleSet.Put(*pRuby); + delete pRuby; + } + else + throw lang::IllegalArgumentException(); + } + goto put_itemset; + break; + case RES_PARATR_DROP: + { + if( MID_DROPCAP_CHAR_STYLE_NAME == pMap->nMemberId) + { + if(rValue.getValueType() == ::getCppuType((const OUString*)0)) + { + SfxItemSet& rStyleSet = rBase.GetItemSet(); + + SwFmtDrop* pDrop = 0; + const SfxPoolItem* pItem; + if(SFX_ITEM_SET == rStyleSet.GetItemState( RES_PARATR_DROP, sal_True, &pItem ) ) + pDrop = new SwFmtDrop(*((SwFmtDrop*)pItem)); + if(!pDrop) + pDrop = new SwFmtDrop(); + OUString uStyle; + rValue >>= uStyle; + String sStyle; + SwStyleNameMapper::FillUIName(uStyle, sStyle, GET_POOLID_CHRFMT, sal_True ); + SwDocStyleSheet* pStyle = + (SwDocStyleSheet*)pDoc->GetDocShell()->GetStyleSheetPool()->Find(sStyle, SFX_STYLE_FAMILY_CHAR); + if(pStyle) + pDrop->SetCharFmt(pStyle->GetCharFmt()); + else + throw lang::IllegalArgumentException(); + rStyleSet.Put(*pDrop); + delete pDrop; + } + else + throw lang::IllegalArgumentException(); + break; + } + } + //no break! + default: +put_itemset: + { + SfxItemSet& rStyleSet = rBase.GetItemSet(); + SfxItemSet aSet(*rStyleSet.GetPool(), pMap->nWID, pMap->nWID); + aSet.SetParent(&rStyleSet); + rPropSet.setPropertyValue(*pMap, rValue, aSet); + rStyleSet.Put(aSet); + } + } +} +/* -----------------------------18.04.01 13:29-------------------------------- + + ---------------------------------------------------------------------------*/ +void SwXStyle::setPropertyValues( + const Sequence< OUString >& rPropertyNames, + const Sequence< Any >& rValues ) + throw(PropertyVetoException, IllegalArgumentException, + WrappedTargetException, RuntimeException) +{ + SolarMutexGuard aGuard; + if ( !m_pDoc ) + throw RuntimeException(); + sal_Int8 nPropSetId = PROPERTY_SET_CHAR_STYLE; + switch(eFamily) + { + case SFX_STYLE_FAMILY_PARA: nPropSetId = PROPERTY_SET_PARA_STYLE ; break; + case SFX_STYLE_FAMILY_FRAME: nPropSetId = PROPERTY_SET_FRAME_STYLE ;break; + case SFX_STYLE_FAMILY_PAGE: nPropSetId = PROPERTY_SET_PAGE_STYLE ;break; + case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_SET_NUM_STYLE ;break; + } + SfxItemPropertySet& aPropSet = aSwMapProvider.GetPropertySet(nPropSetId); + + if(rPropertyNames.getLength() != rValues.getLength()) + throw IllegalArgumentException(); + + const OUString* pNames = rPropertyNames.getConstArray(); + const Any* pValues = rValues.getConstArray(); + const SfxItemPropertyMap* pMap = aPropSet.getPropertyMap(); + + SwStyleBase_Impl aBaseImpl(*m_pDoc, sStyleName); + if(pBasePool) + { + sal_uInt16 nSaveMask = pBasePool->GetSearchMask(); + pBasePool->SetSearchMask(eFamily); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + pBasePool->SetSearchMask(eFamily, nSaveMask ); + DBG_ASSERT(pBase, "where is the style?" ); + if(pBase) + aBaseImpl.pNewBase = new SwDocStyleSheet(*(SwDocStyleSheet*)pBase); + else + throw RuntimeException(); + } + + for(sal_Int16 nProp = 0; nProp < rPropertyNames.getLength(); nProp++) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[nProp]); + + if(!pMap) + throw UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if ( pMap->nFlags & PropertyAttribute::READONLY) + throw PropertyVetoException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Property is read-only: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if(aBaseImpl.pNewBase) + { + lcl_SetStyleProperty(pMap, aPropSet, pValues[nProp], aBaseImpl, + pBasePool, m_pDoc, eFamily); + } + else if(bIsDescriptor) + { + if(!pPropImpl->SetProperty(pNames[nProp], pValues[nProp])) + throw lang::IllegalArgumentException(); + } + else + throw RuntimeException(); + } + if(aBaseImpl.HasItemSet()) + aBaseImpl.pNewBase->SetItemSet(aBaseImpl.GetItemSet()); +} + +Any lcl_GetStyleProperty(const SfxItemPropertyMap* pMap, + SfxItemPropertySet& rPropSet, + SwStyleBase_Impl& rBase, + SfxStyleSheetBase* pBase, + SfxStyleFamily eFamily, + SwDoc *pDoc) throw(RuntimeException) +{ + Any aRet; + if(FN_UNO_IS_PHYSICAL == pMap->nWID) + { + BOOL bPhys = pBase != 0; + if(pBase) + { + bPhys = ((SwDocStyleSheet*)pBase)->IsPhysical(); + // The standard character format is not existing physically + if( bPhys && SFX_STYLE_FAMILY_CHAR == eFamily && + ((SwDocStyleSheet*)pBase)->GetCharFmt() && + ((SwDocStyleSheet*)pBase)->GetCharFmt()->IsDefault() ) + bPhys = FALSE; + } + aRet.setValue(&bPhys, ::getBooleanCppuType()); + } + else if(pBase) + { + if(!rBase.pNewBase) + rBase.pNewBase = new SwDocStyleSheet( *(SwDocStyleSheet*)pBase ); + switch(pMap->nWID) + { + case RES_PAPER_BIN: + { + SfxItemSet& rSet = rBase.GetItemSet(); + aRet = rPropSet.getPropertyValue(*pMap, rSet); + sal_Int8 nBin; + aRet >>= nBin; + if ( nBin == -1 ) + aRet <<= OUString ( RTL_CONSTASCII_USTRINGPARAM ( "[From printer settings]" ) ); + else + { + SfxPrinter *pPrinter = pDoc->GetPrt(); + OUString sTmp; + if (pPrinter ) + sTmp = pPrinter->GetPaperBinName ( nBin ); + aRet <<= sTmp; + } + } + break; + case FN_UNO_NUM_RULES: //Sonderbehandlung fuer das SvxNumRuleItem: + { + const SwNumRule* pRule = rBase.pNewBase->GetNumRule(); + DBG_ASSERT(pRule, "Wo ist die NumRule?"); + Reference< container::XIndexReplace > xRules = new SwXNumberingRules(*pRule); + aRet.setValue(&xRules, ::getCppuType((Reference<container::XIndexReplace>*)0)); + } + break; + case FN_UNO_FOLLOW_STYLE: + { + String aString; + SwStyleNameMapper::FillProgName(rBase.pNewBase->GetFollow(), aString, lcl_GetSwEnumFromSfxEnum ( eFamily ), sal_True); + aRet <<= OUString( aString ); + } + break; + case RES_PAGEDESC : + if( MID_PAGEDESC_PAGEDESCNAME != pMap->nMemberId) + goto query_itemset; + { + // Sonderbehandlung RES_PAGEDESC + const SfxPoolItem* pItem; + if(SFX_ITEM_SET == rBase.GetItemSet().GetItemState( RES_PAGEDESC, sal_True, &pItem ) ) + { + const SwPageDesc* pDesc = ((const SwFmtPageDesc*)pItem)->GetPageDesc(); + if(pDesc) + { + String aString; + SwStyleNameMapper::FillProgName(pDesc->GetName(), aString, GET_POOLID_PAGEDESC, sal_True ); + aRet <<= OUString( aString ); + } + } + } + break; + case FN_UNO_IS_AUTO_UPDATE: + { + BOOL bAuto = FALSE; + if(SFX_STYLE_FAMILY_PARA == eFamily) + bAuto = rBase.pNewBase->GetCollection()->IsAutoUpdateFmt(); + else if(SFX_STYLE_FAMILY_FRAME == eFamily) + bAuto = rBase.pNewBase->GetFrmFmt()->IsAutoUpdateFmt(); + aRet.setValue(&bAuto, ::getBooleanCppuType()); + } + break; + case FN_UNO_DISPLAY_NAME: + { + OUString sName(rBase.pNewBase->GetName()); + aRet <<= sName; + } + break; + case FN_UNO_CATEGORY: + { + sal_uInt16 nPoolId = rBase.pNewBase->GetCollection()->GetPoolFmtId(); + short nRet = -1; + switch ( COLL_GET_RANGE_BITS & nPoolId ) + { + case COLL_TEXT_BITS: + nRet = ParagraphStyleCategory::TEXT; + break; + case COLL_DOC_BITS: + nRet = ParagraphStyleCategory::CHAPTER; + break; + case COLL_LISTS_BITS: + nRet = ParagraphStyleCategory::LIST; + break; + case COLL_REGISTER_BITS: + nRet = ParagraphStyleCategory::INDEX; + break; + case COLL_EXTRA_BITS: + nRet = ParagraphStyleCategory::EXTRA; + break; + case COLL_HTML_BITS: + nRet = ParagraphStyleCategory::HTML; + break; + } + aRet <<= nRet; + } + break; + case SID_SWREGISTER_COLLECTION: + { + const SwPageDesc *pPageDesc = rBase.pNewBase->GetPageDesc(); + const SwTxtFmtColl* pCol = 0; + String aString; + if( pPageDesc ) + pCol = pPageDesc->GetRegisterFmtColl(); + if( pCol ) + SwStyleNameMapper::FillProgName( + pCol->GetName(), aString, GET_POOLID_TXTCOLL, sal_True ); + aRet <<= OUString ( aString ); + } + break; + default: +query_itemset: + { + SfxItemSet& rSet = rBase.GetItemSet(); + aRet = rPropSet.getPropertyValue(*pMap, rSet); + } + } + } + else + throw RuntimeException(); + return aRet; +} +/* -----------------------------19.04.01 09:26-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< Any > SwXStyle::getPropertyValues( + const Sequence< OUString >& rPropertyNames ) throw(RuntimeException) +{ + SolarMutexGuard aGuard; + if ( !m_pDoc ) + throw RuntimeException(); + sal_Int8 nPropSetId = PROPERTY_SET_CHAR_STYLE; + switch(eFamily) + { + case SFX_STYLE_FAMILY_PARA: nPropSetId = PROPERTY_SET_PARA_STYLE ; break; + case SFX_STYLE_FAMILY_FRAME: nPropSetId = PROPERTY_SET_FRAME_STYLE ;break; + case SFX_STYLE_FAMILY_PAGE: nPropSetId = PROPERTY_SET_PAGE_STYLE ;break; + case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_SET_NUM_STYLE ;break; + } + SfxItemPropertySet& aPropSet = aSwMapProvider.GetPropertySet(nPropSetId); + const OUString* pNames = rPropertyNames.getConstArray(); + Sequence< Any > aRet(rPropertyNames.getLength()); + Any* pRet = aRet.getArray(); + const SfxItemPropertyMap* pMap = aPropSet.getPropertyMap(); + SwStyleBase_Impl aBase(*m_pDoc, sStyleName); + SfxStyleSheetBase* pBase = 0; + for(sal_Int32 nProp = 0; nProp < rPropertyNames.getLength(); nProp++) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[nProp]); + if(!pMap) + throw UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if(pBasePool) + { + if(!pBase) + { + sal_uInt16 nSaveMask = pBasePool->GetSearchMask(); + pBasePool->SetSearchMask(eFamily, SFXSTYLEBIT_ALL ); + pBase = pBasePool->Find(sStyleName); + pBasePool->SetSearchMask(eFamily, nSaveMask ); + } + pRet[nProp] = lcl_GetStyleProperty(pMap, aPropSet, aBase, pBase, eFamily, GetDoc() ); + } + else if(bIsDescriptor) + { + Any *pAny = 0; + pPropImpl->GetProperty ( pNames[nProp], pAny ); + if( !pAny ) + { + sal_Bool bExcept = sal_False; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_PSEUDO: + bExcept = sal_True; + break; + case SFX_STYLE_FAMILY_PARA: + case SFX_STYLE_FAMILY_PAGE: + pPropImpl->GetProperty ( pNames[nProp], mxStyleData, pRet[ nProp ] ); + break; + case SFX_STYLE_FAMILY_CHAR: + case SFX_STYLE_FAMILY_FRAME : + { + if (pMap->nWID >= POOLATTR_BEGIN && pMap->nWID < RES_UNKNOWNATR_END ) + { + SwFmt * pFmt; + if ( eFamily == SFX_STYLE_FAMILY_CHAR ) + pFmt = m_pDoc->GetDfltCharFmt(); + else + pFmt = m_pDoc->GetDfltFrmFmt(); + const SwAttrPool * pPool = pFmt->GetAttrSet().GetPool(); + const SfxPoolItem & rItem = pPool->GetDefaultItem ( pMap->nWID ); + rItem.QueryValue ( pRet[nProp], pMap->nMemberId ); + } + else + bExcept = sal_True; + } + break; + } + if (bExcept ) + { + RuntimeException aExcept; + aExcept.Message = OUString ( RTL_CONSTASCII_USTRINGPARAM ( "No default value for: " ) ) + pNames[nProp]; + throw aExcept; + } + } + else + pRet [ nProp ] = *pAny; + } + else + throw RuntimeException(); + } + return aRet; +} +/*-- 18.04.01 13:07:29--------------------------------------------------- + -----------------------------------------------------------------------*/ +void SwXStyle::addPropertiesChangeListener( + const Sequence< OUString >& aPropertyNames, + const Reference< XPropertiesChangeListener >& xListener ) + throw(RuntimeException) +{ +} +/*-- 18.04.01 13:07:30--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::removePropertiesChangeListener( + const Reference< XPropertiesChangeListener >& xListener ) + throw(RuntimeException) +{ +} +/*-- 18.04.01 13:07:30--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::firePropertiesChangeEvent( + const Sequence< OUString >& aPropertyNames, + const Reference< XPropertiesChangeListener >& xListener ) + throw(RuntimeException) +{ +} +/*-- 17.12.98 08:26:53--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::setPropertyValue(const OUString& rPropertyName, const Any& rValue) + throw( UnknownPropertyException, + PropertyVetoException, + IllegalArgumentException, + WrappedTargetException, + RuntimeException) +{ + const Sequence<OUString> aProperties(&rPropertyName, 1); + const Sequence<Any> aValues(&rValue, 1); + setPropertyValues(aProperties, aValues); +} +/*-- 17.12.98 08:26:53--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXStyle::getPropertyValue(const OUString& rPropertyName) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + const Sequence<OUString> aProperties(&rPropertyName, 1); + return getPropertyValues(aProperties).getConstArray()[0]; + +} +/*-- 17.12.98 08:26:53--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::addPropertyChangeListener(const OUString& PropertyName, + const Reference< XPropertyChangeListener > & aListener) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + DBG_WARNING("not implemented"); +} +/*-- 17.12.98 08:26:54--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::removePropertyChangeListener(const OUString& PropertyName, + const Reference< XPropertyChangeListener > & aListener) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + DBG_WARNING("not implemented"); +} +/*-- 17.12.98 08:26:54--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::addVetoableChangeListener(const OUString& PropertyName, + const Reference< XVetoableChangeListener > & aListener) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + DBG_WARNING("not implemented"); +} +/*-- 17.12.98 08:26:54--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::removeVetoableChangeListener(const OUString& PropertyName, + const Reference< XVetoableChangeListener > & aListener) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + DBG_WARNING("not implemented"); +} + +/*-- 08.03.99 10:50:26--------------------------------------------------- + + -----------------------------------------------------------------------*/ +PropertyState SwXStyle::getPropertyState(const OUString& rPropertyName) + throw( UnknownPropertyException, RuntimeException ) +{ + SolarMutexGuard aGuard; + + Sequence< OUString > aNames(1); + OUString* pNames = aNames.getArray(); + pNames[0] = rPropertyName; + Sequence< PropertyState > aStates = getPropertyStates(aNames); + return aStates.getConstArray()[0]; +} +/*-- 08.03.99 10:50:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Sequence< PropertyState > SwXStyle::getPropertyStates( + const Sequence< OUString >& rPropertyNames) + throw( UnknownPropertyException, RuntimeException ) +{ + SolarMutexGuard aGuard; + Sequence< PropertyState > aRet(rPropertyNames.getLength()); + PropertyState* pStates = aRet.getArray(); + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily ); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "where is the style?" ); + + if(pBase) + { + const OUString* pNames = rPropertyNames.getConstArray(); + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + sal_Int8 nPropSetId = PROPERTY_SET_CHAR_STYLE; + switch(eFamily) + { + case SFX_STYLE_FAMILY_PARA: nPropSetId = PROPERTY_SET_PARA_STYLE ; break; + case SFX_STYLE_FAMILY_FRAME: nPropSetId = PROPERTY_SET_FRAME_STYLE ;break; + case SFX_STYLE_FAMILY_PAGE: nPropSetId = PROPERTY_SET_PAGE_STYLE; break; + case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_SET_NUM_STYLE ;break; + } + + SfxItemSet aSet = aStyle.GetItemSet(); + SfxItemPropertySet& rStylePropSet = aSwMapProvider.GetPropertySet(nPropSetId); + for(sal_Int32 i = 0; i < rPropertyNames.getLength(); i++) + { + const String& rPropName = pNames[i]; + const SfxItemPropertyMap* pMap = + SfxItemPropertyMap::GetByName( + rStylePropSet.getPropertyMap(), rPropName); + if(!pMap) + throw UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + rPropName, static_cast < cppu::OWeakObject * > ( this ) ); + if( FN_UNO_NUM_RULES == pMap->nWID || + FN_UNO_FOLLOW_STYLE == pMap->nWID ) + { + pStates[i] = PropertyState_DIRECT_VALUE; + } + else if(SFX_STYLE_FAMILY_PAGE == eFamily && + (rPropName.EqualsAscii("Header", 0, 6) + || rPropName.EqualsAscii("Footer", 0, 6))) + { + sal_uInt16 nResId = lcl_ConvertFNToRES(pMap->nWID); + BOOL bFooter = rPropName.EqualsAscii("Footer", 0, 6); + const SvxSetItem* pSetItem; + if(SFX_ITEM_SET == aSet.GetItemState( + bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, + sal_False, (const SfxPoolItem**)&pSetItem)) + { + const SfxItemSet& rSet = pSetItem->GetItemSet(); + SfxItemState eState = rSet.GetItemState(nResId, sal_False); + if(SFX_ITEM_SET == eState) + pStates[i] = PropertyState_DIRECT_VALUE; + else + pStates[i] = PropertyState_DEFAULT_VALUE; + } + else + pStates[i] = PropertyState_AMBIGUOUS_VALUE; + } + else + { + pStates[i] = rStylePropSet.getPropertyState(*pMap, aSet); + if( SFX_STYLE_FAMILY_PAGE == eFamily && + SID_ATTR_PAGE_SIZE == pMap->nWID && + PropertyState_DIRECT_VALUE == pStates[i] ) + { + const SvxSizeItem& rSize = + static_cast < const SvxSizeItem& >( + aSet.Get(SID_ATTR_PAGE_SIZE) ); + sal_uInt8 nMemberId = pMap->nMemberId & 0x7f; + if( ( LONG_MAX == rSize.GetSize().Width() && + (MID_SIZE_WIDTH == nMemberId || + MID_SIZE_SIZE == nMemberId ) ) || + ( LONG_MAX == rSize.GetSize().Height() && + MID_SIZE_HEIGHT == nMemberId ) ) + { + pStates[i] = PropertyState_DEFAULT_VALUE; + } + } + } + } + } + else + throw RuntimeException(); + } + else + throw RuntimeException(); + return aRet; +} +/*-- 08.03.99 10:50:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXStyle::setPropertyToDefault(const OUString& rPropertyName) + throw( UnknownPropertyException, RuntimeException ) +{ + const Sequence < OUString > aSequence ( &rPropertyName, 1 ); + setPropertiesToDefault ( aSequence ); +} + +void SAL_CALL SwXStyle::setPropertiesToDefault( const Sequence< OUString >& aPropertyNames ) + throw (UnknownPropertyException, RuntimeException) +{ + SolarMutexGuard aGuard; + SwFmt *pTargetFmt = 0; + + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "Where is the style?"); + + if(pBase) + { + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + switch(eFamily) + { + case SFX_STYLE_FAMILY_CHAR: pTargetFmt = aStyle.GetCharFmt(); break; + case SFX_STYLE_FAMILY_PARA: pTargetFmt = aStyle.GetCollection(); break; + case SFX_STYLE_FAMILY_FRAME: pTargetFmt = aStyle.GetFrmFmt(); break; + case SFX_STYLE_FAMILY_PAGE: + { + sal_uInt16 nPgDscPos = USHRT_MAX; + SwPageDesc *pDesc = m_pDoc->FindPageDescByName( aStyle.GetPageDesc()->GetName(), &nPgDscPos ); + if( pDesc ) + pTargetFmt = &pDesc->GetMaster(); + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + break; + } + } + } + sal_Int8 nPropSetId = PROPERTY_SET_CHAR_STYLE; + switch(eFamily) + { + case SFX_STYLE_FAMILY_PARA: nPropSetId = PROPERTY_SET_PARA_STYLE ; break; + case SFX_STYLE_FAMILY_FRAME: nPropSetId = PROPERTY_SET_FRAME_STYLE ;break; + case SFX_STYLE_FAMILY_PAGE: nPropSetId = PROPERTY_SET_PAGE_STYLE ;break; + case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_SET_NUM_STYLE ;break; + } + + const SfxItemPropertyMap* pMap = aSwMapProvider.GetPropertyMap(nPropSetId); + const OUString* pNames = aPropertyNames.getConstArray(); + + if ( pTargetFmt ) + { + for( sal_Int32 nProp = 0, nEnd = aPropertyNames.getLength(); nProp < nEnd; nProp++ ) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[nProp] ); + if( !pMap ) + throw UnknownPropertyException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Property is unknown: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if ( pMap->nWID == FN_UNO_FOLLOW_STYLE || pMap->nWID == FN_UNO_NUM_RULES ) + throw RuntimeException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Cannot reset: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if ( pMap->nFlags & PropertyAttribute::READONLY ) + throw PropertyVetoException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Property is read-only: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + + pTargetFmt->ResetAttr ( pMap->nWID ); + } + } + else if ( bIsDescriptor ) + { + for( sal_Int32 nProp = 0, nEnd = aPropertyNames.getLength(); nProp < nEnd; nProp++ ) + pPropImpl->ClearProperty ( pNames[ nProp ] ); + } +} + +void SAL_CALL SwXStyle::setAllPropertiesToDefault( ) + throw (RuntimeException) +{ + SolarMutexGuard aGuard; + if(pBasePool) + { + pBasePool->SetSearchMask(eFamily); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "where is the style, you fiend!?"); + + if(pBase) + { + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + + SwFmt *pTargetFmt = 0; + SwPageDesc *pTargetDesc = 0; + sal_uInt16 nPgDscPos = USHRT_MAX; + switch( eFamily ) + { + case SFX_STYLE_FAMILY_CHAR : + pTargetFmt = aStyle.GetCharFmt(); + break; + case SFX_STYLE_FAMILY_PARA : + pTargetFmt = aStyle.GetCollection(); + break; + case SFX_STYLE_FAMILY_FRAME: + pTargetFmt = aStyle.GetFrmFmt(); + break; + case SFX_STYLE_FAMILY_PAGE: + { + SwPageDesc *pDesc = m_pDoc->FindPageDescByName( aStyle.GetPageDesc()->GetName(), &nPgDscPos ); + if( pDesc ) + { + pTargetFmt = &pDesc->GetMaster(); + pDesc->SetUseOn ( PD_ALL ); + } + } + break; + case SFX_STYLE_FAMILY_PSEUDO: + break; + } + if( pTargetFmt ) + { + if( USHRT_MAX != nPgDscPos ) + { + SwPageDesc& rPageDesc = m_pDoc->_GetPageDesc(nPgDscPos); + rPageDesc.ResetAllMasterAttr(); + + SvxLRSpaceItem aLR; + sal_Int32 nSize = GetMetricVal ( CM_1) * 2; + aLR.SetLeft ( nSize ); + aLR.SetLeft ( nSize ); + SvxULSpaceItem aUL; + aUL.SetUpper ( static_cast < sal_uInt16 > ( nSize ) ); + aUL.SetLower ( static_cast < sal_uInt16 > ( nSize ) ); + pTargetFmt->SetAttr ( aLR ); + pTargetFmt->SetAttr ( aUL ); + + SwPageDesc* pStdPgDsc = m_pDoc->GetPageDescFromPool( RES_POOLPAGE_STANDARD ); + SwFmtFrmSize aFrmSz( ATT_FIX_SIZE ); + if( RES_POOLPAGE_STANDARD == rPageDesc.GetPoolFmtId() ) + { + if( m_pDoc->GetPrt() ) + { + const Size aPhysSize( SvxPaperInfo::GetPaperSize( + static_cast<Printer*>( m_pDoc->GetPrt() )) ); + aFrmSz.SetSize( aPhysSize ); + } + else + { + aFrmSz.SetWidth( LONG_MAX ); + aFrmSz.SetHeight( LONG_MAX ); + } + + } + else + { + aFrmSz = pStdPgDsc->GetMaster().GetFrmSize(); + } + if( pStdPgDsc->GetLandscape() ) + { + SwTwips nTmp = aFrmSz.GetHeight(); + aFrmSz.SetHeight( aFrmSz.GetWidth() ); + aFrmSz.SetWidth( nTmp ); + } + pTargetFmt->SetAttr( aFrmSz ); + } + else + pTargetFmt->ResetAllAttr(); + + if( USHRT_MAX != nPgDscPos ) + m_pDoc->ChgPageDesc( nPgDscPos, m_pDoc->GetPageDesc(nPgDscPos) ); + } + + } + else + throw RuntimeException(); + } + else if ( bIsDescriptor ) + pPropImpl->ClearAllProperties(); + else + throw RuntimeException(); +} + +Sequence< Any > SAL_CALL SwXStyle::getPropertyDefaults( const Sequence< OUString >& aPropertyNames ) + throw (UnknownPropertyException, WrappedTargetException, RuntimeException) +{ + SolarMutexGuard aGuard; + sal_Int32 nCount = aPropertyNames.getLength(); + Sequence < Any > aRet ( nCount ); + if ( nCount ) + { + if( pBasePool) + { + pBasePool->SetSearchMask(eFamily); + SfxStyleSheetBase* pBase = pBasePool->Find(sStyleName); + DBG_ASSERT(pBase, "Doesn't seem to be a style!"); + + if(pBase) + { + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + sal_Int8 nPropSetId = PROPERTY_SET_CHAR_STYLE; + switch(eFamily) + { + case SFX_STYLE_FAMILY_PARA: nPropSetId = PROPERTY_SET_PARA_STYLE ; break; + case SFX_STYLE_FAMILY_FRAME: nPropSetId = PROPERTY_SET_FRAME_STYLE ;break; + case SFX_STYLE_FAMILY_PAGE: nPropSetId = PROPERTY_SET_PAGE_STYLE ;break; + case SFX_STYLE_FAMILY_PSEUDO: nPropSetId = PROPERTY_SET_NUM_STYLE ;break; + } + + const SfxItemSet &rSet = aStyle.GetItemSet(), *pParentSet = rSet.GetParent(); + const SfxItemPropertyMap* pMap = aSwMapProvider.GetPropertyMap(nPropSetId); + const OUString *pNames = aPropertyNames.getConstArray(); + Any *pRet = aRet.getArray(); + for ( sal_Int32 i = 0 ; i < nCount; i++) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[i]); + + if ( !pMap ) + throw UnknownPropertyException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + pNames[i], static_cast < cppu::OWeakObject * > ( this ) ); + + if( pParentSet ) + pRet[i] = aSwMapProvider.GetPropertySet(nPropSetId).getPropertyValue(pNames[i], *pParentSet); + else if( pMap->nWID != rSet.GetPool()->GetSlotId(pMap->nWID) ) + { + const SfxPoolItem& rItem = rSet.GetPool()->GetDefaultItem(pMap->nWID); + rItem.QueryValue(pRet[i], pMap->nMemberId); + } + } + } + else + throw RuntimeException(); + } + else + throw RuntimeException(); + } + return aRet; +} +/*-- 08.03.99 10:50:27--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXStyle::getPropertyDefault(const OUString& rPropertyName) + throw( UnknownPropertyException, lang::WrappedTargetException, RuntimeException ) +{ + const Sequence < OUString > aSequence ( &rPropertyName, 1 ); + return getPropertyDefaults ( aSequence ).getConstArray()[0]; +} +/* -----------------21.01.99 13:08------------------- + * + * --------------------------------------------------*/ +void SwXStyle::Notify( SfxBroadcaster& rBC, const SfxHint& rHint ) +{ + SfxSimpleHint *pHint = PTR_CAST( SfxSimpleHint, &rHint ); + if( pHint ) + { + if(( pHint->GetId() & SFX_HINT_DYING ) || ( pHint->GetId() & SFX_STYLESHEET_ERASED)) + { + pBasePool = 0; + EndListening(rBC); + } + else if( pHint->GetId() &(SFX_STYLESHEET_CHANGED|SFX_STYLESHEET_ERASED) ) + { + ((SfxStyleSheetPool&)rBC).SetSearchMask(eFamily); + SfxStyleSheetBase* pOwnBase = ((SfxStyleSheetPool&)rBC).Find(sStyleName); + if(!pOwnBase) + { + EndListening(rBC); + Invalidate(); + } + } + } +} +/* -----------------------------15.08.00 11:35-------------------------------- + + ---------------------------------------------------------------------------*/ +void SwXStyle::Invalidate() +{ + sStyleName.Erase(); + pBasePool = 0; + m_pDoc = 0; + mxStyleData.clear(); + mxStyleFamily.clear(); +} + + +/****************************************************************** + * SwXPageStyle + ******************************************************************/ +/*-- 17.12.98 08:43:35--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXPageStyle::SwXPageStyle(SfxStyleSheetBasePool& rPool, + SwDocShell* pDocSh, SfxStyleFamily eFam, + const String& rStyleName)://, const SfxItemPropertyMap* _pMap) : + SwXStyle(rPool, eFam, pDocSh->GetDoc(), rStyleName),//, _pMap), + pDocShell(pDocSh) +{ + +} +/* -----------------23.08.99 15:52------------------- + + --------------------------------------------------*/ +SwXPageStyle::SwXPageStyle(SwDocShell* pDocSh) : + SwXStyle(pDocSh->GetDoc(), SFX_STYLE_FAMILY_PAGE), + pDocShell(pDocSh) +{ +} + +/*-- 17.12.98 08:43:35--------------------------------------------------- + + -----------------------------------------------------------------------*/ +SwXPageStyle::~SwXPageStyle() +{ + +} +/* -----------------------------18.04.01 13:50-------------------------------- + + ---------------------------------------------------------------------------*/ +void SwXPageStyle::setPropertyValues( + const Sequence< OUString >& rPropertyNames, + const Sequence< Any >& rValues ) + throw(PropertyVetoException, IllegalArgumentException, WrappedTargetException, RuntimeException) +{ + SolarMutexGuard aGuard; + if(!GetDoc()) + throw RuntimeException(); + SfxItemPropertySet& aPropSet = aSwMapProvider.GetPropertySet(PROPERTY_SET_PAGE_STYLE); + + if(rPropertyNames.getLength() != rValues.getLength()) + throw IllegalArgumentException(); + + const OUString* pNames = rPropertyNames.getConstArray(); + const Any* pValues = rValues.getConstArray(); + const SfxItemPropertyMap* pMap = aPropSet.getPropertyMap(); + SwStyleBase_Impl aBaseImpl(*GetDoc(), GetStyleName()); + if(GetBasePool()) + { + sal_uInt16 nSaveMask = GetBasePool()->GetSearchMask(); + GetBasePool()->SetSearchMask(GetFamily()); + SfxStyleSheetBase* pBase = GetBasePool()->Find(GetStyleName()); + GetBasePool()->SetSearchMask(GetFamily(), nSaveMask ); + DBG_ASSERT(pBase, "where is the style?" ); + if(pBase) + aBaseImpl.pNewBase = new SwDocStyleSheet(*(SwDocStyleSheet*)pBase); + else + throw RuntimeException(); + } + + for(sal_Int16 nProp = 0; nProp < rPropertyNames.getLength(); nProp++) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[nProp]); + if (!pMap) + throw UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + if ( pMap->nFlags & PropertyAttribute::READONLY) + throw PropertyVetoException ( OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Property is read-only: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + + if(GetBasePool()) + { + switch(pMap->nWID) + { + case FN_UNO_HEADER_ON: + case FN_UNO_HEADER_BACKGROUND: + case FN_UNO_HEADER_BOX: + case FN_UNO_HEADER_LR_SPACE: + case FN_UNO_HEADER_SHADOW: + case FN_UNO_HEADER_BODY_DISTANCE: + case FN_UNO_HEADER_IS_DYNAMIC_DISTANCE: + case FN_UNO_HEADER_SHARE_CONTENT: + case FN_UNO_HEADER_HEIGHT: + case FN_UNO_HEADER_EAT_SPACING: + + case FN_UNO_FOOTER_ON: + case FN_UNO_FOOTER_BACKGROUND: + case FN_UNO_FOOTER_BOX: + case FN_UNO_FOOTER_LR_SPACE: + case FN_UNO_FOOTER_SHADOW: + case FN_UNO_FOOTER_BODY_DISTANCE: + case FN_UNO_FOOTER_IS_DYNAMIC_DISTANCE: + case FN_UNO_FOOTER_SHARE_CONTENT: + case FN_UNO_FOOTER_HEIGHT: + case FN_UNO_FOOTER_EAT_SPACING: + { + sal_Bool bSetItem = sal_False; + sal_Bool bFooter = sal_False; + sal_uInt16 nItemType = TYPE_BOOL; + sal_uInt16 nRes = 0; + switch(pMap->nWID) + { + case FN_UNO_FOOTER_ON: bFooter = sal_True; + //kein break; + case FN_UNO_HEADER_ON: nRes = SID_ATTR_PAGE_ON; + break; + case FN_UNO_FOOTER_BACKGROUND: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BACKGROUND: nRes = RES_BACKGROUND; nItemType = TYPE_BRUSH; + break; + case FN_UNO_FOOTER_BOX: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BOX: nRes = RES_BOX; nItemType = TYPE_BOX; + break; + case FN_UNO_FOOTER_LR_SPACE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_LR_SPACE: nRes = RES_LR_SPACE;nItemType = TYPE_LRSPACE; + break; + case FN_UNO_FOOTER_SHADOW: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_SHADOW: nRes = RES_SHADOW;nItemType = TYPE_SHADOW; + break; + case FN_UNO_FOOTER_BODY_DISTANCE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BODY_DISTANCE: nRes = RES_UL_SPACE;nItemType = TYPE_ULSPACE; + break; + case FN_UNO_FOOTER_IS_DYNAMIC_DISTANCE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_IS_DYNAMIC_DISTANCE: nRes = SID_ATTR_PAGE_DYNAMIC; + break; + case FN_UNO_FOOTER_SHARE_CONTENT: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_SHARE_CONTENT: nRes = SID_ATTR_PAGE_SHARED; + break; + case FN_UNO_FOOTER_HEIGHT: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_HEIGHT: nRes = SID_ATTR_PAGE_SIZE;nItemType = TYPE_SIZE; + break; + case FN_UNO_FOOTER_EAT_SPACING: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_EAT_SPACING: nRes = RES_HEADER_FOOTER_EAT_SPACING;nItemType = TYPE_SIZE; + break; + } + const SvxSetItem* pSetItem; + if(SFX_ITEM_SET == aBaseImpl.GetItemSet().GetItemState( + bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, + sal_False, (const SfxPoolItem**)&pSetItem)) + { + SvxSetItem* pNewSetItem = (SvxSetItem*)pSetItem->Clone(); + SfxItemSet& rSetSet = pNewSetItem->GetItemSet(); + const SfxPoolItem* pItem = 0; + SfxPoolItem* pNewItem = 0; + SfxItemState eState = rSetSet.GetItemState(nRes, sal_True, &pItem); + if(!pItem && nRes != rSetSet.GetPool()->GetSlotId(nRes)) + pItem = &rSetSet.GetPool()->GetDefaultItem(nRes); + if(pItem) + { + pNewItem = pItem->Clone(); + } + else + { + switch(nItemType) + { + case TYPE_BOOL: pNewItem = new SfxBoolItem(nRes); break; + case TYPE_SIZE: pNewItem = new SvxSizeItem(nRes); break; + case TYPE_BRUSH: pNewItem = new SvxBrushItem(nRes); break; + case TYPE_ULSPACE: pNewItem = new SvxULSpaceItem(nRes); break; + case TYPE_SHADOW : pNewItem = new SvxShadowItem(nRes); break; + case TYPE_LRSPACE: pNewItem = new SvxLRSpaceItem(nRes); break; + case TYPE_BOX: pNewItem = new SvxBoxItem(nRes); break; + } + } + bSetItem = pNewItem->PutValue(pValues[nProp], pMap->nMemberId); + rSetSet.Put(*pNewItem); + aBaseImpl.GetItemSet().Put(*pNewSetItem); + delete pNewItem; + delete pNewSetItem; + } + else if(SID_ATTR_PAGE_ON == nRes ) + { + sal_Bool bVal = *(sal_Bool*)pValues[nProp].getValue(); + if(bVal) + { + SfxItemSet aTempSet(*aBaseImpl.GetItemSet().GetPool(), + RES_BACKGROUND, RES_SHADOW, + RES_LR_SPACE, RES_UL_SPACE, + nRes, nRes, + SID_ATTR_PAGE_SIZE, SID_ATTR_PAGE_SIZE, + SID_ATTR_PAGE_DYNAMIC, SID_ATTR_PAGE_DYNAMIC, + SID_ATTR_PAGE_SHARED, SID_ATTR_PAGE_SHARED, + 0 ); + aTempSet.Put(SfxBoolItem(nRes, sal_True)); + aTempSet.Put(SvxSizeItem(SID_ATTR_PAGE_SIZE, Size(MM50, MM50))); + aTempSet.Put(SvxLRSpaceItem(RES_LR_SPACE)); + aTempSet.Put(SvxULSpaceItem(RES_UL_SPACE)); + aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_SHARED, sal_True)); + aTempSet.Put(SfxBoolItem(SID_ATTR_PAGE_DYNAMIC, sal_True)); + + SvxSetItem aNewSetItem( bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, + aTempSet); + aBaseImpl.GetItemSet().Put(aNewSetItem); + } + } + } + break; + case FN_UNO_HEADER : + case FN_UNO_HEADER_LEFT : + case FN_UNO_HEADER_RIGHT : + case FN_UNO_FOOTER : + case FN_UNO_FOOTER_LEFT : + case FN_UNO_FOOTER_RIGHT : + throw lang::IllegalArgumentException(); + break; + case FN_PARAM_FTN_INFO : + { + const SfxPoolItem& rItem = aBaseImpl.GetItemSet().Get(FN_PARAM_FTN_INFO); + SfxPoolItem* pNewFtnItem = rItem.Clone(); + sal_Bool bPut = pNewFtnItem->PutValue(pValues[nProp], pMap->nMemberId); + aBaseImpl.GetItemSet().Put(*pNewFtnItem); + delete pNewFtnItem; + if(!bPut) + throw IllegalArgumentException(); + } + break; + default: + lcl_SetStyleProperty(pMap, aPropSet, pValues[nProp], aBaseImpl, + GetBasePool(), GetDoc(), GetFamily()); + } + } + else if(IsDescriptor()) + { + if(!GetPropImpl()->SetProperty(pNames[nProp], pValues[nProp])) + throw lang::IllegalArgumentException(); + } + else + throw RuntimeException(); + } + if(aBaseImpl.HasItemSet()) + aBaseImpl.pNewBase->SetItemSet(aBaseImpl.GetItemSet()); +} +/* -----------------------------18.04.01 13:50-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< Any > SwXPageStyle::getPropertyValues( + const Sequence< OUString >& rPropertyNames ) + throw(RuntimeException) +{ + SolarMutexGuard aGuard; + if(!GetDoc()) + throw RuntimeException(); + + sal_Int32 nLength = rPropertyNames.getLength(); + SfxItemPropertySet& aPropSet = aSwMapProvider.GetPropertySet(PROPERTY_SET_PAGE_STYLE); + const OUString* pNames = rPropertyNames.getConstArray(); + Sequence< Any > aRet ( nLength ); + + Any* pRet = aRet.getArray(); + const SfxItemPropertyMap* pMap = aPropSet.getPropertyMap(); + SwStyleBase_Impl aBase(*GetDoc(), GetStyleName()); + SfxStyleSheetBase* pBase = 0; + for(sal_Int32 nProp = 0; nProp < nLength; nProp++) + { + pMap = SfxItemPropertyMap::GetByName( pMap, pNames[nProp]); + if (!pMap) + throw UnknownPropertyException(OUString ( RTL_CONSTASCII_USTRINGPARAM ( "Unknown property: " ) ) + pNames[nProp], static_cast < cppu::OWeakObject * > ( this ) ); + + if(GetBasePool()) + { + if(!pBase) + { + sal_uInt16 nSaveMask = GetBasePool()->GetSearchMask(); + GetBasePool()->SetSearchMask(GetFamily(), SFXSTYLEBIT_ALL ); + pBase = GetBasePool()->Find(GetStyleName()); + GetBasePool()->SetSearchMask(GetFamily(), nSaveMask ); + } + sal_uInt16 nRes; + sal_Bool bHeader = sal_False, bAll = sal_False, bLeft = sal_False, bRight = sal_False; + switch(pMap->nWID) + { + case FN_UNO_HEADER_ON: + case FN_UNO_HEADER_BACKGROUND: + case FN_UNO_HEADER_BOX: + case FN_UNO_HEADER_LR_SPACE: + case FN_UNO_HEADER_SHADOW: + case FN_UNO_HEADER_BODY_DISTANCE: + case FN_UNO_HEADER_IS_DYNAMIC_DISTANCE: + case FN_UNO_HEADER_SHARE_CONTENT: + case FN_UNO_HEADER_HEIGHT: + case FN_UNO_HEADER_EAT_SPACING: + + case FN_UNO_FOOTER_ON: + case FN_UNO_FOOTER_BACKGROUND: + case FN_UNO_FOOTER_BOX: + case FN_UNO_FOOTER_LR_SPACE: + case FN_UNO_FOOTER_SHADOW: + case FN_UNO_FOOTER_BODY_DISTANCE: + case FN_UNO_FOOTER_IS_DYNAMIC_DISTANCE: + case FN_UNO_FOOTER_SHARE_CONTENT: + case FN_UNO_FOOTER_HEIGHT: + case FN_UNO_FOOTER_EAT_SPACING: + { + SfxStyleSheetBasePool* pBasePool = ((SwXPageStyle*)this)->GetBasePool(); + pBasePool->SetSearchMask(GetFamily()); + SfxStyleSheetBase* pBase = pBasePool->Find(GetStyleName()); + if(pBase) + { + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + const SfxItemSet& rSet = aStyle.GetItemSet(); + sal_Bool bFooter = sal_False; + sal_uInt16 nRes = 0; + switch(pMap->nWID) + { + case FN_UNO_FOOTER_ON: + bFooter = sal_True; + // kein break! + case FN_UNO_HEADER_ON: + { + //falls das SetItem nicht da ist, dann ist der Wert sal_False + BOOL bRet = sal_False; + pRet[nProp].setValue(&bRet, ::getCppuBooleanType()); + nRes = SID_ATTR_PAGE_ON; + } + break; + case FN_UNO_FOOTER_BACKGROUND: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BACKGROUND: nRes = RES_BACKGROUND; + break; + case FN_UNO_FOOTER_BOX: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BOX: nRes = RES_BOX; + break; + case FN_UNO_FOOTER_LR_SPACE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_LR_SPACE: nRes = RES_LR_SPACE; + break; + case FN_UNO_FOOTER_SHADOW: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_SHADOW: nRes = RES_SHADOW; + break; + case FN_UNO_FOOTER_BODY_DISTANCE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_BODY_DISTANCE: nRes = RES_UL_SPACE; + break; + case FN_UNO_FOOTER_IS_DYNAMIC_DISTANCE: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_IS_DYNAMIC_DISTANCE: nRes = SID_ATTR_PAGE_DYNAMIC; + break; + case FN_UNO_FOOTER_SHARE_CONTENT: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_SHARE_CONTENT: nRes = SID_ATTR_PAGE_SHARED; + break; + case FN_UNO_FOOTER_HEIGHT: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_HEIGHT: nRes = SID_ATTR_PAGE_SIZE; + break; + case FN_UNO_FOOTER_EAT_SPACING: bFooter = sal_True; + // kein break; + case FN_UNO_HEADER_EAT_SPACING: nRes = RES_HEADER_FOOTER_EAT_SPACING; + break; + } + const SvxSetItem* pSetItem; + if(SFX_ITEM_SET == rSet.GetItemState( + bFooter ? SID_ATTR_PAGE_FOOTERSET : SID_ATTR_PAGE_HEADERSET, + sal_False, (const SfxPoolItem**)&pSetItem)) + { + const SfxItemSet& rSet = pSetItem->GetItemSet(); + const SfxPoolItem* pItem = 0; + SfxItemState eState = rSet.GetItemState(nRes, sal_True, &pItem); + if(!pItem && nRes != rSet.GetPool()->GetSlotId(nRes)) + pItem = &rSet.GetPool()->GetDefaultItem(nRes); + if(pItem) + pItem->QueryValue(pRet[nProp], pMap->nMemberId); + } + } + } + break; + case FN_UNO_HEADER : + bAll = sal_True; goto Header; + case FN_UNO_HEADER_LEFT : + bLeft = sal_True; goto Header; + case FN_UNO_HEADER_RIGHT : + bRight = sal_True; goto Header; +Header: + bHeader = sal_True; + nRes = RES_HEADER; goto MakeObject; + case FN_UNO_FOOTER : + bAll = sal_True; goto Footer; + case FN_UNO_FOOTER_LEFT : + bLeft = sal_True; goto Footer; + case FN_UNO_FOOTER_RIGHT : + bRight = sal_True; +Footer: + nRes = RES_FOOTER; +MakeObject: + { + const SwPageDesc& rDesc = aBase.GetOldPageDesc(); + const SwFrmFmt* pFrmFmt = 0; + sal_Bool bShare = bHeader && rDesc.IsHeaderShared()|| + !bHeader && rDesc.IsFooterShared(); + // TextLeft returns the left content if there is one, + // Text and TextRight return the master content. + // TextRight does the same as Text and is for + // comptability only. + if( bLeft && !bShare ) + pFrmFmt = &rDesc.GetLeft(); + else + pFrmFmt = &rDesc.GetMaster(); + if(pFrmFmt) + { + const SfxItemSet& rSet = pFrmFmt->GetAttrSet(); + const SfxPoolItem* pItem; + SwFrmFmt* pHeadFootFmt; + if(SFX_ITEM_SET == rSet.GetItemState(nRes, sal_True, &pItem) && + 0 != (pHeadFootFmt = bHeader ? + ((SwFmtHeader*)pItem)->GetHeaderFmt() : + ((SwFmtFooter*)pItem)->GetFooterFmt())) + { + // gibt es schon ein Objekt dafuer? + SwXHeadFootText* pxHdFt = (SwXHeadFootText*)SwClientIter( *pHeadFootFmt ). + First( TYPE( SwXHeadFootText )); + Reference< text::XText > xRet = pxHdFt; + if(!pxHdFt) + xRet = new SwXHeadFootText(*pHeadFootFmt, bHeader); + pRet[nProp].setValue(&xRet, ::getCppuType((Reference<text::XText>*)0)); + } + } + break; + } + break; + case FN_PARAM_FTN_INFO : + { + SwDocStyleSheet aStyle( *(SwDocStyleSheet*)pBase ); + const SfxItemSet& rSet = aStyle.GetItemSet(); + const SfxPoolItem& rItem = rSet.Get(FN_PARAM_FTN_INFO); + rItem.QueryValue(pRet[nProp], pMap->nMemberId); + } + break; + default: + pRet[nProp] = lcl_GetStyleProperty(pMap, aPropSet, aBase, pBase, GetFamily(), GetDoc() ); + } + } + else if(IsDescriptor()) + { + Any* pAny = 0; + GetPropImpl()->GetProperty(pNames[nProp], pAny); + if ( !pAny ) + GetPropImpl()->GetProperty ( pNames[nProp], mxStyleData, pRet[ nProp ] ); + else + pRet[nProp] = *pAny; + } + else + throw RuntimeException(); + } + return aRet; +} +/*-- 17.12.98 08:43:36--------------------------------------------------- + + -----------------------------------------------------------------------*/ +Any SwXPageStyle::getPropertyValue(const OUString& rPropertyName) throw( + UnknownPropertyException, WrappedTargetException, RuntimeException) +{ + const Sequence<OUString> aProperties(&rPropertyName, 1); + return getPropertyValues(aProperties).getConstArray()[0]; +} +/*-- 17.12.98 08:43:36--------------------------------------------------- + + -----------------------------------------------------------------------*/ +void SwXPageStyle::setPropertyValue(const OUString& rPropertyName, const Any& rValue) + throw( UnknownPropertyException, + PropertyVetoException, + lang::IllegalArgumentException, + lang::WrappedTargetException, + RuntimeException) +{ + const Sequence<OUString> aProperties(&rPropertyName, 1); + const Sequence<Any> aValues(&rValue, 1); + setPropertyValues(aProperties, aValues); +} + +SwXFrameStyle::SwXFrameStyle ( SwDoc *pDoc ) +: SwXStyle ( pDoc, SFX_STYLE_FAMILY_FRAME, FALSE) +{ +} +/* -----------------------------15.12.00 15:45-------------------------------- + + ---------------------------------------------------------------------------*/ +SwXFrameStyle::~SwXFrameStyle() +{ +} +/* -----------------------------15.12.00 14:30-------------------------------- + + ---------------------------------------------------------------------------*/ +Sequence< uno::Type > SwXFrameStyle::getTypes( ) throw(RuntimeException) +{ + Sequence< uno::Type > aTypes = SwXStyle::getTypes(); + sal_Int32 nLen = aTypes.getLength(); + aTypes.realloc(nLen + 1); + aTypes.getArray()[nLen] = ::getCppuType((Reference<XEventsSupplier>*)0); + return aTypes; +} +/* -----------------------------15.12.00 14:30-------------------------------- + + ---------------------------------------------------------------------------*/ +Any SwXFrameStyle::queryInterface( const uno::Type& rType ) throw(RuntimeException) +{ + Any aRet; + if(rType == ::getCppuType((Reference<XEventsSupplier>*)0)) + aRet <<= Reference<XEventsSupplier>(this); + else + aRet = SwXStyle::queryInterface(rType); + return aRet; +} +/* -----------------------------15.12.00 14:30-------------------------------- + + ---------------------------------------------------------------------------*/ +Reference< XNameReplace > SwXFrameStyle::getEvents( ) throw(RuntimeException) +{ + return new SwFrameStyleEventDescriptor( *this ); +} + +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |