/************************************************************** * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * *************************************************************/ #ifndef COMPHELPER_IDPROPERTYARRAYUSAGEHELPER_HXX #define COMPHELPER_IDPROPERTYARRAYUSAGEHELPER_HXX #include #include #include #include #include #include #include namespace cppu { class IPropertyArrayHelper; } namespace comphelper { //************************************************************ // OIdPropertyArrayUsageHelper //************************************************************ template struct OIdPropertyArrayUsageHelperMutex : public rtl::Static< ::osl::Mutex, OIdPropertyArrayUsageHelperMutex > {}; typedef std::map< sal_Int32, ::cppu::IPropertyArrayHelper*, std::less< sal_Int32 > > OIdPropertyArrayMap; template class OIdPropertyArrayUsageHelper { protected: static sal_Int32 s_nRefCount; static OIdPropertyArrayMap* s_pMap; public: OIdPropertyArrayUsageHelper(); virtual ~OIdPropertyArrayUsageHelper() { ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex::get()); OSL_ENSURE(s_nRefCount > 0, "OIdPropertyArrayUsageHelper::~OIdPropertyArrayUsageHelper : suspicious call : have a refcount of 0 !"); if (!--s_nRefCount) { // delete the element for (OIdPropertyArrayMap::iterator i = s_pMap->begin(); i != s_pMap->end(); ++i) delete (*i).second; delete s_pMap; s_pMap = NULL; } } /** call this in the getInfoHelper method of your derived class. The method returns the array helper of the class, which is created if necessary. */ ::cppu::IPropertyArrayHelper* getArrayHelper(sal_Int32 nId); protected: /** used to implement the creation of the array helper which is shared amongst all instances of the class. This method needs to be implemented in derived classes.
The method gets called with Mutex acquired.
as long as IPropertyArrayHelper has no virtual destructor, the implementation of ~OPropertyArrayUsageHelper assumes that you created an ::cppu::OPropertyArrayHelper when deleting s_pProps. @return an pointer to the newly created array helper. Must not be NULL. */ virtual ::cppu::IPropertyArrayHelper* createArrayHelper(sal_Int32 nId) const = 0; }; //------------------------------------------------------------------ template sal_Int32 OIdPropertyArrayUsageHelper< TYPE >::s_nRefCount = 0; template OIdPropertyArrayMap* OIdPropertyArrayUsageHelper< TYPE >::s_pMap = NULL; //------------------------------------------------------------------ template OIdPropertyArrayUsageHelper::OIdPropertyArrayUsageHelper() { ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex::get()); // create the map if necessary if (s_pMap == NULL) s_pMap = new OIdPropertyArrayMap(); ++s_nRefCount; } //------------------------------------------------------------------ template ::cppu::IPropertyArrayHelper* OIdPropertyArrayUsageHelper::getArrayHelper(sal_Int32 nId) { OSL_ENSURE(s_nRefCount, "OIdPropertyArrayUsageHelper::getArrayHelper : suspicious call : have a refcount of 0 !"); ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex::get()); // do we have the array already? if (! (*s_pMap)[nId] ) { (*s_pMap)[nId] = createArrayHelper(nId); OSL_ENSURE((*s_pMap)[nId], "OIdPropertyArrayUsageHelper::getArrayHelper : createArrayHelper returned nonsense !"); } return (*s_pMap)[nId]; } } #endif // COMPHELPER_IDPROPERTYARRAYUSAGEHELPER_HXX