From 99c87ee39e32117ce5a9652ef5b50a1d5760bdf7 Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Tue, 17 Mar 2009 19:36:35 -0400 Subject: Move the map for the values into its own thread-safe class --- sigscript/ValueMap.cpp | 77 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 sigscript/ValueMap.cpp (limited to 'sigscript/ValueMap.cpp') diff --git a/sigscript/ValueMap.cpp b/sigscript/ValueMap.cpp new file mode 100644 index 00000000..1b10462d --- /dev/null +++ b/sigscript/ValueMap.cpp @@ -0,0 +1,77 @@ +/* +* Copyright 2008-2009 Ben Boeckel +* +* This program is free software: you can redistribute it and/or modify +* it under the terms of the GNU General Public License as published by +* the Free Software Foundation, either version 3 of the License, or +* (at your option) any later version. +* +* This program 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 General Public License for more details. +* +* You should have received a copy of the GNU General Public License along +* with this program. If not, see . +*/ + +// Header include +#include "ValueMap.h" + +// Qt includes +#include +#include + +using namespace Sigscript; + +bool ValueMap::contains(const QString& name) const +{ + QReadLocker locker(&m_mutex); + return m_map.contains(name); +} + +QStringList ValueMap::keys() const +{ + QReadLocker locker(&m_mutex); + return m_map.keys(); +} + +QVariant ValueMap::value(const QString& name) const +{ + QReadLocker locker(&m_mutex); + if (m_map.contains(name)) + return m_map[name].first; + return QVariant(); +} + +void ValueMap::setValue(const QString& name, const QVariant& value) +{ + QWriteLocker locker(&m_mutex); + m_map[name].first = value; +} + +void ValueMap::unsetValue(const QString& name) +{ + QWriteLocker locker(&m_mutex); + m_map.remove(name); +} + +ConfigOptions ValueMap::options(const QString& name) const +{ + QReadLocker locker(&m_mutex); + if (m_map.contains(name)) + return m_map[name].second; + return 0; +} + +void ValueMap::setOptions(const QString& name, const ConfigOptions options) +{ + QWriteLocker locker(&m_mutex); + m_map[name].second |= options; +} + +void ValueMap::unsetOptions(const QString& name, const ConfigOptions options) +{ + QWriteLocker locker(&m_mutex); + m_map[name].second &= ~options; +} -- cgit