summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNoel Grandin <noel.grandin@collabora.co.uk>2020-07-13 16:02:05 +0200
committerNoel Grandin <noel.grandin@collabora.co.uk>2020-07-13 19:50:00 +0200
commit9ad54d31c80a6ba826f3c121efbf6b9376140c86 (patch)
tree397bf86eb06ad2de592c7ae82d1f9f951f60525d
parentfcd0338631bb13a3a8354f6e9265e2cb54c38f25 (diff)
connectivity/mozab: create instances with uno constructors
See tdf#74608 for motivation. Change-Id: I93b5ae48ec3580b1feb20fa1cf7897a0f2ed8fb4 Reviewed-on: https://gerrit.libreoffice.org/c/core/+/98668 Tested-by: Jenkins Reviewed-by: Noel Grandin <noel.grandin@collabora.co.uk>
-rw-r--r--connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.cxx63
-rw-r--r--connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.hxx3
-rw-r--r--connectivity/source/drivers/mozab/bootstrap/mozbootstrap.component5
3 files changed, 13 insertions, 58 deletions
diff --git a/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.cxx b/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.cxx
index 8dc7768778af..62bea4e8f253 100644
--- a/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.cxx
+++ b/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.cxx
@@ -21,6 +21,7 @@
#include <cppuhelper/factory.hxx>
#include <com/sun/star/lang/XSingleServiceFactory.hpp>
#include <cppuhelper/supportsservice.hxx>
+#include <rtl/ref.hxx>
#include "MMozillaBootstrap.hxx"
#include "MNSProfileDiscover.hxx"
@@ -34,34 +35,17 @@ using ::com::sun::star::uno::Sequence;
using ::com::sun::star::lang::XSingleServiceFactory;
using ::com::sun::star::lang::XMultiServiceFactory;
-static MozillaBootstrap *pMozillaBootstrap=nullptr;
-static Reference<XMozillaBootstrap> xMozillaBootstrap;
-extern "C" SAL_DLLPUBLIC_EXPORT void* OMozillaBootstrap_CreateInstance(const css::uno::Reference< css::lang::XMultiServiceFactory >& )
-{
- if (!pMozillaBootstrap)
- {
- pMozillaBootstrap=new connectivity::mozab::MozillaBootstrap;
- pMozillaBootstrap->Init();
- xMozillaBootstrap = pMozillaBootstrap;
- }
- return pMozillaBootstrap;
-}
-
MozillaBootstrap::MozillaBootstrap()
: OMozillaBootstrap_BASE(m_aMutex)
{
+ m_ProfileAccess.reset(new ProfileAccess);
+ bootupProfile(css::mozilla::MozillaProductType_Mozilla,OUString());
}
MozillaBootstrap::~MozillaBootstrap()
{
}
-void MozillaBootstrap::Init()
-{
- m_ProfileAccess.reset(new ProfileAccess);
- bootupProfile(css::mozilla::MozillaProductType_Mozilla,OUString());
-}
-
void MozillaBootstrap::disposing()
{
::osl::MutexGuard aGuard(m_aMutex);
@@ -70,7 +54,7 @@ void MozillaBootstrap::disposing()
OUString SAL_CALL MozillaBootstrap::getImplementationName( )
{
- return MOZAB_MozillaBootstrap_IMPL_NAME;
+ return "com.sun.star.comp.mozilla.MozillaBootstrap";
}
sal_Bool SAL_CALL MozillaBootstrap::supportsService( const OUString& _rServiceName )
@@ -144,40 +128,13 @@ OUString SAL_CALL MozillaBootstrap::setCurrentProfile( css::mozilla::MozillaProd
return -1;
}
-static Reference< XInterface > createInstance( const Reference< XMultiServiceFactory >& rServiceManager )
+extern "C" SAL_DLLPUBLIC_EXPORT css::uno::XInterface*
+connectivity_moz_MozillaBootstrap_get_implementation(
+ css::uno::XComponentContext* , css::uno::Sequence<css::uno::Any> const&)
{
- MozillaBootstrap * pBootstrap = static_cast<MozillaBootstrap*>(OMozillaBootstrap_CreateInstance(rServiceManager));
- return *pBootstrap;
+ static rtl::Reference<MozillaBootstrap> pMozillaBootstrap(new connectivity::mozab::MozillaBootstrap());
+ pMozillaBootstrap->acquire();
+ return static_cast<cppu::OWeakObject*>(pMozillaBootstrap.get());
}
-extern "C" SAL_DLLPUBLIC_EXPORT void* mozbootstrap_component_getFactory(
- const char* pImplementationName,
- void* pServiceManager,
- void* /*pRegistryKey*/)
-{
- void* pRet = nullptr;
-
- if (pServiceManager)
- {
- OUString aImplName( OUString::createFromAscii( pImplementationName ) );
- Reference< XSingleServiceFactory > xFactory;
- if ( aImplName == "com.sun.star.comp.mozilla.MozillaBootstrap" )
- {
- Sequence<OUString> aSNS { "com.sun.star.mozilla.MozillaBootstrap" };
-
- xFactory = ::cppu::createSingleFactory(
- static_cast< XMultiServiceFactory* > ( pServiceManager),
- aImplName, createInstance, aSNS );
- }
- if ( xFactory.is() )
- {
- xFactory->acquire();
- pRet = xFactory.get();
- }
- }
-
- return pRet;
-};
-
-
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.hxx b/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.hxx
index a727e3579e0e..24407e038ccb 100644
--- a/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.hxx
+++ b/connectivity/source/drivers/mozab/bootstrap/MMozillaBootstrap.hxx
@@ -28,8 +28,6 @@
#include <cppuhelper/compbase.hxx>
-#define MOZAB_MozillaBootstrap_IMPL_NAME "com.sun.star.comp.mozilla.MozillaBootstrap"
-
namespace connectivity
{
namespace mozab
@@ -46,7 +44,6 @@ namespace connectivity
std::unique_ptr<ProfileAccess> m_ProfileAccess;
public:
- void Init();
MozillaBootstrap();
// OComponentHelper
diff --git a/connectivity/source/drivers/mozab/bootstrap/mozbootstrap.component b/connectivity/source/drivers/mozab/bootstrap/mozbootstrap.component
index 848112c64e79..11b58c134ba8 100644
--- a/connectivity/source/drivers/mozab/bootstrap/mozbootstrap.component
+++ b/connectivity/source/drivers/mozab/bootstrap/mozbootstrap.component
@@ -18,8 +18,9 @@
-->
<component loader="com.sun.star.loader.SharedLibrary" environment="@CPPU_ENV@"
- prefix="mozbootstrap" xmlns="http://openoffice.org/2010/uno-components">
- <implementation name="com.sun.star.comp.mozilla.MozillaBootstrap">
+ xmlns="http://openoffice.org/2010/uno-components">
+ <implementation name="com.sun.star.comp.mozilla.MozillaBootstrap"
+ constructor="connectivity_moz_MozillaBootstrap_get_implementation">
<service name="com.sun.star.mozilla.MozillaBootstrap"/>
</implementation>
</component>