/* -*- 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 * * for a copy of the LGPLv3 License. * ************************************************************************/ #include "unotools/accessiblerelationsethelper.hxx" #include #include #include using namespace ::utl; using namespace ::rtl; using namespace ::com::sun::star; using namespace ::com::sun::star::accessibility; class AccessibleRelationSetHelperImpl { public: AccessibleRelationSetHelperImpl(); AccessibleRelationSetHelperImpl(const AccessibleRelationSetHelperImpl& rImpl); ~AccessibleRelationSetHelperImpl(); sal_Int32 getRelationCount( ) throw (uno::RuntimeException); AccessibleRelation getRelation( sal_Int32 nIndex ) throw (lang::IndexOutOfBoundsException, uno::RuntimeException); sal_Bool containsRelation( sal_Int16 aRelationType ) throw (uno::RuntimeException); AccessibleRelation getRelationByType( sal_Int16 aRelationType ) throw (uno::RuntimeException); void AddRelation(const AccessibleRelation& rRelation) throw (uno::RuntimeException); private: std::vector maRelations; }; AccessibleRelationSetHelperImpl::AccessibleRelationSetHelperImpl() { } AccessibleRelationSetHelperImpl::AccessibleRelationSetHelperImpl(const AccessibleRelationSetHelperImpl& rImpl) : maRelations(rImpl.maRelations) { } AccessibleRelationSetHelperImpl::~AccessibleRelationSetHelperImpl() { } sal_Int32 AccessibleRelationSetHelperImpl::getRelationCount( ) throw (uno::RuntimeException) { return maRelations.size(); } AccessibleRelation AccessibleRelationSetHelperImpl::getRelation( sal_Int32 nIndex ) throw (lang::IndexOutOfBoundsException, uno::RuntimeException) { if ((nIndex < 0) || (static_cast(nIndex) >= maRelations.size())) throw lang::IndexOutOfBoundsException(); return maRelations[nIndex]; } sal_Bool AccessibleRelationSetHelperImpl::containsRelation( sal_Int16 aRelationType ) throw (uno::RuntimeException) { AccessibleRelation defaultRelation; // default is INVALID AccessibleRelation relationByType = getRelationByType(aRelationType); return relationByType.RelationType != defaultRelation.RelationType; } AccessibleRelation AccessibleRelationSetHelperImpl::getRelationByType( sal_Int16 aRelationType ) throw (uno::RuntimeException) { sal_Int32 nCount(getRelationCount()); sal_Int32 i(0); sal_Bool bFound(sal_False); while ((i < nCount) && !bFound) { if (maRelations[i].RelationType == aRelationType) return maRelations[i]; else i++; } return AccessibleRelation(); } void AccessibleRelationSetHelperImpl::AddRelation(const AccessibleRelation& rRelation) throw (uno::RuntimeException) { sal_Int32 nCount(getRelationCount()); sal_Int32 i(0); sal_Bool bFound(sal_False); while ((i < nCount) && !bFound) { if (maRelations[i].RelationType == rRelation.RelationType) bFound = sal_True; else i++; } if (bFound) maRelations[i].TargetSet = comphelper::concatSequences(maRelations[i].TargetSet, rRelation.TargetSet); else maRelations.push_back(rRelation); } //===== internal ============================================================ AccessibleRelationSetHelper::AccessibleRelationSetHelper () : mpHelperImpl(NULL) { mpHelperImpl = new AccessibleRelationSetHelperImpl(); } AccessibleRelationSetHelper::AccessibleRelationSetHelper (const AccessibleRelationSetHelper& rHelper) : cppu::WeakImplHelper1() , mpHelperImpl(NULL) { if (rHelper.mpHelperImpl) mpHelperImpl = new AccessibleRelationSetHelperImpl(*rHelper.mpHelperImpl); else mpHelperImpl = new AccessibleRelationSetHelperImpl(); } AccessibleRelationSetHelper::~AccessibleRelationSetHelper(void) { delete mpHelperImpl; } //===== XAccessibleRelationSet ============================================== /** Returns the number of relations in this relation set. @return Returns the number of relations or zero if there are none. */ sal_Int32 SAL_CALL AccessibleRelationSetHelper::getRelationCount( ) throw (uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); return mpHelperImpl->getRelationCount(); } /** Returns the relation of this relation set that is specified by the given index. @param nIndex This index specifies the relatio to return. @return For a valid index, i.e. inside the range 0 to the number of relations minus one, the returned value is the requested relation. If the index is invalid then the returned relation has the type INVALID. */ AccessibleRelation SAL_CALL AccessibleRelationSetHelper::getRelation( sal_Int32 nIndex ) throw (lang::IndexOutOfBoundsException, uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); return mpHelperImpl->getRelation(nIndex); } /** Tests whether the relation set contains a relation matching the specified key. @param aRelationType The type of relation to look for in this set of relations. This has to be one of the constants of AccessibleRelationType. @return Returns if there is a (at least one) relation of the given type and if there is no such relation in the set. */ sal_Bool SAL_CALL AccessibleRelationSetHelper::containsRelation( sal_Int16 aRelationType ) throw (uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); return mpHelperImpl->containsRelation(aRelationType); } /** Retrieve and return the relation with the given relation type. @param aRelationType The type of the relation to return. This has to be one of the constants of AccessibleRelationType. @return If a relation with the given type could be found than (a copy of) this relation is returned. Otherwise a relation with the type INVALID is returned. */ AccessibleRelation SAL_CALL AccessibleRelationSetHelper::getRelationByType( sal_Int16 aRelationType ) throw (uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); return mpHelperImpl->getRelationByType(aRelationType); } void AccessibleRelationSetHelper::AddRelation(const AccessibleRelation& rRelation) throw (uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); mpHelperImpl->AddRelation(rRelation); } //===== XTypeProvider ======================================================= uno::Sequence< ::com::sun::star::uno::Type> AccessibleRelationSetHelper::getTypes (void) throw (::com::sun::star::uno::RuntimeException) { osl::MutexGuard aGuard (maMutex); const ::com::sun::star::uno::Type aTypeList[] = { ::getCppuType((const uno::Reference< XAccessibleRelationSet>*)0), ::getCppuType((const uno::Reference< lang::XTypeProvider>*)0) }; ::com::sun::star::uno::Sequence< ::com::sun::star::uno::Type> aTypeSequence (aTypeList, 2); return aTypeSequence; } namespace { class theAccessibleRelationSetHelperUnoTunnelId : public rtl::Static< UnoTunnelIdInit, theAccessibleRelationSetHelperUnoTunnelId > {}; } uno::Sequence SAL_CALL AccessibleRelationSetHelper::getImplementationId (void) throw (::com::sun::star::uno::RuntimeException) { return theAccessibleRelationSetHelperUnoTunnelId::get().getSeq(); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */