diff options
author | Kurt Zenker <kz@openoffice.org> | 2007-05-09 12:37:50 +0000 |
---|---|---|
committer | Kurt Zenker <kz@openoffice.org> | 2007-05-09 12:37:50 +0000 |
commit | f56797c42c2ca0c29143db23acb5f6b27405b70b (patch) | |
tree | 0685ef7fe48dd1e692d8695d84a01d11dbbe6c20 /cppu/source/threadpool/current.cxx | |
parent | 1bdde728ed7697dc84a3932e6c08a9212669b3f6 (diff) |
INTEGRATION: CWS bunoexttm (1.14.28); FILE MERGED
2007/03/08 12:16:48 thb 1.14.28.5: #i10000# Fixed build breakages with DBG_UTIL build and OSX
2007/03/01 09:18:31 kr 1.14.28.4: simplified: rely on IdentityMapping
2007/03/01 09:14:33 kr 1.14.28.3: simplified: use uno::Mapping and uno::Environment instead of C types
2007/03/01 09:01:36 kr 1.14.28.2: simplified: removed unreachable code
2007/03/01 08:56:38 kr 1.14.28.1: fixed: removed all hard casts, manage obj lifecycle vie env. only
Diffstat (limited to 'cppu/source/threadpool/current.cxx')
-rw-r--r-- | cppu/source/threadpool/current.cxx | 162 |
1 files changed, 45 insertions, 117 deletions
diff --git a/cppu/source/threadpool/current.cxx b/cppu/source/threadpool/current.cxx index 353244f86d7f..d51b0c10dbb3 100644 --- a/cppu/source/threadpool/current.cxx +++ b/cppu/source/threadpool/current.cxx @@ -4,9 +4,9 @@ * * $RCSfile: current.cxx,v $ * - * $Revision: 1.14 $ + * $Revision: 1.15 $ * - * last change: $Author: obo $ $Date: 2006-09-17 00:19:17 $ + * last change: $Author: kz $ $Date: 2007-05-09 13:37:50 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. @@ -41,7 +41,7 @@ #include "osl/mutex.hxx" #include "uno/environment.hxx" -#include "uno/mapping.h" +#include "uno/mapping.hxx" #include "uno/lbnames.h" #include "typelib/typedescription.h" @@ -177,17 +177,10 @@ extern "C" void SAL_CALL delete_IdContainer( void * p ) IdContainer * pId = reinterpret_cast< IdContainer * >( p ); if (pId->pCurrentContext) { - if (pId->pCurrentContextEnv) - { - (*pId->pCurrentContextEnv->releaseInterface)( - pId->pCurrentContextEnv, pId->pCurrentContext ); - (*((uno_Environment *)pId->pCurrentContextEnv)->release)( - (uno_Environment *)pId->pCurrentContextEnv ); - } - else // current compiler used for context interface implementation - { - reinterpret_cast< ::cppu::XInterface * >( pId->pCurrentContext )->release(); - } + (*pId->pCurrentContextEnv->releaseInterface)( + pId->pCurrentContextEnv, pId->pCurrentContext ); + (*((uno_Environment *)pId->pCurrentContextEnv)->release)( + (uno_Environment *)pId->pCurrentContextEnv ); } if (pId->bInit) { @@ -229,56 +222,39 @@ extern "C" sal_Bool SAL_CALL uno_setCurrentContext( // free old one if (pId->pCurrentContext) { - if (pId->pCurrentContextEnv) - { - (*pId->pCurrentContextEnv->releaseInterface)( - pId->pCurrentContextEnv, pId->pCurrentContext ); - (*((uno_Environment *)pId->pCurrentContextEnv)->release)( - (uno_Environment *)pId->pCurrentContextEnv ); - pId->pCurrentContextEnv = 0; - } - else // current compiler used for context interface implementation - { - reinterpret_cast< ::cppu::XInterface * >( pId->pCurrentContext )->release(); - } + (*pId->pCurrentContextEnv->releaseInterface)( + pId->pCurrentContextEnv, pId->pCurrentContext ); + (*((uno_Environment *)pId->pCurrentContextEnv)->release)( + (uno_Environment *)pId->pCurrentContextEnv ); + pId->pCurrentContextEnv = 0; + pId->pCurrentContext = 0; } if (pCurrentContext) { - OUString const & rEnvTypeName = * reinterpret_cast< OUString const * >( &pEnvTypeName ); - if (rEnvTypeName.equalsAsciiL( - RTL_CONSTASCII_STRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) )) + uno_Environment * pEnv = 0; + ::uno_getEnvironment( &pEnv, pEnvTypeName, pEnvContext ); + OSL_ASSERT( pEnv && pEnv->pExtEnv ); + if (pEnv) { - reinterpret_cast< ::cppu::XInterface * >( pCurrentContext )->acquire(); - pId->pCurrentContext = pCurrentContext; - pId->pCurrentContextEnv = 0; // special for this compiler env - } - else - { - uno_Environment * pEnv = 0; - ::uno_getEnvironment( &pEnv, pEnvTypeName, pEnvContext ); - OSL_ASSERT( pEnv && pEnv->pExtEnv ); - if (pEnv) + if (pEnv->pExtEnv) { - if (pEnv->pExtEnv) - { - pId->pCurrentContextEnv = pEnv->pExtEnv; - (*pId->pCurrentContextEnv->acquireInterface)( - pId->pCurrentContextEnv, pCurrentContext ); - pId->pCurrentContext = pCurrentContext; - } - else - { - (*pEnv->release)( pEnv ); - return sal_False; - } + pId->pCurrentContextEnv = pEnv->pExtEnv; + (*pId->pCurrentContextEnv->acquireInterface)( + pId->pCurrentContextEnv, pCurrentContext ); + pId->pCurrentContext = pCurrentContext; } else { + (*pEnv->release)( pEnv ); return sal_False; } } + else + { + return sal_False; + } } return sal_True; } @@ -290,29 +266,21 @@ extern "C" sal_Bool SAL_CALL uno_getCurrentContext( IdContainer * pId = getIdContainer(); OSL_ASSERT( pId ); - ::com::sun::star::uno::Environment target_env; - OUString const & rEnvTypeName = * reinterpret_cast< OUString const * >( &pEnvTypeName ); + Environment target_env; // release inout parameter if (*ppCurrentContext) { - if (rEnvTypeName.equalsAsciiL( - RTL_CONSTASCII_STRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) )) - { - reinterpret_cast< ::cppu::XInterface * >( *ppCurrentContext )->release(); - } - else - { - uno_getEnvironment( (uno_Environment **) &target_env, pEnvTypeName, pEnvContext ); - OSL_ASSERT( target_env.is() ); - if (! target_env.is()) - return sal_False; - uno_ExtEnvironment * pEnv = target_env.get()->pExtEnv; - OSL_ASSERT( 0 != pEnv ); - if (0 == pEnv) - return sal_False; - (*pEnv->releaseInterface)( pEnv, *ppCurrentContext ); - } + target_env = Environment(rtl::OUString(pEnvTypeName), pEnvContext); + OSL_ASSERT( target_env.is() ); + if (! target_env.is()) + return sal_False; + uno_ExtEnvironment * pEnv = target_env.get()->pExtEnv; + OSL_ASSERT( 0 != pEnv ); + if (0 == pEnv) + return sal_False; + (*pEnv->releaseInterface)( pEnv, *ppCurrentContext ); + *ppCurrentContext = 0; } @@ -320,60 +288,20 @@ extern "C" sal_Bool SAL_CALL uno_getCurrentContext( if (0 == pId->pCurrentContext) return sal_True; - // case: same env (current compiler env) - if ((0 == pId->pCurrentContextEnv) && - rEnvTypeName.equalsAsciiL( - RTL_CONSTASCII_STRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) ) && - (0 == pEnvContext)) - { - reinterpret_cast< ::cppu::XInterface * >( pId->pCurrentContext )->acquire(); - *ppCurrentContext = pId->pCurrentContext; - return sal_True; - } - // case: same env (!= current compiler env) - if ((0 != pId->pCurrentContextEnv) && - (0 == ::rtl_ustr_compare( - ((uno_Environment *) pId->pCurrentContextEnv)->pTypeName->buffer, - pEnvTypeName->buffer )) && - ((uno_Environment *) pId->pCurrentContextEnv)->pContext == pEnvContext) - { - // target env == current env - (*pId->pCurrentContextEnv->acquireInterface)( - pId->pCurrentContextEnv, pId->pCurrentContext ); - *ppCurrentContext = pId->pCurrentContext; - return sal_True; - } - // else: mapping needed - if (! target_env.is()) { - uno_getEnvironment( (uno_Environment **) &target_env, pEnvTypeName, pEnvContext ); + target_env = Environment(rtl::OUString(pEnvTypeName), pEnvContext); OSL_ASSERT( target_env.is() ); if (! target_env.is()) return sal_False; } - ::com::sun::star::uno::Environment source_env; - uno_Environment * p_source_env = (uno_Environment *) pId->pCurrentContextEnv; - if (0 == p_source_env) - { - OUString current_env_name( - RTL_CONSTASCII_USTRINGPARAM(CPPU_CURRENT_LANGUAGE_BINDING_NAME) ); - uno_getEnvironment( (uno_Environment **) &source_env, current_env_name.pData, 0 ); - OSL_ASSERT( source_env.is() ); - if (! source_env.is()) - return sal_False; - p_source_env = source_env.get(); - } - - uno_Mapping * mapping = 0; - uno_getMapping( &mapping, p_source_env, target_env.get(), 0 ); - OSL_ASSERT( mapping != 0 ); - if (! mapping) + Mapping mapping((uno_Environment *) pId->pCurrentContextEnv, target_env.get()); + OSL_ASSERT( mapping.is() ); + if (! mapping.is()) return sal_False; - (*mapping->mapInterface)( - mapping, - ppCurrentContext, pId->pCurrentContext, ::cppu::get_type_XCurrentContext() ); - (*mapping->release)( mapping ); + + mapping.mapInterface(ppCurrentContext, pId->pCurrentContext, ::cppu::get_type_XCurrentContext() ); + return sal_True; } |