1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
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
; }
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
;
42 class OIdPropertyArrayUsageHelper
45 static sal_Int32 s_nRefCount
;
46 static OIdPropertyArrayMap
* s_pMap
;
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 !");
57 for (OIdPropertyArrayMap::iterator i
= s_pMap
->begin(); i
!= s_pMap
->end(); ++i
)
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
);
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.
73 The method gets called with Mutex acquired.
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 //------------------------------------------------------------------
84 sal_Int32 OIdPropertyArrayUsageHelper
< TYPE
>::s_nRefCount
= 0;
87 OIdPropertyArrayMap
* OIdPropertyArrayUsageHelper
< TYPE
>::s_pMap
= NULL
;
89 //------------------------------------------------------------------
91 OIdPropertyArrayUsageHelper
<TYPE
>::OIdPropertyArrayUsageHelper()
93 ::osl::MutexGuard
aGuard(OIdPropertyArrayUsageHelperMutex
<TYPE
>::get());
94 // create the map if necessary
96 s_pMap
= new OIdPropertyArrayMap();
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: */