bump product version to 4.2.0.1
[LibreOffice.git] / include / comphelper / IdPropArrayHelper.hxx
blob251236f570708c87d3161e47fbece267fcae3c85
1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /*
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
19 #ifndef INCLUDED_COMPHELPER_IDPROPARRAYHELPER_HXX
20 #define INCLUDED_COMPHELPER_IDPROPARRAYHELPER_HXX
22 #include <cppuhelper/component.hxx>
23 #include <osl/mutex.hxx>
24 #include <cppuhelper/interfacecontainer.hxx>
25 #include <osl/diagnose.h>
26 #include <comphelper/stl_types.hxx>
27 #include <rtl/instance.hxx>
28 #include <cppuhelper/propshlp.hxx>
30 namespace cppu { class IPropertyArrayHelper; }
32 namespace comphelper
34 //************************************************************
35 // OIdPropertyArrayUsageHelper
36 //************************************************************
37 template <typename TYPE> struct OIdPropertyArrayUsageHelperMutex
38 : public rtl::Static< ::osl::Mutex, OIdPropertyArrayUsageHelperMutex<TYPE> > {};
40 typedef std::map< sal_Int32, ::cppu::IPropertyArrayHelper*, std::less< sal_Int32 > > OIdPropertyArrayMap;
41 template <class TYPE>
42 class OIdPropertyArrayUsageHelper
44 protected:
45 static sal_Int32 s_nRefCount;
46 static OIdPropertyArrayMap* s_pMap;
48 public:
49 OIdPropertyArrayUsageHelper();
50 virtual ~OIdPropertyArrayUsageHelper()
52 ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex<TYPE>::get());
53 OSL_ENSURE(s_nRefCount > 0, "OIdPropertyArrayUsageHelper::~OIdPropertyArrayUsageHelper : suspicious call : have a refcount of 0 !");
54 if (!--s_nRefCount)
56 // delete the element
57 for (OIdPropertyArrayMap::iterator i = s_pMap->begin(); i != s_pMap->end(); ++i)
58 delete (*i).second;
59 delete s_pMap;
60 s_pMap = NULL;
64 /** call this in the getInfoHelper method of your derived class. The method returns the array helper of the
65 class, which is created if neccessary.
67 ::cppu::IPropertyArrayHelper* getArrayHelper(sal_Int32 nId);
69 protected:
70 /** used to implement the creation of the array helper which is shared amongst all instances of the class.
71 This method needs to be implemented in derived classes.
72 <BR>
73 The method gets called with Mutex acquired.
74 <BR>
75 as long as IPropertyArrayHelper has no virtual destructor, the implementation of ~OPropertyArrayUsageHelper
76 assumes that you created an ::cppu::OPropertyArrayHelper when deleting s_pProps.
77 @return an pointer to the newly created array helper. Must not be NULL.
79 virtual ::cppu::IPropertyArrayHelper* createArrayHelper(sal_Int32 nId) const = 0;
82 //------------------------------------------------------------------
83 template<class TYPE>
84 sal_Int32 OIdPropertyArrayUsageHelper< TYPE >::s_nRefCount = 0;
86 template<class TYPE>
87 OIdPropertyArrayMap* OIdPropertyArrayUsageHelper< TYPE >::s_pMap = NULL;
89 //------------------------------------------------------------------
90 template <class TYPE>
91 OIdPropertyArrayUsageHelper<TYPE>::OIdPropertyArrayUsageHelper()
93 ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex<TYPE>::get());
94 // create the map if necessary
95 if (s_pMap == NULL)
96 s_pMap = new OIdPropertyArrayMap();
97 ++s_nRefCount;
100 //------------------------------------------------------------------
101 template <class TYPE>
102 ::cppu::IPropertyArrayHelper* OIdPropertyArrayUsageHelper<TYPE>::getArrayHelper(sal_Int32 nId)
104 OSL_ENSURE(s_nRefCount, "OIdPropertyArrayUsageHelper::getArrayHelper : suspicious call : have a refcount of 0 !");
105 ::osl::MutexGuard aGuard(OIdPropertyArrayUsageHelperMutex<TYPE>::get());
106 // do we have the array already?
107 if (! (*s_pMap)[nId] )
109 (*s_pMap)[nId] = createArrayHelper(nId);
110 OSL_ENSURE((*s_pMap)[nId], "OIdPropertyArrayUsageHelper::getArrayHelper : createArrayHelper returned nonsense !");
112 return (*s_pMap)[nId];
115 #endif // INCLUDED_COMPHELPER_IDPROPARRAYHELPER_HXX
117 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */