diff options
author | Rüdiger Timm <rt@openoffice.org> | 2003-04-17 09:24:15 +0000 |
---|---|---|
committer | Rüdiger Timm <rt@openoffice.org> | 2003-04-17 09:24:15 +0000 |
commit | db7254979b4983549956165de6b3baf5c3bf64f7 (patch) | |
tree | 30215d20dd7abac1104b7bd4391f3d01c7c44060 | |
parent | ebf7bcdf0e7d86f38a9e9fa4fb2163518abf2f3c (diff) |
INTEGRATION: CWS sdk01 (1.4.42); FILE MERGED
2003/03/07 07:40:31 jsc 1.4.42.1: #107900# bugfix using tdmgr instead or registry files
-rw-r--r-- | rdbmaker/source/rdbmaker/typeblop.cxx | 146 |
1 files changed, 101 insertions, 45 deletions
diff --git a/rdbmaker/source/rdbmaker/typeblop.cxx b/rdbmaker/source/rdbmaker/typeblop.cxx index 10d6e333d79d..c1eb3db8ba4d 100644 --- a/rdbmaker/source/rdbmaker/typeblop.cxx +++ b/rdbmaker/source/rdbmaker/typeblop.cxx @@ -2,9 +2,9 @@ * * $RCSfile: typeblop.cxx,v $ * - * $Revision: 1.4 $ + * $Revision: 1.5 $ * - * last change: $Author: jsc $ $Date: 2001-08-17 13:09:50 $ + * last change: $Author: rt $ $Date: 2003-04-17 10:24:15 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -76,6 +76,15 @@ #ifndef _COM_SUN_STAR_REFLECTION_XINTERFACETYPEDESCRIPTION_HPP_ #include <com/sun/star/reflection/XInterfaceTypeDescription.hpp> #endif +#ifndef _COM_SUN_STAR_REFLECTION_XCONSTANTSTYPEDESCRIPTION_HPP_ +#include <com/sun/star/reflection/XConstantsTypeDescription.hpp> +#endif +#ifndef _COM_SUN_STAR_REFLECTION_XCONSTANTTYPEDESCRIPTION_HPP_ +#include <com/sun/star/reflection/XConstantTypeDescription.hpp> +#endif +#ifndef _COM_SUN_STAR_REFLECTION_XMODULETYPEDESCRIPTION_HPP_ +#include <com/sun/star/reflection/XModuleTypeDescription.hpp> +#endif #ifndef _COM_SUN_STAR_REFLECTION_XINTERFACEMETHODTYPEDESCRIPTION_HPP_ #include <com/sun/star/reflection/XInterfaceMethodTypeDescription.hpp> #endif @@ -116,95 +125,84 @@ using namespace rtl; static Reference< XHierarchicalNameAccess > xNameAccess; -sal_uInt32 writeConstantData( const RegistryTypeWriterLoader& rLoader, - const OUString& typeName, - const Any& aTypeAny, - sal_uInt8** pBlop ) -{ - sal_uInt32 lastIndex = typeName.lastIndexOf('.'); - OUString uModuleName( typeName.copy(0, lastIndex) ); - OUString uConstName( typeName.copy(lastIndex + 1) ); - - RegistryTypeWriter writer(rLoader, RT_TYPE_MODULE, uModuleName.replace('.', '/'), - OUString(), 1, 0, 0); +void writeConstantData( RegistryTypeWriter& rWriter, sal_uInt16 fieldIndex, + const Reference< XConstantTypeDescription >& xConstant) +{ RTConstValue constValue; OUString uConstTypeName; - switch ( aTypeAny.getValueTypeClass() ) + OUString uConstName = xConstant->getName(); + Any aConstantAny = xConstant->getConstantValue(); + + switch ( aConstantAny.getValueTypeClass() ) { case TypeClass_BOOLEAN: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("boolean") ); constValue.m_type = RT_TYPE_BOOL; - aTypeAny >>= constValue.m_value.aBool; + aConstantAny >>= constValue.m_value.aBool; } break; case TypeClass_BYTE: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("byte") ); constValue.m_type = RT_TYPE_BYTE; - aTypeAny >>= constValue.m_value.aByte; + aConstantAny >>= constValue.m_value.aByte; } break; case TypeClass_SHORT: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("short") ); constValue.m_type = RT_TYPE_INT16; - aTypeAny >>= constValue.m_value.aShort; + aConstantAny >>= constValue.m_value.aShort; } break; case TypeClass_UNSIGNED_SHORT: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("unsigned short") ); constValue.m_type = RT_TYPE_UINT16; - aTypeAny >>= constValue.m_value.aUShort; + aConstantAny >>= constValue.m_value.aUShort; } break; case TypeClass_LONG: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("long") ); constValue.m_type = RT_TYPE_INT32; - aTypeAny >>= constValue.m_value.aLong; + aConstantAny >>= constValue.m_value.aLong; } break; case TypeClass_UNSIGNED_LONG: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("unsigned long") ); constValue.m_type = RT_TYPE_UINT32; - aTypeAny >>= constValue.m_value.aULong; + aConstantAny >>= constValue.m_value.aULong; } break; case TypeClass_FLOAT: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("float") ); constValue.m_type = RT_TYPE_FLOAT; - aTypeAny >>= constValue.m_value.aFloat; + aConstantAny >>= constValue.m_value.aFloat; } break; case TypeClass_DOUBLE: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("double") ); constValue.m_type = RT_TYPE_DOUBLE; - aTypeAny >>= constValue.m_value.aDouble; + aConstantAny >>= constValue.m_value.aDouble; } break; case TypeClass_STRING: { uConstTypeName = OUString( RTL_CONSTASCII_USTRINGPARAM("string") ); constValue.m_type = RT_TYPE_STRING; - constValue.m_value.aString = ((OUString*)aTypeAny.getValue())->getStr(); + constValue.m_value.aString = ((OUString*)aConstantAny.getValue())->getStr(); } break; } - writer.setFieldData(1, uConstName, uConstTypeName, OUString(), + rWriter.setFieldData(fieldIndex, uConstName, uConstTypeName, OUString(), OUString(), RT_ACCESS_CONST, constValue); - - sal_uInt32 length = writer.getBlopSize(); - *pBlop = (sal_uInt8*)rtl_allocateMemory( length ); - rtl_copyMemory(*pBlop, writer.getBlop(), length); - - return length; } sal_uInt32 getInheritedMemberCount( Reference< XTypeDescription >& xType ) @@ -243,7 +241,7 @@ sal_uInt32 getInheritedMemberCount( Reference< XTypeDescription >& xType ) return memberCount; } -void writeMethodData( RegistryTypeWriter& rWriter, sal_uInt32 inheritedMmeberCount, +void writeMethodData( RegistryTypeWriter& rWriter, sal_uInt32 calculatedMemberOffset, const Reference< XInterfaceMemberTypeDescription >& xMember, const Reference< XInterfaceMethodTypeDescription >& xMethod ) { @@ -255,7 +253,7 @@ void writeMethodData( RegistryTypeWriter& rWriter, sal_uInt32 inheritedMmeberCou Sequence< Reference< XMethodParameter > > parameters( xMethod->getParameters() ); Sequence< Reference< XTypeDescription > > exceptions( xMethod->getExceptions() ); - sal_uInt16 methodIndex = (sal_uInt16)(xMember->getPosition() - inheritedMmeberCount); + sal_uInt16 methodIndex = (sal_uInt16)(xMember->getPosition() - calculatedMemberOffset); sal_uInt16 paramCount = (sal_uInt16)parameters.getLength(); sal_uInt16 exceptionCount = (sal_uInt16)exceptions.getLength(); @@ -316,7 +314,7 @@ sal_Bool SAL_CALL initTypeMapper( const sal_Char* pRegName ) if (xProps->getPropertyValue( ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("DefaultContext") ) ) >>= xContext) { xContext->getValueByName( - OUString( RTL_CONSTASCII_USTRINGPARAM("com.sun.star.reflection.TypeDescriptionManager") ) ) >>= xNAccess; + OUString( RTL_CONSTASCII_USTRINGPARAM("/singletons/com.sun.star.reflection.theTypeDescriptionManager") ) ) >>= xNAccess; } } catch (beans::UnknownPropertyException &) @@ -324,12 +322,6 @@ sal_Bool SAL_CALL initTypeMapper( const sal_Char* pRegName ) } } - if (! xNAccess.is()) - { - xNAccess.set( xSMgr->createInstance( - OUString(RTL_CONSTASCII_USTRINGPARAM("com.sun.star.reflection.TypeDescriptionManager"))), UNO_QUERY ); - } - if ( !xNAccess.is() ) return sal_False; @@ -362,11 +354,6 @@ sal_uInt32 SAL_CALL getTypeBlop(const sal_Char* pTypeName, sal_uInt8** pBlop) if ( !rtwLoader.isLoaded() ) return length; - if ( aTypeAny.getValueTypeClass() != TypeClass_INTERFACE ) - { - return writeConstantData( rtwLoader, uTypeName, aTypeAny, pBlop ); - } - Reference< XTypeDescription > xType; aTypeAny >>= xType; @@ -375,6 +362,68 @@ sal_uInt32 SAL_CALL getTypeBlop(const sal_Char* pTypeName, sal_uInt8** pBlop) switch (xType->getTypeClass()) { + case TypeClass_CONSTANTS: + { + Reference< XConstantsTypeDescription > xCFace(xType, UNO_QUERY); + + if ( !xCFace.is() ) + return length; + + Sequence< Reference< XConstantTypeDescription > > constTypes( xCFace->getConstants()); + sal_uInt16 constCount = (sal_uInt16)constTypes.getLength(); + + RegistryTypeWriter writer(rtwLoader, RT_TYPE_MODULE, uTypeName.replace('.', '/'), + OUString(), constCount, 0, 0); + + for (sal_uInt16 i=0; i < constCount; i++) + writeConstantData(writer, i, constTypes[i]); + + length = writer.getBlopSize(); + *pBlop = (sal_uInt8*)rtl_allocateMemory( length ); + rtl_copyMemory(*pBlop, writer.getBlop(), length); + } + break; + case TypeClass_MODULE: + { + Reference< XModuleTypeDescription > xMFace(xType, UNO_QUERY); + + if ( !xMFace.is() ) + return length; + + Sequence< Reference< XTypeDescription > > memberTypes( xMFace->getMembers()); + + sal_uInt16 memberCount = (sal_uInt16)memberTypes.getLength(); + sal_uInt16 constCount = 0; + + for (sal_Int16 i=0; i < memberCount; i++) + { + if ( TypeClass_CONSTANT == memberTypes[i]->getTypeClass() ) + constCount++; + } + + RegistryTypeWriter writer(rtwLoader, RT_TYPE_MODULE, uTypeName.replace('.', '/'), + OUString(), constCount, 0, 0); + + if ( 0 < constCount ) + { + Reference< XConstantTypeDescription > xConst; + sal_uInt16 fieldIndex = 0; + for (i=0; i < memberCount; i++) + { + if ( TypeClass_CONSTANT == memberTypes[i]->getTypeClass() ) + { + xConst = Reference< XConstantTypeDescription >(memberTypes[i], UNO_QUERY); + + writeConstantData(writer, ++fieldIndex, xConst); + } + } + } + + length = writer.getBlopSize(); + *pBlop = (sal_uInt8*)rtl_allocateMemory( length ); + rtl_copyMemory(*pBlop, writer.getBlop(), length); + } + break; case TypeClass_INTERFACE: { Reference< XInterfaceTypeDescription > xIFace(xType, UNO_QUERY); @@ -414,11 +463,15 @@ sal_uInt32 SAL_CALL getTypeBlop(const sal_Char* pTypeName, sal_uInt8** pBlop) writer.setUik( rtUik ); RTFieldAccess attrAccess = RT_ACCESS_READWRITE; + // reset attrCount, used for method index calculation + attrCount = 0; + for (i=0; i < memberCount; i++) { xAttr = Reference< XInterfaceAttributeTypeDescription >(memberTypes[i], UNO_QUERY); if ( xAttr.is() ) { + ++attrCount; if (xAttr->isReadOnly()) { attrAccess = RT_ACCESS_READONLY; @@ -436,7 +489,7 @@ sal_uInt32 SAL_CALL getTypeBlop(const sal_Char* pTypeName, sal_uInt8** pBlop) xMethod = Reference< XInterfaceMethodTypeDescription >(memberTypes[i], UNO_QUERY); if ( xMethod.is() ) { - writeMethodData( writer, inheritedMemberCount, memberTypes[i], xMethod ); + writeMethodData( writer, attrCount+inheritedMemberCount, memberTypes[i], xMethod ); } } @@ -453,6 +506,9 @@ sal_uInt32 SAL_CALL getTypeBlop(const sal_Char* pTypeName, sal_uInt8** pBlop) { rtTypeClass = RT_TYPE_EXCEPTION; } +#ifndef _COM_SUN_STAR_REFLECTION_XCONSTANTSTYPEDESCRIPTION_HPP_ +#include <com/sun/star/reflection/XConstantsTypeDescription.hpp> +#endif Reference< XCompoundTypeDescription > xComp(xType, UNO_QUERY); |