From 940b4d1848e8c70ab7642901a68594e8016caffc Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 27 Apr 2024 18:51:28 +0200 Subject: Adding upstream version 1:7.0.4. Signed-off-by: Daniel Baumann --- xmlhelp/source/treeview/tvfactory.cxx | 157 ++++++++++++++++++++++++++++++++++ 1 file changed, 157 insertions(+) create mode 100644 xmlhelp/source/treeview/tvfactory.cxx (limited to 'xmlhelp/source/treeview/tvfactory.cxx') diff --git a/xmlhelp/source/treeview/tvfactory.cxx b/xmlhelp/source/treeview/tvfactory.cxx new file mode 100644 index 000000000..9f59b66e4 --- /dev/null +++ b/xmlhelp/source/treeview/tvfactory.cxx @@ -0,0 +1,157 @@ +/* -*- 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 + +using namespace treeview; +using namespace com::sun::star; +using namespace com::sun::star::uno; +using namespace com::sun::star::lang; +using namespace com::sun::star::beans; +using namespace com::sun::star::container; + +TVFactory::TVFactory( const uno::Reference< XComponentContext >& xContext ) + : m_xContext( xContext ) +{ +} + +TVFactory::~TVFactory() +{ +} + +// XServiceInfo methods. + +OUString SAL_CALL +TVFactory::getImplementationName() +{ + return TVFactory::getImplementationName_static(); +} + +sal_Bool SAL_CALL TVFactory::supportsService( const OUString& ServiceName ) +{ + return cppu::supportsService( this, ServiceName ); +} + +Sequence< OUString > SAL_CALL +TVFactory::getSupportedServiceNames() +{ + return TVFactory::getSupportedServiceNames_static(); +} + +// XMultiServiceFactory + +Reference< XInterface > SAL_CALL +TVFactory::createInstance( + const OUString& aServiceSpecifier ) +{ + uno::Sequence seq(comphelper::InitAnyPropertySequence( + { + {"nodepath", uno::Any(OUString())} + })); + + return createInstanceWithArguments( aServiceSpecifier, seq ); +} + +Reference< XInterface > SAL_CALL +TVFactory::createInstanceWithArguments( + const OUString& /*ServiceSpecifier*/, + const Sequence< Any >& Arguments ) +{ + if( ! m_xHDS.is() ) + { + cppu::OWeakObject* p = new TVChildTarget( m_xContext ); + m_xHDS.set( p ); + } + + OUString hierview; + for( const auto& rArgument : Arguments ) + { + PropertyValue pV; + if( ! ( rArgument >>= pV ) ) + continue; + + if( pV.Name != "nodepath" ) + continue; + + if( ! ( pV.Value >>= hierview ) ) + continue; + + break; + } + + if( !hierview.isEmpty() ) + { + Reference< XHierarchicalNameAccess > xhieraccess( m_xHDS,UNO_QUERY ); + Any aAny = xhieraccess->getByHierarchicalName( hierview ); + Reference< XInterface > xInterface; + aAny >>= xInterface; + return xInterface; + } + else + return m_xHDS; +} + +Sequence< OUString > SAL_CALL +TVFactory::getAvailableServiceNames( ) +{ + return { "com.sun.star.ucb.HierarchyDataReadAccess" }; +} + +// static + +OUString +TVFactory::getImplementationName_static() +{ + return "com.sun.star.help.TreeViewImpl"; +} + +Sequence< OUString > +TVFactory::getSupportedServiceNames_static() +{ + return { "com.sun.star.help.TreeView", "com.sun.star.ucb.HiearchyDataSource" }; +} + +Reference< XSingleServiceFactory > +TVFactory::createServiceFactory( + const Reference< XMultiServiceFactory >& rxServiceMgr ) +{ + return cppu::createSingleFactory( + rxServiceMgr, + TVFactory::getImplementationName_static(), + TVFactory::CreateInstance, + TVFactory::getSupportedServiceNames_static() ); +} + +Reference< XInterface > SAL_CALL +TVFactory::CreateInstance( + const Reference< XMultiServiceFactory >& xMultiServiceFactory ) +{ + return static_cast( + new TVFactory(comphelper::getComponentContext(xMultiServiceFactory))); +} + +/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ -- cgit v1.2.3