/* -*- 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 SwTextCharFormat::SwTextCharFormat( SwFormatCharFormat& rAttr, sal_Int32 nStt, sal_Int32 nEnd ) : SwTextAttr( rAttr, nStt ) , SwTextAttrEnd( rAttr, nStt, nEnd ) , m_pTextNode( nullptr ) , m_nSortNumber( 0 ) { rAttr.m_pTextAttribute = this; SetCharFormatAttr( true ); } SwTextCharFormat::~SwTextCharFormat( ) { } void SwTextCharFormat::ModifyNotification( const SfxPoolItem* pOld, const SfxPoolItem* pNew ) { const sal_uInt16 nWhich = pOld ? pOld->Which() : pNew ? pNew->Which() : 0; OSL_ENSURE( isCHRATR(nWhich) || (RES_OBJECTDYING == nWhich) || (RES_ATTRSET_CHG == nWhich) || (RES_FMT_CHG == nWhich), "SwTextCharFormat::Modify(): unknown Modify"); if ( m_pTextNode ) { SwUpdateAttr aUpdateAttr( GetStart(), *GetEnd(), nWhich); m_pTextNode->ModifyNotification( &aUpdateAttr, &aUpdateAttr ); } } bool SwTextCharFormat::GetInfo( SfxPoolItem const & rInfo ) const { return RES_AUTOFMT_DOCNODE != rInfo.Which() || !m_pTextNode || &m_pTextNode->GetNodes() != static_cast(rInfo).pNodes; } SwTextAttrNesting::SwTextAttrNesting( SfxPoolItem & i_rAttr, const sal_Int32 i_nStart, const sal_Int32 i_nEnd ) : SwTextAttr( i_rAttr, i_nStart ) , SwTextAttrEnd( i_rAttr, i_nStart, i_nEnd ) { SetDontExpand( true ); // never expand this attribute // lock the expand flag: simple guarantee that nesting will not be // invalidated by expand operations SetLockExpandFlag( true ); SetDontExpandStartAttr( true ); SetNesting( true ); } SwTextAttrNesting::~SwTextAttrNesting() { } SwTextINetFormat::SwTextINetFormat( SwFormatINetFormat& rAttr, sal_Int32 nStart, sal_Int32 nEnd ) : SwTextAttr( rAttr, nStart ) , SwTextAttrNesting( rAttr, nStart, nEnd ) , SwClient( nullptr ) , m_pTextNode( nullptr ) , m_bVisited( false ) , m_bVisitedValid( false ) { rAttr.mpTextAttr = this; SetCharFormatAttr( true ); } SwTextINetFormat::~SwTextINetFormat( ) { } SwCharFormat* SwTextINetFormat::GetCharFormat() { const SwFormatINetFormat& rFormat = SwTextAttrEnd::GetINetFormat(); SwCharFormat* pRet = nullptr; if (!rFormat.GetValue().isEmpty()) { SwDoc* pDoc = GetTextNode().GetDoc(); if( !IsVisitedValid() ) { SetVisited( pDoc->IsVisitedURL( rFormat.GetValue() ) ); SetVisitedValid( true ); } const sal_uInt16 nId = IsVisited() ? rFormat.GetVisitedFormatId() : rFormat.GetINetFormatId(); const OUString& rStr = IsVisited() ? rFormat.GetVisitedFormat() : rFormat.GetINetFormat(); if (rStr.isEmpty()) { OSL_ENSURE( false, " - missing character format at hyperlink attribute"); } // JP 10.02.2000, Bug 72806: don't modify the doc for getting the // correct charstyle. bool bResetMod = !pDoc->getIDocumentState().IsModified(); Link aOle2Lnk; if ( bResetMod ) { aOle2Lnk = pDoc->GetOle2Link(); pDoc->SetOle2Link( Link() ); } pRet = IsPoolUserFormat( nId ) ? pDoc->FindCharFormatByName( rStr ) : pDoc->getIDocumentStylePoolAccess().GetCharFormatFromPool( nId ); if ( bResetMod ) { pDoc->getIDocumentState().ResetModified(); pDoc->SetOle2Link( aOle2Lnk ); } } if ( pRet ) pRet->Add( this ); else EndListeningAll(); return pRet; } void SwTextINetFormat::Modify( const SfxPoolItem* pOld, const SfxPoolItem* pNew ) { const sal_uInt16 nWhich = pOld ? pOld->Which() : pNew ? pNew->Which() : 0; OSL_ENSURE( isCHRATR(nWhich) || (RES_OBJECTDYING == nWhich) || (RES_ATTRSET_CHG == nWhich) || (RES_FMT_CHG == nWhich), "SwTextINetFormat::Modify(): unknown Modify"); if ( m_pTextNode ) { SwUpdateAttr aUpdateAttr( GetStart(), *GetEnd(), nWhich); m_pTextNode->ModifyNotification( &aUpdateAttr, &aUpdateAttr ); } } bool SwTextINetFormat::GetInfo( SfxPoolItem& rInfo ) const { return RES_AUTOFMT_DOCNODE != rInfo.Which() || !m_pTextNode || &m_pTextNode->GetNodes() != static_cast(rInfo).pNodes; } bool SwTextINetFormat::IsProtect( ) const { return m_pTextNode && m_pTextNode->IsProtect(); } SwTextRuby::SwTextRuby( SwFormatRuby& rAttr, sal_Int32 nStart, sal_Int32 nEnd ) : SwTextAttr( rAttr, nStart ) , SwTextAttrNesting( rAttr, nStart, nEnd ) , SwClient( nullptr ) , m_pTextNode( nullptr ) { rAttr.m_pTextAttr = this; } SwTextRuby::~SwTextRuby() { } void SwTextRuby::Modify( const SfxPoolItem* pOld, const SfxPoolItem *pNew ) { const sal_uInt16 nWhich = pOld ? pOld->Which() : pNew ? pNew->Which() : 0; OSL_ENSURE( isCHRATR(nWhich) || (RES_OBJECTDYING == nWhich) || (RES_ATTRSET_CHG == nWhich) || (RES_FMT_CHG == nWhich), "SwTextRuby::Modify(): unknown Modify"); if ( m_pTextNode ) { SwUpdateAttr aUpdateAttr( GetStart(), *GetEnd(), nWhich); m_pTextNode->ModifyNotification( &aUpdateAttr, &aUpdateAttr ); } } bool SwTextRuby::GetInfo( SfxPoolItem& rInfo ) const { return RES_AUTOFMT_DOCNODE != rInfo.Which() || !m_pTextNode || &m_pTextNode->GetNodes() != static_cast(rInfo).pNodes; } SwCharFormat* SwTextRuby::GetCharFormat() { const SwFormatRuby& rFormat = SwTextAttrEnd::GetRuby(); SwCharFormat* pRet = nullptr; if( !rFormat.GetText().isEmpty() ) { const SwDoc* pDoc = GetTextNode().GetDoc(); const OUString& rStr = rFormat.GetCharFormatName(); const sal_uInt16 nId = rStr.isEmpty() ? static_cast(RES_POOLCHR_RUBYTEXT) : rFormat.GetCharFormatId(); // JP 10.02.2000, Bug 72806: don't modify the doc for getting the // correct charstyle. const bool bResetMod = !pDoc->getIDocumentState().IsModified(); Link aOle2Lnk; if( bResetMod ) { aOle2Lnk = pDoc->GetOle2Link(); const_cast(pDoc)->SetOle2Link( Link() ); } pRet = IsPoolUserFormat( nId ) ? pDoc->FindCharFormatByName( rStr ) : const_cast(pDoc)->getIDocumentStylePoolAccess().GetCharFormatFromPool( nId ); if( bResetMod ) { const_cast(pDoc)->getIDocumentState().ResetModified(); const_cast(pDoc)->SetOle2Link( aOle2Lnk ); } } if( pRet ) pRet->Add( this ); else EndListeningAll(); return pRet; } SwTextMeta * SwTextMeta::CreateTextMeta( ::sw::MetaFieldManager & i_rTargetDocManager, SwTextNode *const i_pTargetTextNode, SwFormatMeta & i_rAttr, sal_Int32 const i_nStart, sal_Int32 const i_nEnd, bool const i_bIsCopy) { if (i_bIsCopy) { // i_rAttr is already cloned, now call DoCopy to copy the sw::Meta OSL_ENSURE(i_pTargetTextNode, "cannot copy Meta without target node"); i_rAttr.DoCopy(i_rTargetDocManager, *i_pTargetTextNode); } SwTextMeta *const pTextMeta(new SwTextMeta(i_rAttr, i_nStart, i_nEnd)); return pTextMeta; } SwTextMeta::SwTextMeta( SwFormatMeta & i_rAttr, const sal_Int32 i_nStart, const sal_Int32 i_nEnd ) : SwTextAttr( i_rAttr, i_nStart ) , SwTextAttrNesting( i_rAttr, i_nStart, i_nEnd ) { i_rAttr.SetTextAttr( this ); SetHasDummyChar(true); } SwTextMeta::~SwTextMeta() { SwFormatMeta & rFormatMeta( static_cast(GetAttr()) ); if (rFormatMeta.GetTextAttr() == this) { rFormatMeta.SetTextAttr(nullptr); } } void SwTextMeta::ChgTextNode(SwTextNode * const pNode) { SwFormatMeta & rFormatMeta( static_cast(GetAttr()) ); if (rFormatMeta.GetTextAttr() == this) { rFormatMeta.NotifyChangeTextNode(pNode); } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */