/************************************************************** * * 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 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ //---------------------------------------------- // includes of other projects //---------------------------------------------- #include #include // #ifndef _OSL_DIAGNOSE_H_ // #include // #endif #include "SalAquaFilePicker.hxx" #include "SalAquaFolderPicker.hxx" // #ifndef _SV_SVAPP_HXX // #include // #endif #include "FPServiceInfo.hxx" //----------------------------------------------- // namespace directives //----------------------------------------------- using namespace ::rtl; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::container; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::registry; using namespace ::cppu; using ::com::sun::star::ui::dialogs::XFilePicker; using ::com::sun::star::ui::dialogs::XFolderPicker; //------------------------------------------------ // //------------------------------------------------ static Reference< XInterface > SAL_CALL createFileInstance( const Reference< XMultiServiceFactory >& rServiceManager ) { return Reference< XInterface >( *new SalAquaFilePicker( rServiceManager ) ); } static Reference< XInterface > SAL_CALL createFolderInstance( const Reference< XMultiServiceFactory >& rServiceManager ) { return Reference< XInterface >( *new SalAquaFolderPicker( rServiceManager ) ); } //------------------------------------------------ // the three uno functions that will be exported //------------------------------------------------ extern "C" { //------------------------------------------------ // component_getImplementationEnvironment //------------------------------------------------ void SAL_CALL component_getImplementationEnvironment( const sal_Char ** ppEnvTypeName, uno_Environment ** /*ppEnv*/ ) { *ppEnvTypeName = CPPU_CURRENT_LANGUAGE_BINDING_NAME; } //------------------------------------------------ // //------------------------------------------------ void* SAL_CALL component_getFactory( const sal_Char* pImplName, uno_Interface* pSrvManager, uno_Interface* /*pRegistryKey*/ ) { void* pRet = 0; if( pSrvManager ) { // FIXME: PJ: when we do not need native file and folder picker... if (0) return 0; Reference< XSingleServiceFactory > xFactory; if (0 == rtl_str_compare(pImplName, FILE_PICKER_IMPL_NAME)) { Sequence< OUString > aSNS( 1 ); aSNS.getArray( )[0] = OUString::createFromAscii(FILE_PICKER_SERVICE_NAME); xFactory = createSingleFactory( reinterpret_cast< XMultiServiceFactory* > ( pSrvManager ), OUString::createFromAscii( pImplName ), createFileInstance, aSNS ); } else if (0 == rtl_str_compare(pImplName, FOLDER_PICKER_IMPL_NAME)) { Sequence< OUString > aSNS( 1 ); aSNS.getArray( )[0] = OUString::createFromAscii(FOLDER_PICKER_SERVICE_NAME); xFactory = createSingleFactory( reinterpret_cast< XMultiServiceFactory* > ( pSrvManager ), OUString::createFromAscii( pImplName ), createFolderInstance, aSNS ); } if ( xFactory.is() ) { xFactory->acquire(); pRet = xFactory.get(); } } return pRet; } } // extern "C"