/* -*- 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 "stdafx.h" #include "AccRelation.h" #if defined __clang__ #pragma clang diagnostic push #pragma clang diagnostic ignored "-Wnon-virtual-dtor" #endif #include "UAccCOM.h" #if defined __clang__ #pragma clang diagnostic pop #endif #include #include #include #include #include "MAccessible.h" using namespace com::sun::star::accessibility; using namespace com::sun::star::uno; /** * Get relation type. * @param relationType Variant to get relation type. * @return Result. */ STDMETHODIMP CAccRelation::get_relationType(BSTR * relationType) { SolarMutexGuard g; ENTER_PROTECTED_BLOCK if (relationType == nullptr) return E_INVALIDARG; int type = relation.RelationType; SAFE_SYSFREESTRING(*relationType); *relationType = getRelationTypeBSTR(type); return S_OK; LEAVE_PROTECTED_BLOCK } // Gets what the type of localized relation is. STDMETHODIMP CAccRelation::get_localizedRelationType(BSTR *) { ENTER_PROTECTED_BLOCK return S_OK; LEAVE_PROTECTED_BLOCK } /** * Get targets length. * @param nTargets Variant to get targets length. * @return Result. */ STDMETHODIMP CAccRelation::get_nTargets(long * nTargets) { SolarMutexGuard g; ENTER_PROTECTED_BLOCK if (nTargets == nullptr) return E_INVALIDARG; Sequence< Reference< XInterface > > xTargets = relation.TargetSet; *nTargets = xTargets.getLength(); return S_OK; LEAVE_PROTECTED_BLOCK } /** * Get special target. * @param targetIndex target index. * @param target Variant to get special target. * @return Result. */ STDMETHODIMP CAccRelation::get_target(long targetIndex, IUnknown * * target) { SolarMutexGuard g; ENTER_PROTECTED_BLOCK if (target == nullptr) return E_FAIL; Sequence< Reference< XInterface > > xTargets = relation.TargetSet; int nCount = xTargets.getLength(); if( targetIndex >= nCount ) return E_FAIL; Reference xRAcc(xTargets[targetIndex], UNO_QUERY); IAccessible* pRet = nullptr; BOOL isGet = CMAccessible::get_IAccessibleFromXAccessible(xRAcc.get(), &pRet); if(isGet) { *target = /*(IAccessible2 *)*/static_cast(pRet); pRet->AddRef(); return S_OK; } return E_FAIL; LEAVE_PROTECTED_BLOCK } /** * Get special targets. * @param maxTargets Special targets count. * @param target Variant to get special target. * @param nTargets Variant to accept actual target length. * @return Result. */ STDMETHODIMP CAccRelation::get_targets(long, IUnknown * * target, long * nTargets) { SolarMutexGuard g; ENTER_PROTECTED_BLOCK // #CHECK# if(target == nullptr) return E_INVALIDARG; if (nTargets == nullptr) return E_INVALIDARG; Sequence< Reference< XInterface > > xTargets = relation.TargetSet; int nCount = xTargets.getLength(); *target = static_cast(::CoTaskMemAlloc(nCount*sizeof(IUnknown))); // #CHECK Memory Allocation# if(*target == nullptr) { return E_FAIL; } for(int i=0; i(pXSubInterface); return S_OK; } /** * Get relation type string by type. * @param type Relation type. * @return relation type string. */ BSTR CAccRelation::getRelationTypeBSTR(int type) { static LPCTSTR map[] = { _T("INVALID"), // AccessibleRelationType::INVALID IA2_RELATION_FLOWS_FROM, // AccessibleRelationType::CONTENT_FLOWS_FROM IA2_RELATION_FLOWS_TO, // AccessibleRelationType::CONTENT_FLOWS_TO IA2_RELATION_CONTROLLED_BY, // AccessibleRelationType::CONTROLLED_BY IA2_RELATION_CONTROLLER_FOR, // AccessibleRelationType::CONTROLLER_FOR IA2_RELATION_LABEL_FOR, // AccessibleRelationType::LABEL_FOR IA2_RELATION_LABELED_BY, // AccessibleRelationType::LABELED_BY IA2_RELATION_MEMBER_OF, // AccessibleRelationType::MEMBER_OF IA2_RELATION_SUBWINDOW_OF, // AccessibleRelationType::SUB_WINDOW_OF IA2_RELATION_NODE_CHILD_OF, // AccessibleRelationType::NODE_CHILD_OF IA2_RELATION_DESCRIBED_BY // AccessibleRelationType::DESCRIBED_BY }; return ::SysAllocString( (type >= AccessibleRelationType::INVALID && type <= AccessibleRelationType::DESCRIBED_BY) ? map[type] : _T("")); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */