summaryrefslogtreecommitdiff
path: root/comphelper/source/property/MasterPropertySetInfo.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'comphelper/source/property/MasterPropertySetInfo.cxx')
-rw-r--r--comphelper/source/property/MasterPropertySetInfo.cxx170
1 files changed, 170 insertions, 0 deletions
diff --git a/comphelper/source/property/MasterPropertySetInfo.cxx b/comphelper/source/property/MasterPropertySetInfo.cxx
new file mode 100644
index 000000000000..57cf22b77508
--- /dev/null
+++ b/comphelper/source/property/MasterPropertySetInfo.cxx
@@ -0,0 +1,170 @@
+/*************************************************************************
+ *
+ * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
+ *
+ * Copyright 2000, 2010 Oracle and/or its affiliates.
+ *
+ * OpenOffice.org - a multi-platform office productivity suite
+ *
+ * This file is part of OpenOffice.org.
+ *
+ * OpenOffice.org is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License version 3
+ * only, as published by the Free Software Foundation.
+ *
+ * OpenOffice.org is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License version 3 for more details
+ * (a copy is included in the LICENSE file that accompanied this code).
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * version 3 along with OpenOffice.org. If not, see
+ * <http://www.openoffice.org/license.html>
+ * for a copy of the LGPLv3 License.
+ *
+ ************************************************************************/
+
+// MARKER(update_precomp.py): autogen include statement, do not remove
+#include "precompiled_comphelper.hxx"
+#ifndef _COMPHELPER_CHAINABLEPROPERTYSETINFO_HXX_
+#include <comphelper/MasterPropertySetInfo.hxx>
+#endif
+#include <comphelper/TypeGeneration.hxx>
+
+using ::rtl::OUString;
+using ::comphelper::PropertyInfo;
+using ::comphelper::GenerateCppuType;
+using ::comphelper::MasterPropertySetInfo;
+using ::com::sun::star::uno::Any;
+using ::com::sun::star::uno::Type;
+using ::com::sun::star::uno::Sequence;
+using ::com::sun::star::uno::Reference;
+using ::com::sun::star::uno::XInterface;
+using ::com::sun::star::uno::RuntimeException;
+using ::com::sun::star::beans::Property;
+using ::com::sun::star::beans::XPropertySetInfo;
+using ::com::sun::star::beans::UnknownPropertyException;
+
+MasterPropertySetInfo::MasterPropertySetInfo()
+ throw()
+{
+}
+
+MasterPropertySetInfo::MasterPropertySetInfo( PropertyInfo* pMap )
+ throw()
+{
+ add ( pMap );
+}
+
+MasterPropertySetInfo::~MasterPropertySetInfo()
+ throw()
+{
+ PropertyDataHash::iterator aEnd = maMap.end(), aIter = maMap.begin();
+ while (aIter != aEnd )
+ {
+ delete (*aIter).second;
+ aIter++;
+ }
+}
+
+void MasterPropertySetInfo::add( PropertyInfo* pMap, sal_Int32 nCount, sal_uInt8 nMapId )
+ throw()
+{
+ // nCount < 0 => add all
+ // nCount == 0 => add nothing
+ // nCount > 0 => add at most nCount entries
+ if( maProperties.getLength() )
+ maProperties.realloc( 0 );
+
+ for ( ; pMap->mpName && ( ( nCount < 0 ) || ( nCount > 0 ) ); --nCount, ++pMap )
+ {
+ OUString aName( pMap->mpName, pMap->mnNameLen, RTL_TEXTENCODING_ASCII_US );
+
+#ifdef DBG_UTIL
+ PropertyDataHash::iterator aIter = maMap.find( aName );
+ if( aIter != maMap.end() )
+ OSL_ENSURE( sal_False, "Warning: PropertyInfo added twice, possible error!");
+#endif
+ maMap[aName] = new PropertyData ( nMapId, pMap );
+ }
+}
+
+void MasterPropertySetInfo::add( PropertyInfoHash &rHash, sal_uInt8 nMapId )
+ throw()
+{
+ if( maProperties.getLength() )
+ maProperties.realloc( 0 );
+ PropertyInfoHash::iterator aIter = rHash.begin(), aEnd = rHash.end();
+
+ while ( aIter != aEnd )
+ {
+#ifdef DBG_UTIL
+ PropertyDataHash::iterator aDebugIter = maMap.find( (*aIter).first );
+ if( aDebugIter != maMap.end() )
+ OSL_ENSURE( sal_False, "Warning: PropertyInfo added twice, possible error!");
+#endif
+ maMap[(*aIter).first] = new PropertyData ( nMapId, (*aIter).second );
+ aIter++;
+ }
+}
+
+void MasterPropertySetInfo::remove( const rtl::OUString& aName )
+ throw()
+{
+ maMap.erase ( aName );
+ if ( maProperties.getLength() )
+ maProperties.realloc( 0 );
+}
+
+Sequence< ::Property > SAL_CALL MasterPropertySetInfo::getProperties()
+ throw(::com::sun::star::uno::RuntimeException)
+{
+ sal_Int32 nSize = maMap.size();
+ if( maProperties.getLength() != nSize )
+ {
+ maProperties.realloc ( nSize );
+ Property* pProperties = maProperties.getArray();
+
+ PropertyDataHash::iterator aIter = maMap.begin();
+ const PropertyDataHash::iterator aEnd = maMap.end();
+ for ( ; aIter != aEnd; ++aIter, ++pProperties)
+ {
+ PropertyInfo* pInfo = (*aIter).second->mpInfo;
+
+ pProperties->Name = OUString( pInfo->mpName, pInfo->mnNameLen, RTL_TEXTENCODING_ASCII_US );
+ pProperties->Handle = pInfo->mnHandle;
+ const Type* pType;
+ GenerateCppuType ( pInfo->meCppuType, pType);
+ pProperties->Type = *pType;
+ pProperties->Attributes = pInfo->mnAttributes;
+ }
+ }
+ return maProperties;
+}
+
+Property SAL_CALL MasterPropertySetInfo::getPropertyByName( const ::rtl::OUString& rName )
+ throw(::UnknownPropertyException, ::com::sun::star::uno::RuntimeException)
+{
+ PropertyDataHash::iterator aIter = maMap.find( rName );
+
+ if ( maMap.end() == aIter )
+ throw UnknownPropertyException( rName, *this );
+
+ PropertyInfo *pInfo = (*aIter).second->mpInfo;
+ Property aProperty;
+ aProperty.Name = OUString( pInfo->mpName, pInfo->mnNameLen, RTL_TEXTENCODING_ASCII_US );
+ aProperty.Handle = pInfo->mnHandle;
+ const Type* pType;
+ GenerateCppuType ( pInfo->meCppuType, pType );
+ aProperty.Type = *pType;
+
+ aProperty.Attributes = pInfo->mnAttributes;
+ return aProperty;
+}
+
+sal_Bool SAL_CALL MasterPropertySetInfo::hasPropertyByName( const ::rtl::OUString& rName )
+ throw(::com::sun::star::uno::RuntimeException)
+{
+ return static_cast < sal_Bool > ( maMap.find ( rName ) != maMap.end() );
+}