/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /* * This file is part of the LibreOffice project. * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * This file incorporates work covered by the following license notice: * * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed * with this work for additional information regarding copyright * ownership. The ASF licenses this file to you under the Apache * License, Version 2.0 (the "License"); you may not use this file * except in compliance with the License. You may obtain a copy of * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "paratr.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "swabstdlg.hxx" #include "outline.hxx" #include "chrdlg.hrc" #include const sal_uInt32 nFontInc = 40; // 2pt const sal_uInt32 nFontMaxSz = 19998; // 999.9pt void SwTextShell::ExecCharAttr(SfxRequest &rReq) { SwWrtShell &rSh = GetShell(); const SfxItemSet *pArgs = rReq.GetArgs(); int eState = STATE_TOGGLE; sal_uInt16 nWhich = rReq.GetSlot(); if(pArgs ) { const SfxPoolItem* pItem; pArgs->GetItemState(nWhich, false, &pItem); eState = static_cast( pArgs-> Get( nWhich )).GetValue() ? STATE_ON : STATE_OFF; } SfxItemSet aSet( GetPool(), RES_CHRATR_BEGIN, RES_CHRATR_END-1 ); if (STATE_TOGGLE == eState) rSh.GetCurAttr( aSet ); switch ( nWhich ) { case FN_SET_SUB_SCRIPT: case FN_SET_SUPER_SCRIPT: { SvxEscapement eEscape = SvxEscapement::Subscript; switch (eState) { case STATE_TOGGLE: { short nTmpEsc = static_cast( aSet.Get( RES_CHRATR_ESCAPEMENT )).GetEsc(); eEscape = nWhich == FN_SET_SUPER_SCRIPT ? SvxEscapement::Superscript: SvxEscapement::Subscript; if( (nWhich == FN_SET_SUB_SCRIPT && nTmpEsc < 0) || (nWhich == FN_SET_SUPER_SCRIPT && nTmpEsc > 0) ) eEscape = SvxEscapement::Off; SfxBindings& rBind = GetView().GetViewFrame()->GetBindings(); if( nWhich == FN_SET_SUB_SCRIPT ) rBind.SetState( SfxBoolItem( FN_SET_SUPER_SCRIPT, false ) ); else rBind.SetState( SfxBoolItem( FN_SET_SUB_SCRIPT, false ) ); } break; case STATE_ON: eEscape = nWhich == FN_SET_SUPER_SCRIPT ? SvxEscapement::Superscript: SvxEscapement::Subscript; break; case STATE_OFF: eEscape = SvxEscapement::Off; break; } SvxEscapementItem aEscape( eEscape, RES_CHRATR_ESCAPEMENT ); if(eEscape == SvxEscapement::Superscript) aEscape.GetEsc() = DFLT_ESC_AUTO_SUPER; else if(eEscape == SvxEscapement::Subscript) aEscape.GetEsc() = DFLT_ESC_AUTO_SUB; rSh.SetAttrItem( aEscape ); rReq.AppendItem( aEscape ); rReq.Done(); } break; case FN_SET_SMALL_CAPS: { SvxCaseMap eCaseMap = SVX_CASEMAP_KAPITAELCHEN; switch (eState) { case STATE_TOGGLE: { SvxCaseMap eTmpCaseMap = static_cast(aSet.Get(RES_CHRATR_CASEMAP)).GetCaseMap(); if (eTmpCaseMap == SVX_CASEMAP_KAPITAELCHEN) eCaseMap = SVX_CASEMAP_NOT_MAPPED; } break; case STATE_ON: // Nothing to do, already set. break; case STATE_OFF: eCaseMap = SVX_CASEMAP_NOT_MAPPED; break; } SvxCaseMapItem aCaseMap(eCaseMap, RES_CHRATR_CASEMAP); rSh.SetAttrItem(aCaseMap); rReq.AppendItem(aCaseMap); rReq.Done(); } break; case FN_UPDATE_STYLE_BY_EXAMPLE: rSh.QuickUpdateStyle(); rReq.Done(); break; case FN_UNDERLINE_DOUBLE: { FontLineStyle eUnderline = static_cast( aSet.Get(RES_CHRATR_UNDERLINE)).GetLineStyle(); switch( eState ) { case STATE_TOGGLE: eUnderline = eUnderline == LINESTYLE_DOUBLE ? LINESTYLE_NONE : LINESTYLE_DOUBLE; break; case STATE_ON: eUnderline = LINESTYLE_DOUBLE; break; case STATE_OFF: eUnderline = LINESTYLE_NONE; break; } SvxUnderlineItem aUnderline(eUnderline, RES_CHRATR_UNDERLINE ); rSh.SetAttrItem( aUnderline ); rReq.AppendItem( aUnderline ); rReq.Done(); } break; case FN_REMOVE_DIRECT_CHAR_FORMATS: if( !rSh.HasReadonlySel() && rSh.IsEndPara()) rSh.DontExpandFormat(); break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::ExecCharAttrArgs(SfxRequest &rReq) { sal_uInt16 nSlot = rReq.GetSlot(); const SfxItemSet* pArgs = rReq.GetArgs(); bool bArgs = pArgs != nullptr && pArgs->Count() > 0; SwWrtShell& rWrtSh = GetShell(); SwTextFormatColl* pColl = nullptr; // Is only set if the whole paragraph is selected and AutoUpdateFormat is set. if (rWrtSh.HasSelection() && rWrtSh.IsSelFullPara()) { pColl = rWrtSh.GetCurTextFormatColl(); if ( pColl && !pColl->IsAutoUpdateFormat() ) pColl = nullptr; } SfxItemPool& rPool = GetPool(); sal_uInt16 nWhich = rPool.GetWhich( nSlot ); switch (nSlot) { case FN_TXTATR_INET: // Special treatment of the PoolId of the SwFormatInetFormat if(bArgs) { const SfxPoolItem& rItem = pArgs->Get( nWhich ); SwFormatINetFormat aINetFormat( static_cast(rItem) ); if ( USHRT_MAX == aINetFormat.GetVisitedFormatId() ) { OSL_ENSURE( false, " - unexpected visited character format ID at hyperlink attribute" ); aINetFormat.SetVisitedFormatAndId( aINetFormat.GetVisitedFormat(), SwStyleNameMapper::GetPoolIdFromUIName( aINetFormat.GetVisitedFormat(), SwGetPoolIdFromName::ChrFmt ) ); } if ( USHRT_MAX == aINetFormat.GetINetFormatId() ) { OSL_ENSURE( false, " - unexpected unvisited character format ID at hyperlink attribute" ); aINetFormat.SetINetFormatAndId( aINetFormat.GetINetFormat(), SwStyleNameMapper::GetPoolIdFromUIName( aINetFormat.GetINetFormat(), SwGetPoolIdFromName::ChrFmt ) ); } if ( pColl ) pColl->SetFormatAttr( aINetFormat ); else rWrtSh.SetAttrItem( aINetFormat ); rReq.Done(); } break; case FN_GROW_FONT_SIZE: case FN_SHRINK_FONT_SIZE: { SvxScriptSetItem aSetItem( SID_ATTR_CHAR_FONTHEIGHT, rPool ); rWrtSh.GetCurAttr( aSetItem.GetItemSet() ); SfxItemSet aAttrSet( rPool, aSetItem.GetItemSet().GetRanges() ); SvtScriptType nScriptTypes = rWrtSh.GetScriptType(); const SvxFontHeightItem* pSize( static_cast( aSetItem.GetItemOfScript( nScriptTypes ) ) ); std::vector >> vItems; if ( pSize ) // selected text has one size { // must create new one, otherwise document is without pam SwPaM* pPaM = rWrtSh.GetCursor(); vItems.push_back( std::make_pair( pSize, o3tl::make_unique( *(pPaM->GetMark()), *(pPaM->GetPoint())) ) ); } else vItems = rWrtSh.GetItemWithPaM( RES_CHRATR_FONTSIZE ); rWrtSh.StartUndo( UNDO_INSATTR ); for( std::pair< const SfxPoolItem*, std::unique_ptr >& iPair : vItems ) { std::unique_ptr pPaM = std::move(iPair.second); const SfxPoolItem* pItem = iPair.first; rWrtSh.GetPaMAttr( pPaM.get(), aSetItem.GetItemSet() ); aAttrSet.SetRanges( aSetItem.GetItemSet().GetRanges() ); pSize = static_cast( pItem ); if (pSize) { SvxFontHeightItem aSize(*pSize); sal_uInt32 nSize = aSize.GetHeight(); if ( nSlot == FN_GROW_FONT_SIZE && ( nSize += nFontInc ) > nFontMaxSz ) nSize = nFontMaxSz; else if ( nSlot == FN_SHRINK_FONT_SIZE && ( nSize -= nFontInc ) < nFontInc ) nSize = nFontInc; aSize.SetHeight( nSize ); aSetItem.PutItemForScriptType( nScriptTypes, aSize ); aAttrSet.Put( aSetItem.GetItemSet() ); if( pColl ) pColl->SetFormatAttr( aAttrSet ); else rWrtSh.SetAttrSet( aAttrSet, SetAttrMode::DEFAULT, pPaM.get() ); } } rWrtSh.EndUndo( UNDO_INSATTR ); rReq.Done(); } break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::ExecParaAttr(SfxRequest &rReq) { SvxAdjust eAdjst; sal_uInt8 ePropL; const SfxItemSet* pArgs = rReq.GetArgs(); // Get both attributes immediately isn't more expensive!! SfxItemSet aSet( GetPool(), RES_PARATR_LINESPACING, RES_PARATR_ADJUST, RES_FRAMEDIR, RES_FRAMEDIR, 0 ); sal_uInt16 nSlot = rReq.GetSlot(); switch (nSlot) { case SID_ATTR_PARA_ADJUST: { if( pArgs && SfxItemState::SET == pArgs->GetItemState(RES_PARATR_ADJUST) ) { const SvxAdjustItem& rAdj = static_cast( pArgs->Get(RES_PARATR_ADJUST) ); SvxAdjustItem aAdj( rAdj.GetAdjust(), RES_PARATR_ADJUST ); if ( rAdj.GetAdjust() == SVX_ADJUST_BLOCK ) { aAdj.SetLastBlock( rAdj.GetLastBlock() ); aAdj.SetOneWord( rAdj.GetOneWord() ); } aSet.Put(aAdj); } } break; case SID_ATTR_PARA_ADJUST_LEFT: eAdjst = SVX_ADJUST_LEFT; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_RIGHT: eAdjst = SVX_ADJUST_RIGHT; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_CENTER: eAdjst = SVX_ADJUST_CENTER; goto SET_ADJUST; case SID_ATTR_PARA_ADJUST_BLOCK: eAdjst = SVX_ADJUST_BLOCK; goto SET_ADJUST; SET_ADJUST: { aSet.Put(SvxAdjustItem(eAdjst,RES_PARATR_ADJUST)); rReq.AppendItem( SfxBoolItem( GetPool().GetWhich(nSlot), true ) ); } break; case SID_ATTR_PARA_LINESPACE: if(pArgs && SfxItemState::SET == pArgs->GetItemState( GetPool().GetWhich(nSlot) )) { SvxLineSpacingItem aLineSpace = static_cast( pArgs->Get( GetPool().GetWhich(nSlot))); aSet.Put( aLineSpace ); } break; case SID_ATTR_PARA_LINESPACE_10: ePropL = 100; goto SET_LINESPACE; case SID_ATTR_PARA_LINESPACE_15: ePropL = 150; goto SET_LINESPACE; case SID_ATTR_PARA_LINESPACE_20: ePropL = 200; goto SET_LINESPACE; SET_LINESPACE: { SvxLineSpacingItem aLineSpacing(ePropL, RES_PARATR_LINESPACING ); aLineSpacing.SetLineSpaceRule( SvxLineSpaceRule::Auto ); if( 100 == ePropL ) aLineSpacing.SetInterLineSpaceRule( SvxInterLineSpaceRule::Off ); else aLineSpacing.SetPropLineSpace(ePropL); aSet.Put( aLineSpacing ); } break; case SID_ATTR_PARA_LEFT_TO_RIGHT : case SID_ATTR_PARA_RIGHT_TO_LEFT : { SfxItemSet aAdjustSet( GetPool(), RES_PARATR_ADJUST, RES_PARATR_ADJUST ); GetShell().GetCurAttr(aAdjustSet); bool bChgAdjust = false; SfxItemState eAdjustState = aAdjustSet.GetItemState(RES_PARATR_ADJUST, false); if(eAdjustState >= SfxItemState::DEFAULT) { int eAdjust = (int)static_cast( aAdjustSet.Get(RES_PARATR_ADJUST)).GetAdjust(); bChgAdjust = (SVX_ADJUST_LEFT == eAdjust && SID_ATTR_PARA_RIGHT_TO_LEFT == nSlot) || (SVX_ADJUST_RIGHT == eAdjust && SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot); } else bChgAdjust = true; SvxFrameDirection eFrameDirection = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot) ? FRMDIR_HORI_LEFT_TOP : FRMDIR_HORI_RIGHT_TOP; aSet.Put( SvxFrameDirectionItem( eFrameDirection, RES_FRAMEDIR ) ); if (bChgAdjust) { SvxAdjust eAdjust = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot) ? SVX_ADJUST_LEFT : SVX_ADJUST_RIGHT; SvxAdjustItem aAdjust( eAdjust, RES_PARATR_ADJUST ); aSet.Put( aAdjust ); aAdjust.SetWhich(SID_ATTR_PARA_ADJUST); GetView().GetViewFrame()->GetBindings().SetState( aAdjust ); // Toggle numbering alignment const SwNumRule* pCurRule = GetShell().GetNumRuleAtCurrCursorPos(); if( pCurRule ) { SvxNumRule aRule = pCurRule->MakeSvxNumRule(); for(sal_uInt16 i = 0; i < aRule.GetLevelCount(); i++) { SvxNumberFormat aFormat(aRule.GetLevel(i)); if(SVX_ADJUST_LEFT == aFormat.GetNumAdjust()) aFormat.SetNumAdjust( SVX_ADJUST_RIGHT ); else if(SVX_ADJUST_RIGHT == aFormat.GetNumAdjust()) aFormat.SetNumAdjust( SVX_ADJUST_LEFT ); aRule.SetLevel(i, aFormat, aRule.Get(i) != nullptr); } SwNumRule aSetRule( pCurRule->GetName(), pCurRule->Get( 0 ).GetPositionAndSpaceMode() ); aSetRule.SetSvxRule( aRule, GetShell().GetDoc()); aSetRule.SetAutoRule( true ); // no start or continuation of a list - list style is only changed GetShell().SetCurNumRule( aSetRule, false ); } } } break; default: OSL_FAIL("wrong dispatcher"); return; } SwWrtShell& rWrtSh = GetShell(); SwTextFormatColl* pColl = rWrtSh.GetCurTextFormatColl(); if(pColl && pColl->IsAutoUpdateFormat()) { rWrtSh.AutoUpdatePara(pColl, aSet); } else rWrtSh.SetAttrSet( aSet ); rReq.Done(); } void SwTextShell::ExecParaAttrArgs(SfxRequest &rReq) { SwWrtShell &rSh = GetShell(); const SfxItemSet *pArgs = rReq.GetArgs(); const SfxPoolItem *pItem = nullptr; sal_uInt16 nSlot = rReq.GetSlot(); if(pArgs) pArgs->GetItemState(GetPool().GetWhich(nSlot), false, &pItem); switch ( nSlot ) { case FN_DROP_CHAR_STYLE_NAME: if( pItem ) { OUString sCharStyleName = static_cast(pItem)->GetValue(); SfxItemSet aSet(GetPool(), RES_PARATR_DROP, RES_PARATR_DROP, 0L); rSh.GetCurAttr(aSet); SwFormatDrop aDropItem(static_cast(aSet.Get(RES_PARATR_DROP))); SwCharFormat* pFormat = nullptr; if(!sCharStyleName.isEmpty()) pFormat = rSh.FindCharFormatByName( sCharStyleName ); aDropItem.SetCharFormat( pFormat ); aSet.Put(aDropItem); rSh.SetAttrSet(aSet); } break; case FN_FORMAT_DROPCAPS: { if(pItem) { rSh.SetAttrItem(*pItem); rReq.Done(); } else { SfxItemSet aSet(GetPool(), RES_PARATR_DROP, RES_PARATR_DROP, HINT_END, HINT_END, 0); rSh.GetCurAttr(aSet); SwAbstractDialogFactory* pFact = SwAbstractDialogFactory::Create(); OSL_ENSURE(pFact, "SwAbstractDialogFactory fail!"); ScopedVclPtr pDlg(pFact->CreateSfxDialog( GetView().GetWindow(), aSet, rSh.GetView().GetViewFrame()->GetFrame().GetFrameInterface(), DLG_SWDROPCAPS)); OSL_ENSURE(pDlg, "Dialog creation failed!"); if (pDlg->Execute() == RET_OK) { rSh.StartAction(); rSh.StartUndo( UNDO_START ); if ( SfxItemState::SET == aSet.GetItemState(HINT_END,false,&pItem) ) { if ( !static_cast(pItem)->GetValue().isEmpty() ) rSh.ReplaceDropText(static_cast(pItem)->GetValue()); } rSh.SetAttrSet(*pDlg->GetOutputItemSet()); rSh.StartUndo( UNDO_END ); rSh.EndAction(); rReq.Done(*pDlg->GetOutputItemSet()); } } } break; case SID_ATTR_PARA_PAGEBREAK: if(pItem) { rSh.SetAttrItem( *pItem ); rReq.Done(); } break; case SID_ATTR_PARA_MODEL: { if(pItem) { SfxItemSet aCoreSet( GetPool(), RES_PAGEDESC, RES_PAGEDESC, SID_ATTR_PARA_MODEL, SID_ATTR_PARA_MODEL, 0); aCoreSet.Put(*pItem); SfxToSwPageDescAttr( rSh, aCoreSet); rSh.SetAttrSet(aCoreSet); rReq.Done(); } } break; default: OSL_FAIL("wrong dispatcher"); return; } } void SwTextShell::GetAttrState(SfxItemSet &rSet) { SwWrtShell &rSh = GetShell(); SfxItemPool& rPool = GetPool(); SfxItemSet aCoreSet(rPool, aTextFormatCollSetRange); // Request *all* text attributes from the core. // fdo#78737: this is called from SvxRuler, which requires the list indents! rSh.GetCurAttr(aCoreSet, /* bMergeIndentValuesOfNumRule = */ true); SfxWhichIter aIter(rSet); sal_uInt16 nSlot = aIter.FirstWhich(); bool bFlag = false; SfxBoolItem aFlagItem; const SfxPoolItem* pItem = nullptr; int eAdjust = -1; // Illegal value to recognize DONTCARE. SfxItemState eState = aCoreSet.GetItemState(RES_PARATR_ADJUST, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetDefaultItem(RES_PARATR_ADJUST); if( SfxItemState::DEFAULT <= eState ) eAdjust = (int)static_cast( pItem)->GetAdjust(); short nEsc = 0; eState = aCoreSet.GetItemState(RES_CHRATR_ESCAPEMENT, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetDefaultItem(RES_CHRATR_ESCAPEMENT); if( eState >= SfxItemState::DEFAULT ) nEsc = static_cast(pItem)->GetEsc(); sal_uInt16 nLineSpace = 0; eState = aCoreSet.GetItemState(RES_PARATR_LINESPACING, false, &pItem); if( SfxItemState::DEFAULT == eState ) pItem = &rPool.GetDefaultItem(RES_PARATR_LINESPACING); if( SfxItemState::DEFAULT <= eState && static_cast(pItem)->GetLineSpaceRule() == SvxLineSpaceRule::Auto ) { if(SvxInterLineSpaceRule::Off == static_cast(pItem)->GetInterLineSpaceRule()) nLineSpace = 100; else nLineSpace = static_cast(pItem)->GetPropLineSpace(); } SvxCaseMap eCaseMap = SVX_CASEMAP_NOT_MAPPED; eState = aCoreSet.GetItemState(RES_CHRATR_CASEMAP, false, &pItem); if (eState == SfxItemState::DEFAULT) pItem = &rPool.GetDefaultItem(RES_CHRATR_CASEMAP); if (eState >= SfxItemState::DEFAULT) eCaseMap = static_cast(pItem)->GetCaseMap(); while (nSlot) { switch(nSlot) { case FN_SET_SUPER_SCRIPT: bFlag = 0 < nEsc; break; case FN_SET_SUB_SCRIPT: bFlag = 0 > nEsc; break; case FN_SET_SMALL_CAPS: bFlag = eCaseMap == SVX_CASEMAP_KAPITAELCHEN; break; case SID_ATTR_PARA_ADJUST_LEFT: if (eAdjust == -1) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SVX_ADJUST_LEFT == eAdjust; break; case SID_ATTR_PARA_ADJUST_RIGHT: if (eAdjust == -1) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SVX_ADJUST_RIGHT == eAdjust; break; case SID_ATTR_PARA_ADJUST_CENTER: if (eAdjust == -1) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else bFlag = SVX_ADJUST_CENTER == eAdjust; break; case SID_ATTR_PARA_ADJUST_BLOCK: { if (eAdjust == -1) { rSet.InvalidateItem( nSlot ); nSlot = 0; } else { bFlag = SVX_ADJUST_BLOCK == eAdjust; sal_uInt16 nHtmlMode = GetHtmlMode(rSh.GetView().GetDocShell()); if((nHtmlMode & HTMLMODE_ON) && !(nHtmlMode & HTMLMODE_FULL_STYLES )) { rSet.DisableItem( nSlot ); nSlot = 0; } } } break; case SID_ATTR_PARA_LINESPACE_10: bFlag = nLineSpace == 100; break; case SID_ATTR_PARA_LINESPACE_15: bFlag = nLineSpace == 150; break; case SID_ATTR_PARA_LINESPACE_20: bFlag = nLineSpace == 200; break; case FN_GROW_FONT_SIZE: case FN_SHRINK_FONT_SIZE: { SvxScriptSetItem aSetItem( SID_ATTR_CHAR_FONTHEIGHT, *rSet.GetPool() ); aSetItem.GetItemSet().Put( aCoreSet, false ); const SvxFontHeightItem* pSize( static_cast( aSetItem.GetItemOfScript( rSh.GetScriptType() ) ) ); if( pSize ) // selection is of one size { sal_uInt32 nSize = pSize->GetHeight(); if( nSize == nFontMaxSz ) rSet.DisableItem( FN_GROW_FONT_SIZE ); else if( nSize == nFontInc ) rSet.DisableItem( FN_SHRINK_FONT_SIZE ); } else { std::vector >> vFontHeight = rSh.GetItemWithPaM( RES_CHRATR_FONTSIZE ); for ( const std::pair< const SfxPoolItem*, std::unique_ptr>& aIt : vFontHeight ) { if (!aIt.first) { rSet.DisableItem(FN_GROW_FONT_SIZE); rSet.DisableItem(FN_SHRINK_FONT_SIZE); break; } pSize = static_cast( aIt.first ); sal_uInt32 nSize = pSize->GetHeight(); if( nSize == nFontMaxSz ) rSet.DisableItem( FN_GROW_FONT_SIZE ); else if( nSize == nFontInc ) rSet.DisableItem( FN_SHRINK_FONT_SIZE ); } } nSlot = 0; } break; case FN_UNDERLINE_DOUBLE: { eState = aCoreSet.GetItemState(RES_CHRATR_UNDERLINE); if( eState >= SfxItemState::DEFAULT ) { FontLineStyle eUnderline = static_cast( aCoreSet.Get(RES_CHRATR_UNDERLINE)).GetLineStyle(); rSet.Put(SfxBoolItem(nSlot, eUnderline == LINESTYLE_DOUBLE)); } else rSet.InvalidateItem(nSlot); nSlot = 0; } break; case SID_ATTR_PARA_ADJUST: if (eAdjust == -1) rSet.InvalidateItem( nSlot ); else rSet.Put(SvxAdjustItem((SvxAdjust)eAdjust, SID_ATTR_PARA_ADJUST )); nSlot = 0; break; case SID_ATTR_PARA_LRSPACE: { eState = aCoreSet.GetItemState(RES_LR_SPACE); if( eState >= SfxItemState::DEFAULT ) { SvxLRSpaceItem aLR = static_cast( aCoreSet.Get( RES_LR_SPACE ) ); aLR.SetWhich(SID_ATTR_PARA_LRSPACE); rSet.Put(aLR); } else rSet.InvalidateItem(nSlot); nSlot = 0; } break; case SID_ATTR_PARA_LEFT_TO_RIGHT : case SID_ATTR_PARA_RIGHT_TO_LEFT : { if ( !SW_MOD()->GetCTLOptions().IsCTLFontEnabled() ) { rSet.DisableItem( nSlot ); nSlot = 0; } else { // is the item set? sal_uInt16 nHtmlMode = GetHtmlMode(rSh.GetView().GetDocShell()); if((!(nHtmlMode & HTMLMODE_ON) || (0 != (nHtmlMode & HTMLMODE_SOME_STYLES))) && aCoreSet.GetItemState( RES_FRAMEDIR, false ) >= SfxItemState::DEFAULT) { SvxFrameDirection eFrameDir = (SvxFrameDirection) static_cast(aCoreSet.Get(RES_FRAMEDIR)).GetValue(); if (FRMDIR_ENVIRONMENT == eFrameDir) { eFrameDir = rSh.IsInRightToLeftText() ? FRMDIR_HORI_RIGHT_TOP : FRMDIR_HORI_LEFT_TOP; } bFlag = (SID_ATTR_PARA_LEFT_TO_RIGHT == nSlot && FRMDIR_HORI_LEFT_TOP == eFrameDir) || (SID_ATTR_PARA_RIGHT_TO_LEFT == nSlot && FRMDIR_HORI_RIGHT_TOP == eFrameDir); } else { rSet.InvalidateItem(nSlot); nSlot = 0; } } } break; case SID_ATTR_CHAR_LANGUAGE: case SID_ATTR_CHAR_KERNING: case RES_PARATR_DROP: { #if OSL_DEBUG_LEVEL > 1 const SfxPoolItem& rItem = aCoreSet.Get(GetPool().GetWhich(nSlot), true); rSet.Put(rItem); #else rSet.Put(aCoreSet.Get( GetPool().GetWhich(nSlot))); #endif nSlot = 0; } break; case SID_ATTR_PARA_MODEL: { SfxItemSet aTemp(GetPool(), RES_PAGEDESC,RES_PAGEDESC, SID_ATTR_PARA_MODEL,SID_ATTR_PARA_MODEL, 0L); aTemp.Put(aCoreSet); ::SwToSfxPageDescAttr(aTemp); rSet.Put(aTemp.Get(SID_ATTR_PARA_MODEL)); nSlot = 0; } break; case RES_TXTATR_INETFMT: { SfxItemSet aSet(GetPool(), RES_TXTATR_INETFMT, RES_TXTATR_INETFMT); rSh.GetCurAttr(aSet); const SfxPoolItem& rItem = aSet.Get(RES_TXTATR_INETFMT); rSet.Put(rItem); nSlot = 0; } break; default: // Do nothing nSlot = 0; break; } if( nSlot ) { aFlagItem.SetWhich( nSlot ); aFlagItem.SetValue( bFlag ); rSet.Put( aFlagItem ); } nSlot = aIter.NextWhich(); } rSet.Put(aCoreSet,false); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */