diff options
Diffstat (limited to 'svx/source/accessibility/AccessibleOLEShape.cxx')
-rw-r--r-- | svx/source/accessibility/AccessibleOLEShape.cxx | 232 |
1 files changed, 232 insertions, 0 deletions
diff --git a/svx/source/accessibility/AccessibleOLEShape.cxx b/svx/source/accessibility/AccessibleOLEShape.cxx new file mode 100644 index 000000000000..8f7effb4d2b8 --- /dev/null +++ b/svx/source/accessibility/AccessibleOLEShape.cxx @@ -0,0 +1,232 @@ +/************************************************************************* + * + * 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 + * <http://www.openoffice.org/license.html> + * for a copy of the LGPLv3 License. + * + ************************************************************************/ + +// MARKER(update_precomp.py): autogen include statement, do not remove +#include "precompiled_svx.hxx" + + +#include <svx/AccessibleOLEShape.hxx> + +#include <svx/ShapeTypeHandler.hxx> +#include <svx/SvxShapeTypes.hxx> + +using namespace accessibility; +using namespace ::com::sun::star; +using namespace ::com::sun::star::uno; +using namespace ::com::sun::star::accessibility; + +//===== internal ============================================================ + +AccessibleOLEShape::AccessibleOLEShape ( + const AccessibleShapeInfo& rShapeInfo, + const AccessibleShapeTreeInfo& rShapeTreeInfo) + : AccessibleShape (rShapeInfo, rShapeTreeInfo) +{ +} + + + + +AccessibleOLEShape::~AccessibleOLEShape (void) +{ +} + + + + +//===== XAccessibleAction =================================================== + +sal_Int32 SAL_CALL AccessibleOLEShape::getAccessibleActionCount (void) + throw (::com::sun::star::uno::RuntimeException) +{ + return 0; +} + + + + +sal_Bool SAL_CALL AccessibleOLEShape::doAccessibleAction (sal_Int32 /*nIndex*/) + throw (lang::IndexOutOfBoundsException, uno::RuntimeException) +{ + throw lang::IndexOutOfBoundsException(); +} + + + + +::rtl::OUString SAL_CALL AccessibleOLEShape::getAccessibleActionDescription (sal_Int32 /*nIndex*/) + throw (::com::sun::star::lang::IndexOutOfBoundsException, + ::com::sun::star::uno::RuntimeException) +{ + throw lang::IndexOutOfBoundsException(); +} + + + + +Reference<XAccessibleKeyBinding> SAL_CALL AccessibleOLEShape::getAccessibleActionKeyBinding (sal_Int32 /*nIndex*/) + throw (::com::sun::star::lang::IndexOutOfBoundsException, + ::com::sun::star::uno::RuntimeException) +{ + throw lang::IndexOutOfBoundsException(); +} + + + + +//===== XInterface ========================================================== + +com::sun::star::uno::Any SAL_CALL + AccessibleOLEShape::queryInterface (const com::sun::star::uno::Type & rType) + throw (::com::sun::star::uno::RuntimeException) +{ + ::com::sun::star::uno::Any aReturn = AccessibleShape::queryInterface (rType); + if ( ! aReturn.hasValue()) + aReturn = ::cppu::queryInterface (rType, + static_cast<XAccessibleAction*>(this)); + return aReturn; +} + + + +void SAL_CALL + AccessibleOLEShape::acquire (void) + throw () +{ + AccessibleShape::acquire (); +} + + + +void SAL_CALL + AccessibleOLEShape::release (void) + throw () +{ + AccessibleShape::release (); +} + + + + +//===== XServiceInfo ======================================================== + +::rtl::OUString SAL_CALL + AccessibleOLEShape::getImplementationName (void) + throw (::com::sun::star::uno::RuntimeException) +{ + return ::rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("AccessibleOLEShape")); +} + + + + +::com::sun::star::uno::Sequence< ::rtl::OUString> SAL_CALL + AccessibleOLEShape::getSupportedServiceNames (void) + throw (::com::sun::star::uno::RuntimeException) +{ + ThrowIfDisposed(); + // Get list of supported service names from base class... + uno::Sequence< ::rtl::OUString > aServiceNames = + AccessibleShape::getSupportedServiceNames(); + sal_Int32 nCount (aServiceNames.getLength()); + + // ...and add additional names. + aServiceNames.realloc (nCount + 1); + static const ::rtl::OUString sAdditionalServiceName (RTL_CONSTASCII_USTRINGPARAM( + "com.sun.star.drawing.AccessibleOLEShape")); + aServiceNames[nCount] = sAdditionalServiceName; + + return aServiceNames; +} + + + + +//===== XTypeProvider =================================================== + +uno::Sequence<uno::Type> SAL_CALL + AccessibleOLEShape::getTypes (void) + throw (uno::RuntimeException) +{ + // Get list of types from the context base implementation... + uno::Sequence<uno::Type> aTypeList (AccessibleShape::getTypes()); + // ...and add the additional type for the component. + long nTypeCount = aTypeList.getLength(); + aTypeList.realloc (nTypeCount + 1); + const uno::Type aActionType = + ::getCppuType((const uno::Reference<XAccessibleAction>*)0); + aTypeList[nTypeCount] = aActionType; + + return aTypeList; +} + + + + +/// Set this object's name if is different to the current name. +::rtl::OUString + AccessibleOLEShape::CreateAccessibleBaseName (void) + throw (::com::sun::star::uno::RuntimeException) +{ + ::rtl::OUString sName; + + ShapeTypeId nShapeType = ShapeTypeHandler::Instance().GetTypeId (mxShape); + switch (nShapeType) + { + case DRAWING_APPLET: + sName = ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM("AppletOLEShape")); + break; + case DRAWING_FRAME: + sName = ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM("FrameOLEShape")); + break; + case DRAWING_OLE: + sName = ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM("OLEShape")); + break; + case DRAWING_PLUGIN: + sName = ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM("PluginOLEShape")); + break; + + default: + sName = ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM("UnknownAccessibleOLEShape")); + uno::Reference<drawing::XShapeDescriptor> xDescriptor (mxShape, uno::UNO_QUERY); + if (xDescriptor.is()) + sName += ::rtl::OUString (RTL_CONSTASCII_USTRINGPARAM(": ")) + + xDescriptor->getShapeType(); + } + + return sName; +} + + + +::rtl::OUString + AccessibleOLEShape::CreateAccessibleDescription (void) + throw (::com::sun::star::uno::RuntimeException) +{ + return CreateAccessibleName (); +} + |