/* -*- 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 "access.hrc" #include #include #include #include #include "unostyle.hxx" #include "docsh.hxx" #include #include "fesh.hxx" #include #include #include #include #include #include #include #include #include #include #include #include #include #include const sal_Char sServiceName[] = "com.sun.star.text.AccessibleTextDocumentView"; const sal_Char sImplementationName[] = "com.sun.star.comp.Writer.SwAccessibleDocumentView"; using namespace ::com::sun::star; using namespace ::com::sun::star::accessibility; using lang::IndexOutOfBoundsException; // SwAccessibleDocumentBase: base class for SwAccessibleDocument and // SwAccessiblePreview SwAccessibleDocumentBase::SwAccessibleDocumentBase ( SwAccessibleMap *_pMap ) : SwAccessibleContext( _pMap, AccessibleRole::DOCUMENT_TEXT, _pMap->GetShell()->GetLayout() ), mxParent( _pMap->GetShell()->GetWin()->GetAccessibleParentWindow()->GetAccessible() ), mpChildWin( nullptr ) { } SwAccessibleDocumentBase::~SwAccessibleDocumentBase() { } void SwAccessibleDocumentBase::SetVisArea() { SolarMutexGuard aGuard; SwRect aOldVisArea( GetVisArea() ); const SwRect& rNewVisArea = GetMap()->GetVisArea(); if( aOldVisArea != rNewVisArea ) { SwAccessibleFrame::SetVisArea( GetMap()->GetVisArea() ); // #i58139# - showing state of document view needs also be updated. // Thus, call method instead of // ChildrenScrolled( GetFrame(), aOldVisArea ); Scrolled( aOldVisArea ); } } void SwAccessibleDocumentBase::AddChild( vcl::Window *pWin, bool bFireEvent ) { SolarMutexGuard aGuard; OSL_ENSURE( !mpChildWin, "only one child window is supported" ); if( !mpChildWin ) { mpChildWin = pWin; if( bFireEvent ) { AccessibleEventObject aEvent; aEvent.EventId = AccessibleEventId::CHILD; aEvent.NewValue <<= mpChildWin->GetAccessible(); FireAccessibleEvent( aEvent ); } } } void SwAccessibleDocumentBase::RemoveChild( vcl::Window *pWin ) { SolarMutexGuard aGuard; OSL_ENSURE( !mpChildWin || pWin == mpChildWin, "invalid child window to remove" ); if( mpChildWin && pWin == mpChildWin ) { AccessibleEventObject aEvent; aEvent.EventId = AccessibleEventId::CHILD; aEvent.OldValue <<= mpChildWin->GetAccessible(); FireAccessibleEvent( aEvent ); mpChildWin = nullptr; } } sal_Int32 SAL_CALL SwAccessibleDocumentBase::getAccessibleChildCount() throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; // CHECK_FOR_DEFUNC is called by parent sal_Int32 nChildren = SwAccessibleContext::getAccessibleChildCount(); if( !IsDisposing() && mpChildWin ) nChildren++; return nChildren; } uno::Reference< XAccessible> SAL_CALL SwAccessibleDocumentBase::getAccessibleChild( sal_Int32 nIndex ) throw (uno::RuntimeException, lang::IndexOutOfBoundsException, std::exception) { SolarMutexGuard aGuard; if( mpChildWin ) { CHECK_FOR_DEFUNC( XAccessibleContext ) if ( nIndex == GetChildCount( *(GetMap()) ) ) { return mpChildWin->GetAccessible(); } } return SwAccessibleContext::getAccessibleChild( nIndex ); } uno::Reference< XAccessible> SAL_CALL SwAccessibleDocumentBase::getAccessibleParent() throw (uno::RuntimeException, std::exception) { return mxParent; } sal_Int32 SAL_CALL SwAccessibleDocumentBase::getAccessibleIndexInParent() throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; uno::Reference < XAccessibleContext > xAcc( mxParent->getAccessibleContext() ); uno::Reference < XAccessible > xThis( this ); sal_Int32 nCount = xAcc->getAccessibleChildCount(); for( sal_Int32 i=0; i < nCount; i++ ) { try { if( xAcc->getAccessibleChild( i ) == xThis ) return i; } catch(const css::lang::IndexOutOfBoundsException &) { return -1L; } } return -1L; } OUString SAL_CALL SwAccessibleDocumentBase::getAccessibleDescription() throw (uno::RuntimeException, std::exception) { return GetResource( STR_ACCESS_DOC_DESC ); } OUString SAL_CALL SwAccessibleDocumentBase::getAccessibleName() throw (css::uno::RuntimeException, std::exception) { SolarMutexGuard g; OUString sAccName = GetResource( STR_ACCESS_DOC_WORDPROCESSING ); SwDoc *pDoc = GetMap() ? GetShell()->GetDoc() : nullptr; if ( pDoc ) { OUString sFileName = pDoc->getDocAccTitle(); if ( sFileName.isEmpty() ) { SwDocShell* pDocSh = pDoc->GetDocShell(); if ( pDocSh ) { sFileName = pDocSh->GetTitle( SFX_TITLE_APINAME ); } } OUString sReadOnly; if(pDoc->getDocReadOnly()) { sReadOnly = GetResource( STR_ACCESS_DOC_WORDPROCESSING_READONLY ); } if ( !sFileName.isEmpty() ) { sAccName = sFileName + sReadOnly + " - " + sAccName; } } return sAccName; } awt::Rectangle SAL_CALL SwAccessibleDocumentBase::getBounds() throw (uno::RuntimeException, std::exception) { try { SolarMutexGuard aGuard; vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Rectangle aPixBounds( pWin->GetWindowExtentsRelative( pWin->GetAccessibleParentWindow() ) ); awt::Rectangle aBox( aPixBounds.Left(), aPixBounds.Top(), aPixBounds.GetWidth(), aPixBounds.GetHeight() ); return aBox; } catch(const css::lang::IndexOutOfBoundsException &) { return awt::Rectangle(); } } awt::Point SAL_CALL SwAccessibleDocumentBase::getLocation() throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Point aPixPos( pWin->GetWindowExtentsRelative( pWin->GetAccessibleParentWindow() ).TopLeft() ); awt::Point aLoc( aPixPos.getX(), aPixPos.getY() ); return aLoc; } css::awt::Point SAL_CALL SwAccessibleDocumentBase::getLocationOnScreen() throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Point aPixPos( pWin->GetWindowExtentsRelative( nullptr ).TopLeft() ); awt::Point aLoc( aPixPos.getX(), aPixPos.getY() ); return aLoc; } css::awt::Size SAL_CALL SwAccessibleDocumentBase::getSize() throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Size aPixSize( pWin->GetWindowExtentsRelative( nullptr ).GetSize() ); awt::Size aSize( aPixSize.Width(), aPixSize.Height() ); return aSize; } sal_Bool SAL_CALL SwAccessibleDocumentBase::containsPoint( const awt::Point& aPoint ) throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Rectangle aPixBounds( pWin->GetWindowExtentsRelative( nullptr ) ); aPixBounds.Move(-aPixBounds.Left(), -aPixBounds.Top()); Point aPixPoint( aPoint.X, aPoint.Y ); return aPixBounds.IsInside( aPixPoint ); } uno::Reference< XAccessible > SAL_CALL SwAccessibleDocumentBase::getAccessibleAtPoint( const awt::Point& aPoint ) throw (uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; if( mpChildWin ) { CHECK_FOR_DEFUNC( XAccessibleComponent ) vcl::Window *pWin = GetWindow(); CHECK_FOR_WINDOW( XAccessibleComponent, pWin ) Point aPixPoint( aPoint.X, aPoint.Y ); // px rel to window if( mpChildWin->GetWindowExtentsRelative( pWin ).IsInside( aPixPoint ) ) return mpChildWin->GetAccessible(); } return SwAccessibleContext::getAccessibleAtPoint( aPoint ); } // SwAccessibeDocument void SwAccessibleDocument::GetStates( ::utl::AccessibleStateSetHelper& rStateSet ) { SwAccessibleContext::GetStates( rStateSet ); // MULTISELECTABLE rStateSet.AddState( AccessibleStateType::MULTI_SELECTABLE ); rStateSet.AddState( AccessibleStateType::MANAGES_DESCENDANTS ); } SwAccessibleDocument::SwAccessibleDocument ( SwAccessibleMap* pInitMap ) : SwAccessibleDocumentBase( pInitMap ), maSelectionHelper( *this ) { SetName( GetResource( STR_ACCESS_DOC_NAME ) ); vcl::Window *pWin = pInitMap->GetShell()->GetWin(); if( pWin ) { pWin->AddChildEventListener( LINK( this, SwAccessibleDocument, WindowChildEventListener )); sal_uInt16 nCount = pWin->GetChildCount(); for( sal_uInt16 i=0; i < nCount; i++ ) { vcl::Window* pChildWin = pWin->GetChild( i ); if( pChildWin && AccessibleRole::EMBEDDED_OBJECT == pChildWin->GetAccessibleRole() ) AddChild( pChildWin, false ); } } } SwAccessibleDocument::~SwAccessibleDocument() { vcl::Window *pWin = GetMap() ? GetMap()->GetShell()->GetWin() : nullptr; if( pWin ) pWin->RemoveChildEventListener( LINK( this, SwAccessibleDocument, WindowChildEventListener )); } void SwAccessibleDocument::Dispose( bool bRecursive ) { OSL_ENSURE( GetFrame() && GetMap(), "already disposed" ); vcl::Window *pWin = GetMap() ? GetMap()->GetShell()->GetWin() : nullptr; if( pWin ) pWin->RemoveChildEventListener( LINK( this, SwAccessibleDocument, WindowChildEventListener )); SwAccessibleContext::Dispose( bRecursive ); } IMPL_LINK_TYPED( SwAccessibleDocument, WindowChildEventListener, VclWindowEvent&, rEvent, void ) { OSL_ENSURE( rEvent.GetWindow(), "Window???" ); switch ( rEvent.GetId() ) { case VCLEVENT_WINDOW_SHOW: // send create on show for direct accessible children { vcl::Window* pChildWin = static_cast< vcl::Window* >( rEvent.GetData() ); if( pChildWin && AccessibleRole::EMBEDDED_OBJECT == pChildWin->GetAccessibleRole() ) { AddChild( pChildWin ); } } break; case VCLEVENT_WINDOW_HIDE: // send destroy on hide for direct accessible children { vcl::Window* pChildWin = static_cast< vcl::Window* >( rEvent.GetData() ); if( pChildWin && AccessibleRole::EMBEDDED_OBJECT == pChildWin->GetAccessibleRole() ) { RemoveChild( pChildWin ); } } break; case VCLEVENT_OBJECT_DYING: // send destroy on hide for direct accessible children { vcl::Window* pChildWin = rEvent.GetWindow(); if( pChildWin && AccessibleRole::EMBEDDED_OBJECT == pChildWin->GetAccessibleRole() ) { RemoveChild( pChildWin ); } } break; } } OUString SAL_CALL SwAccessibleDocument::getImplementationName() throw( uno::RuntimeException, std::exception ) { return OUString(sImplementationName); } sal_Bool SAL_CALL SwAccessibleDocument::supportsService(const OUString& sTestServiceName) throw (uno::RuntimeException, std::exception) { return cppu::supportsService(this, sTestServiceName); } uno::Sequence< OUString > SAL_CALL SwAccessibleDocument::getSupportedServiceNames() throw( uno::RuntimeException, std::exception ) { uno::Sequence< OUString > aRet(2); OUString* pArray = aRet.getArray(); pArray[0] = sServiceName; pArray[1] = sAccessibleServiceName; return aRet; } // XInterface uno::Any SwAccessibleDocument::queryInterface( const uno::Type& rType ) throw ( uno::RuntimeException, std::exception ) { uno::Any aRet; if ( rType == cppu::UnoType::get() ) { uno::Reference aSelect = this; aRet <<= aSelect; } else if ( rType == cppu::UnoType::get()) { uno::Reference aAttribute = this; aRet <<= aAttribute; } else if(rType == cppu::UnoType::get()) { uno::Reference AccFlowTo = this; aRet <<= AccFlowTo; } else aRet = SwAccessibleContext::queryInterface( rType ); return aRet; } // XTypeProvider uno::Sequence< uno::Type > SAL_CALL SwAccessibleDocument::getTypes() throw(uno::RuntimeException, std::exception) { uno::Sequence< uno::Type > aTypes( SwAccessibleDocumentBase::getTypes() ); sal_Int32 nIndex = aTypes.getLength(); //Reset types memory alloc aTypes.realloc( nIndex + 1 ); uno::Type* pTypes = aTypes.getArray(); pTypes[nIndex] = cppu::UnoType::get(); return aTypes; } uno::Sequence< sal_Int8 > SAL_CALL SwAccessibleDocument::getImplementationId() throw(uno::RuntimeException, std::exception) { return css::uno::Sequence(); } // XAccessibleSelection void SwAccessibleDocument::selectAccessibleChild( sal_Int32 nChildIndex ) throw ( lang::IndexOutOfBoundsException, uno::RuntimeException, std::exception ) { maSelectionHelper.selectAccessibleChild(nChildIndex); } sal_Bool SwAccessibleDocument::isAccessibleChildSelected( sal_Int32 nChildIndex ) throw ( lang::IndexOutOfBoundsException, uno::RuntimeException, std::exception ) { return maSelectionHelper.isAccessibleChildSelected(nChildIndex); } void SwAccessibleDocument::clearAccessibleSelection( ) throw ( uno::RuntimeException, std::exception ) { } void SwAccessibleDocument::selectAllAccessibleChildren( ) throw ( uno::RuntimeException, std::exception ) { maSelectionHelper.selectAllAccessibleChildren(); } sal_Int32 SwAccessibleDocument::getSelectedAccessibleChildCount( ) throw ( uno::RuntimeException, std::exception ) { return maSelectionHelper.getSelectedAccessibleChildCount(); } uno::Reference SwAccessibleDocument::getSelectedAccessibleChild( sal_Int32 nSelectedChildIndex ) throw ( lang::IndexOutOfBoundsException, uno::RuntimeException, std::exception) { return maSelectionHelper.getSelectedAccessibleChild(nSelectedChildIndex); } // index has to be treated as global child index. void SwAccessibleDocument::deselectAccessibleChild( sal_Int32 nChildIndex ) throw ( lang::IndexOutOfBoundsException, uno::RuntimeException, std::exception ) { maSelectionHelper.deselectAccessibleChild( nChildIndex ); } uno::Any SAL_CALL SwAccessibleDocument::getExtendedAttributes() throw (css::lang::IndexOutOfBoundsException, css::uno::RuntimeException, std::exception) { SolarMutexGuard g; uno::Any anyAtrribute; SwDoc *pDoc = GetMap() ? GetShell()->GetDoc() : nullptr; if (!pDoc) return anyAtrribute; SwCursorShell* pCursorShell = GetCursorShell(); if( !pCursorShell ) return anyAtrribute; SwFEShell* pFEShell = dynamic_cast( pCursorShell) != nullptr ? static_cast( pCursorShell ) : nullptr; OUString sAttrName; OUString sValue; sal_uInt16 nPage, nLogPage; OUString sDisplay; if( pFEShell ) { pFEShell->GetPageNumber(-1,true,nPage,nLogPage,sDisplay); sAttrName = "page-name:"; sValue = sAttrName + sDisplay ; sAttrName = ";page-number:"; sValue += sAttrName; sValue += OUString::number( nPage ) ; sAttrName = ";total-pages:"; sValue += sAttrName; sValue += OUString::number( pCursorShell->GetPageCnt() ) ; sValue += ";"; sAttrName = "line-number:"; SwContentFrame* pCurrFrame = pCursorShell->GetCurrFrame(); SwPageFrame* pCurrPage=static_cast(pCurrFrame)->FindPageFrame(); sal_uLong nLineNum = 0; SwTextFrame* pTextFrame = nullptr; SwTextFrame* pCurrTextFrame = nullptr; pTextFrame = static_cast< SwTextFrame* >(static_cast< SwPageFrame* > (pCurrPage)->ContainsContent()); if (pCurrFrame->IsInFly())//such as, graphic,chart { SwFlyFrame *pFlyFrame = pCurrFrame->FindFlyFrame(); const SwFormatAnchor& rAnchor = pFlyFrame->GetFormat()->GetAnchor(); RndStdIds eAnchorId = rAnchor.GetAnchorId(); if(eAnchorId == FLY_AS_CHAR) { const SwFrame *pSwFrame = pFlyFrame->GetAnchorFrame(); if(pSwFrame->IsTextFrame()) pCurrTextFrame = const_cast(static_cast(pSwFrame)); } } else pCurrTextFrame = const_cast(static_cast(pCurrFrame)); //check whether the text frame where the Graph/OLE/Frame anchored is in the Header/Footer SwFrame* pFrame = pCurrTextFrame; while ( pFrame && !pFrame->IsHeaderFrame() && !pFrame->IsFooterFrame() ) pFrame = pFrame->GetUpper(); if ( pFrame ) pCurrTextFrame = nullptr; //check shape if(pCursorShell->Imp()->GetDrawView()) { const SdrMarkList &rMrkList = pCursorShell->Imp()->GetDrawView()->GetMarkedObjectList(); for ( size_t i = 0; i < rMrkList.GetMarkCount(); ++i ) { SdrObject *pObj = rMrkList.GetMark(i)->GetMarkedSdrObj(); SwFrameFormat* pFormat = static_cast(pObj->GetUserCall())->GetFormat(); const SwFormatAnchor& rAnchor = pFormat->GetAnchor(); if( FLY_AS_CHAR != rAnchor.GetAnchorId() ) pCurrTextFrame = nullptr; } } //calculate line number if (pCurrTextFrame && pTextFrame) { if (!(pCurrTextFrame->IsInTab() || pCurrTextFrame->IsInFootnote())) { while( pTextFrame != pCurrTextFrame ) { //check header/footer pFrame = pTextFrame; while ( pFrame && !pFrame->IsHeaderFrame() && !pFrame->IsFooterFrame() ) pFrame = pFrame->GetUpper(); if ( pFrame ) { pTextFrame = static_cast< SwTextFrame*>(pTextFrame->GetNextContentFrame()); continue; } if (!(pTextFrame->IsInTab() || pTextFrame->IsInFootnote() || pTextFrame->IsInFly())) nLineNum += pTextFrame->GetThisLines(); pTextFrame = static_cast< SwTextFrame* >(pTextFrame ->GetNextContentFrame()); } SwPaM* pCaret = pCursorShell->GetCursor(); if (!pCurrTextFrame->IsEmpty() && pCaret) { if (pCurrTextFrame->IsTextFrame()) { const SwPosition* pPoint = nullptr; if(pCurrTextFrame->IsInFly()) { SwFlyFrame *pFlyFrame = pCurrTextFrame->FindFlyFrame(); const SwFormatAnchor& rAnchor = pFlyFrame->GetFormat()->GetAnchor(); pPoint= rAnchor.GetContentAnchor(); } else pPoint = pCaret->GetPoint(); const sal_Int32 nActPos = pPoint->nContent.GetIndex(); nLineNum += pCurrTextFrame->GetLineCount( nActPos ); } else//graphic, form, shape, etc. { SwPosition* pPoint = pCaret->GetPoint(); Point aPt = pCursorShell->_GetCursor()->GetPtPos(); if( pCursorShell->GetLayout()->GetCursorOfst( pPoint, aPt/*,* &eTmpState*/ ) ) { const sal_Int32 nActPos = pPoint->nContent.GetIndex(); nLineNum += pCurrTextFrame->GetLineCount( nActPos ); } } } else ++nLineNum; } } sValue += sAttrName; sValue += OUString::number( nLineNum ) ; sValue += ";"; SwFrame* pCurrCol=static_cast(pCurrFrame)->FindColFrame(); sAttrName = "column-number:"; sValue += sAttrName; int nCurrCol = 1; if(pCurrCol!=nullptr) { //SwLayoutFrame* pParent = pCurrCol->GetUpper(); SwFrame* pCurrPageCol=static_cast(pCurrFrame)->FindColFrame(); while(pCurrPageCol && pCurrPageCol->GetUpper() && pCurrPageCol->GetUpper()->IsPageFrame()) { pCurrPageCol = pCurrPageCol->GetUpper(); } SwLayoutFrame* pParent = pCurrPageCol->GetUpper(); if(pParent!=nullptr) { SwFrame* pCol = pParent->Lower(); while(pCol&&(pCol!=pCurrPageCol)) { pCol = pCol->GetNext(); ++nCurrCol; } } } sValue += OUString::number( nCurrCol ) ; sValue += ";"; sAttrName = "total-columns:"; const SwFormatCol &rFormatCol=pCurrPage->GetAttrSet()->GetCol(); sal_uInt16 nColCount=rFormatCol.GetNumCols(); nColCount = nColCount>0?nColCount:1; sValue += sAttrName; sValue += OUString::number( nColCount ) ; sValue += ";"; SwSectionFrame* pCurrSctFrame=static_cast(pCurrFrame)->FindSctFrame(); if(pCurrSctFrame!=nullptr && pCurrSctFrame->GetSection()!=nullptr ) { sAttrName = "section-name:"; sValue += sAttrName; OUString sectionName = pCurrSctFrame->GetSection()->GetSectionName(); sectionName = sectionName.replaceFirst( "\\" , "\\\\" ); sectionName = sectionName.replaceFirst( "=" , "\\=" ); sectionName = sectionName.replaceFirst( ";" , "\\;" ); sectionName = sectionName.replaceFirst( "," , "\\," ); sectionName = sectionName.replaceFirst( ":" , "\\:" ); sValue += sectionName; sValue += ";"; //section-columns-number sAttrName = "section-columns-number:"; nCurrCol = 1; if(pCurrCol!=nullptr) { SwLayoutFrame* pParent = pCurrCol->GetUpper(); if(pParent!=nullptr) { SwFrame* pCol = pParent->Lower(); while(pCol&&(pCol!=pCurrCol)) { pCol = pCol->GetNext(); nCurrCol +=1; } } } sValue += sAttrName; sValue += OUString::number( nCurrCol ) ; sValue += ";"; //section-total-columns sAttrName = "section-total-columns:"; const SwFormatCol &rFormatSctCol=pCurrSctFrame->GetAttrSet()->GetCol(); sal_uInt16 nSctColCount=rFormatSctCol.GetNumCols(); nSctColCount = nSctColCount>0?nSctColCount:1; sValue += sAttrName; sValue += OUString::number( nSctColCount ) ; sValue += ";"; } anyAtrribute <<= sValue; } return anyAtrribute; } sal_Int32 SAL_CALL SwAccessibleDocument::getBackground() throw (css::uno::RuntimeException, std::exception) { SolarMutexGuard aGuard; return SW_MOD()->GetColorConfig().GetColorValue( ::svtools::DOCCOLOR ).nColor; } css::uno::Sequence< css::uno::Any > SAL_CALL SwAccessibleDocument::getAccFlowTo(const css::uno::Any& rAny, sal_Int32 nType) throw (css::uno::RuntimeException, std::exception) { SolarMutexGuard g; const sal_Int32 FORSPELLCHECKFLOWTO = 1; const sal_Int32 FORFINDREPLACEFLOWTO = 2; SwAccessibleMap* pAccMap = GetMap(); if ( !pAccMap ) { return uno::Sequence< uno::Any >(); } if ( nType == FORSPELLCHECKFLOWTO ) { uno::Reference< css::drawing::XShape > xShape; rAny >>= xShape; if( xShape.is() ) { SdrObject* pObj = GetSdrObjectFromXShape(xShape); if( pObj ) { uno::Reference xAcc = pAccMap->GetContext(pObj, this, false); uno::Reference < XAccessibleSelection > xAccSelection( xAcc, uno::UNO_QUERY ); if ( xAccSelection.is() ) { try { if ( xAccSelection->getSelectedAccessibleChildCount() ) { uno::Reference < XAccessible > xSel = xAccSelection->getSelectedAccessibleChild( 0 ); if ( xSel.is() ) { uno::Reference < XAccessibleContext > xSelContext( xSel->getAccessibleContext() ); if ( xSelContext.is() ) { //if in sw we find the selected paragraph here if ( xSelContext->getAccessibleRole() == AccessibleRole::PARAGRAPH ) { uno::Sequence aRet( 1 ); aRet[0] = uno::makeAny( xSel ); return aRet; } } } } } catch ( const css::lang::IndexOutOfBoundsException& ) { return uno::Sequence< uno::Any >(); } //end of try...catch } } } else { uno::Reference< XAccessible > xAcc = pAccMap->GetCursorContext(); SwAccessibleContext *pAccImpl = static_cast< SwAccessibleContext *>( xAcc.get() ); if ( pAccImpl && pAccImpl->getAccessibleRole() == AccessibleRole::PARAGRAPH ) { uno::Sequence< uno::Any > aRet(1); aRet[0] = uno::makeAny( xAcc ); return aRet; } } } else if ( nType == FORFINDREPLACEFLOWTO ) { SwCursorShell* pCursorShell = GetCursorShell(); if ( pCursorShell ) { SwPaM *_pStartCursor = pCursorShell->GetCursor(), *__pStartCursor = _pStartCursor; SwContentNode* pPrevNode = nullptr; std::vector vFrameList; do { if ( _pStartCursor && _pStartCursor->HasMark() ) { SwContentNode* pContentNode = _pStartCursor->GetContentNode(); if ( pContentNode == pPrevNode ) { continue; } SwFrame* pFrame = pContentNode ? pContentNode->getLayoutFrame( pCursorShell->GetLayout() ) : nullptr; if ( pFrame ) { vFrameList.push_back( pFrame ); } pPrevNode = pContentNode; } } while( _pStartCursor && ( (_pStartCursor = _pStartCursor->GetNext()) != __pStartCursor) ); if ( vFrameList.size() ) { uno::Sequence< uno::Any > aRet(vFrameList.size()); std::vector::iterator aIter = vFrameList.begin(); for ( sal_Int32 nIndex = 0; aIter != vFrameList.end(); ++aIter, nIndex++ ) { uno::Reference< XAccessible > xAcc = pAccMap->GetContext(*aIter, false); if ( xAcc.is() ) { SwAccessibleContext *pAccImpl = static_cast< SwAccessibleContext *>( xAcc.get() ); if ( pAccImpl && pAccImpl->getAccessibleRole() == AccessibleRole::PARAGRAPH ) { aRet[nIndex] = uno::makeAny( xAcc ); } } } return aRet; } } } return uno::Sequence< uno::Any >(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */