summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--svx/source/accessibility/DGColorNameLookUp.cxx31
-rw-r--r--svx/source/inc/DGColorNameLookUp.hxx19
2 files changed, 15 insertions, 35 deletions
diff --git a/svx/source/accessibility/DGColorNameLookUp.cxx b/svx/source/accessibility/DGColorNameLookUp.cxx
index 844cd7f3d239..ca673015bc62 100644
--- a/svx/source/accessibility/DGColorNameLookUp.cxx
+++ b/svx/source/accessibility/DGColorNameLookUp.cxx
@@ -42,29 +42,18 @@ using namespace ::com::sun::star;
namespace accessibility {
-// Initialize the class instance with NULL. A true instance is created only
-// when the static <member>Instance</member> is called for the first time.
-DGColorNameLookUp* DGColorNameLookUp::mpInstance = NULL;
-
-DGColorNameLookUp& DGColorNameLookUp::Instance (void)
+namespace
{
- // Using double check pattern to make sure that exactly one instance of
- // the shape type handler is instantiated.
- if (mpInstance == NULL)
+ class theDGColorNameLookUp
+ : public rtl::Static< DGColorNameLookUp, theDGColorNameLookUp >
{
- SolarMutexGuard aGuard;
- if (mpInstance == NULL)
- {
- // Create the single instance of the color name look up.
- mpInstance = new DGColorNameLookUp();
- }
- }
-
- return *mpInstance;
+ };
}
-
-
+DGColorNameLookUp& DGColorNameLookUp::Instance()
+{
+ return theDGColorNameLookUp::get();
+}
OUString DGColorNameLookUp::LookUpColor (long int nColor) const
{
@@ -89,7 +78,7 @@ OUString DGColorNameLookUp::LookUpColor (long int nColor) const
-DGColorNameLookUp::DGColorNameLookUp (void)
+DGColorNameLookUp::DGColorNameLookUp()
{
uno::Sequence<OUString> aNames;
uno::Reference<container::XNameAccess> xNA;
@@ -141,7 +130,7 @@ DGColorNameLookUp::DGColorNameLookUp (void)
-DGColorNameLookUp::~DGColorNameLookUp (void)
+DGColorNameLookUp::~DGColorNameLookUp()
{
maColorValueToNameMap.clear();
}
diff --git a/svx/source/inc/DGColorNameLookUp.hxx b/svx/source/inc/DGColorNameLookUp.hxx
index 8ed88322228b..d3a04a2b8d71 100644
--- a/svx/source/inc/DGColorNameLookUp.hxx
+++ b/svx/source/inc/DGColorNameLookUp.hxx
@@ -30,7 +30,9 @@
#define _SVX_ACCESSIBILITY_DG_COLOR_NAME_LOOK_UP_HXX
#include <rtl/ustrbuf.hxx>
+#include <rtl/instance.hxx>
#include <boost/unordered_map.hpp>
+#include <boost/noncopyable.hpp>
namespace accessibility {
@@ -49,7 +51,7 @@ namespace accessibility {
its values may change during this time. Reacting to these changes
remains a task for the future.</p>
*/
-class DGColorNameLookUp
+class DGColorNameLookUp : private ::boost::noncopyable
{
public:
/** Return the single instance of this class. Use this to look up
@@ -77,22 +79,11 @@ private:
/// This ma translates from numerical color values to names.
tColorValueToNameMap maColorValueToNameMap;
- /** The pointer to the only instance of this class. It is NULL until
- the <member>Instance</member> is called for the first time.
- */
- static DGColorNameLookUp* mpInstance;
-
+private:
+ template<class> friend class rtl::Static;
/// Create a new (the only) instance of this class.
DGColorNameLookUp();
-
- /// The destructor is never called.
~DGColorNameLookUp();
-
- /// The copy constructor is not implemented.
- DGColorNameLookUp (const DGColorNameLookUp&);
-
- /// The assignment operator is not implemented.
- DGColorNameLookUp& operator= (const DGColorNameLookUp&);
};
} // end of namespace accessibility