summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cppuhelper/source/component_context.cxx231
1 files changed, 0 insertions, 231 deletions
diff --git a/cppuhelper/source/component_context.cxx b/cppuhelper/source/component_context.cxx
index 776eef021eaf..8e75d5f4dd68 100644
--- a/cppuhelper/source/component_context.cxx
+++ b/cppuhelper/source/component_context.cxx
@@ -17,15 +17,7 @@
* the License at http://www.apache.org/licenses/LICENSE-2.0 .
*/
-
-#ifdef DIAG
-#define CONTEXT_DIAG
-#endif
-
#include <unordered_map>
-#ifdef CONTEXT_DIAG
-#include <map>
-#endif
#include <osl/diagnose.h>
#include <osl/mutex.hxx>
@@ -68,202 +60,6 @@ using rtl::OUStringHash;
namespace cppu
{
-#ifdef CONTEXT_DIAG
-
-static OUString val2str( void const * pVal, typelib_TypeDescriptionReference * pTypeRef )
-{
- OSL_ASSERT( pVal );
- if (pTypeRef->eTypeClass == typelib_TypeClass_VOID)
- return "void";
-
- OUStringBuffer buf( 64 );
- buf.append( "(" + pTypeRef->pTypeName + ")" );
-
- switch (pTypeRef->eTypeClass)
- {
- case typelib_TypeClass_INTERFACE:
- buf.append( "0x" );
- buf.append( (sal_Int64)*(void **)pVal, 16 );
- break;
- case typelib_TypeClass_STRUCT:
- case typelib_TypeClass_EXCEPTION:
- {
- buf.append( "{ " );
- typelib_TypeDescription * pTypeDescr = 0;
- ::typelib_typedescriptionreference_getDescription( &pTypeDescr, pTypeRef );
- OSL_ASSERT( pTypeDescr );
- if (! pTypeDescr->bComplete)
- ::typelib_typedescription_complete( &pTypeDescr );
-
- typelib_CompoundTypeDescription * pCompType = (typelib_CompoundTypeDescription *)pTypeDescr;
- sal_Int32 nDescr = pCompType->nMembers;
-
- if (pCompType->pBaseTypeDescription)
- {
- buf.append( val2str( pVal, ((typelib_TypeDescription *)pCompType->pBaseTypeDescription)->pWeakRef ) );
- if (nDescr)
- buf.append( ", " );
- }
-
- typelib_TypeDescriptionReference ** ppTypeRefs = pCompType->ppTypeRefs;
- sal_Int32 * pMemberOffsets = pCompType->pMemberOffsets;
- rtl_uString ** ppMemberNames = pCompType->ppMemberNames;
-
- for ( sal_Int32 nPos = 0; nPos < nDescr; ++nPos )
- {
- buf.append( ppMemberNames[ nPos ] );
- buf.append( " = " );
- typelib_TypeDescription * pMemberType = 0;
- TYPELIB_DANGER_GET( &pMemberType, ppTypeRefs[ nPos ] );
- buf.append( val2str( (char *)pVal + pMemberOffsets[ nPos ], pMemberType->pWeakRef ) );
- TYPELIB_DANGER_RELEASE( pMemberType );
- if (nPos < (nDescr -1))
- buf.append( ", " );
- }
-
- ::typelib_typedescription_release( pTypeDescr );
-
- buf.append( " }" );
- break;
- }
- case typelib_TypeClass_SEQUENCE:
- {
- typelib_TypeDescription * pTypeDescr = 0;
- TYPELIB_DANGER_GET( &pTypeDescr, pTypeRef );
-
- uno_Sequence * pSequence = *(uno_Sequence **)pVal;
- typelib_TypeDescription * pElementTypeDescr = 0;
- TYPELIB_DANGER_GET( &pElementTypeDescr, ((typelib_IndirectTypeDescription *)pTypeDescr)->pType );
-
- sal_Int32 nElementSize = pElementTypeDescr->nSize;
- sal_Int32 nElements = pSequence->nElements;
-
- if (nElements)
- {
- buf.append( "{ " );
- char * pElements = pSequence->elements;
- for ( sal_Int32 nPos = 0; nPos < nElements; ++nPos )
- {
- buf.append( val2str( pElements + (nElementSize * nPos), pElementTypeDescr->pWeakRef ) );
- if (nPos < (nElements -1))
- buf.append( ", " );
- }
- buf.append( " }" );
- }
- else
- {
- buf.append( "{}" );
- }
- TYPELIB_DANGER_RELEASE( pElementTypeDescr );
- TYPELIB_DANGER_RELEASE( pTypeDescr );
- break;
- }
- case typelib_TypeClass_ANY:
- buf.append( "{ " );
- buf.append( val2str( ((uno_Any *)pVal)->pData,
- ((uno_Any *)pVal)->pType ) );
- buf.append( " }" );
- break;
- case typelib_TypeClass_TYPE:
- buf.append( (*(typelib_TypeDescriptionReference **)pVal)->pTypeName );
- break;
- case typelib_TypeClass_STRING:
- buf.append( '\"' );
- buf.append( *(rtl_uString **)pVal );
- buf.append( '\"' );
- break;
- case typelib_TypeClass_ENUM:
- {
- typelib_TypeDescription * pTypeDescr = 0;
- ::typelib_typedescriptionreference_getDescription( &pTypeDescr, pTypeRef );
- OSL_ASSERT( pTypeDescr );
- if (! pTypeDescr->bComplete)
- ::typelib_typedescription_complete( &pTypeDescr );
-
- sal_Int32 * pValues = ((typelib_EnumTypeDescription *)pTypeDescr)->pEnumValues;
- sal_Int32 nPos = ((typelib_EnumTypeDescription *)pTypeDescr)->nEnumValues;
- while (nPos--)
- {
- if (pValues[ nPos ] == *(sal_Int32 *)pVal)
- break;
- }
- if (nPos >= 0)
- buf.append( ((typelib_EnumTypeDescription *)pTypeDescr)->ppEnumNames[ nPos ] );
- else
- buf.append( '?' );
-
- ::typelib_typedescription_release( pTypeDescr );
- break;
- }
- case typelib_TypeClass_BOOLEAN:
- if (*(sal_Bool *)pVal)
- buf.append( "true" );
- else
- buf.append( "false" );
- break;
- case typelib_TypeClass_CHAR:
- buf.append( '\'' );
- buf.append( *(sal_Unicode *)pVal );
- buf.append( '\'' );
- break;
- case typelib_TypeClass_FLOAT:
- buf.append( *(float *)pVal );
- break;
- case typelib_TypeClass_DOUBLE:
- buf.append( *(double *)pVal );
- break;
- case typelib_TypeClass_BYTE:
- buf.append( "0x" );
- buf.append( (sal_Int32)*(sal_Int8 *)pVal, 16 );
- break;
- case typelib_TypeClass_SHORT:
- buf.append( "0x" );
- buf.append( (sal_Int32)*(sal_Int16 *)pVal, 16 );
- break;
- case typelib_TypeClass_UNSIGNED_SHORT:
- buf.append( "0x" );
- buf.append( (sal_Int32)*(sal_uInt16 *)pVal, 16 );
- break;
- case typelib_TypeClass_LONG:
- buf.append( "0x" );
- buf.append( *(sal_Int32 *)pVal, 16 );
- break;
- case typelib_TypeClass_UNSIGNED_LONG:
- buf.append( "0x" );
- buf.append( (sal_Int64)*(sal_uInt32 *)pVal, 16 );
- break;
- case typelib_TypeClass_HYPER:
- case typelib_TypeClass_UNSIGNED_HYPER:
- buf.append( "0x" );
-#if defined(__GNUC__) && defined(SPARC)
-// I guess this really should check if there are strict alignment
-// requirements, not just "GCC on SPARC".
- {
- sal_Int64 aVal;
- *(sal_Int32 *)&aVal = *(sal_Int32 *)pVal;
- *((sal_Int32 *)&aVal +1)= *((sal_Int32 *)pVal +1);
- buf.append( aVal, 16 );
- }
-#else
- buf.append( *(sal_Int64 *)pVal, 16 );
-#endif
- break;
- default:
- buf.append( '?' );
- }
-
- return buf.makeStringAndClear();
-}
-
-static void dumpEntry( OUString const & key, Any const & value )
-{
- OUString val( val2str( value.getValue(), value.getValueTypeRef() ) );
- OString key_str( OUStringToOString( key, RTL_TEXTENCODING_ASCII_US ) );
- OString val_str( OUStringToOString( val, RTL_TEXTENCODING_ASCII_US ) );
- ::fprintf( stderr, "| %s = %s\n", key_str.getStr(), val_str.getStr() );
-}
-#endif
-
static inline void try_dispose( Reference< XInterface > const & xInstance )
{
Reference< lang::XComponent > xComp( xInstance, UNO_QUERY );
@@ -504,26 +300,6 @@ sal_Bool ComponentContext::hasElements() throw (RuntimeException, std::exception
Any ComponentContext::lookupMap( OUString const & rName )
{
-#ifdef CONTEXT_DIAG
- if ( rName == "dump_maps" )
- {
- ::fprintf( stderr, ">>> dumping out ComponentContext %p m_map:\n", this );
- typedef ::std::map< OUString, ContextEntry * > t_sorted; // sorted map
- t_sorted sorted;
- for ( t_map::const_iterator iPos( m_map.begin() ); iPos != m_map.end(); ++iPos )
- {
- sorted[ iPos->first ] = iPos->second;
- }
- {
- for ( t_sorted::const_iterator iPos( sorted.begin() ); iPos != sorted.end(); ++iPos )
- {
- dumpEntry( iPos->first, iPos->second->value );
- }
- }
- return Any();
- }
-#endif
-
ResettableMutexGuard guard( m_mutex );
t_map::const_iterator iFind( m_map.find( rName ) );
if (iFind == m_map.end())
@@ -652,9 +428,6 @@ Reference< lang::XMultiComponentFactory > ComponentContext::getServiceManager()
ComponentContext::~ComponentContext()
{
-#ifdef CONTEXT_DIAG
- ::fprintf( stderr, "> destructed context %p\n", this );
-#endif
t_map::const_iterator iPos( m_map.begin() );
t_map::const_iterator const iEnd( m_map.end() );
for ( ; iPos != iEnd; ++iPos )
@@ -664,10 +437,6 @@ ComponentContext::~ComponentContext()
void ComponentContext::disposing()
{
-#ifdef CONTEXT_DIAG
- ::fprintf( stderr, "> disposing context %p\n", this );
-#endif
-
Reference< lang::XComponent > xTDMgr, xAC; // to be disposed separately
// dispose all context objects