|
- /*
- ==============================================================================
-
- This file is part of the JUCE library - "Jules' Utility Class Extensions"
- Copyright 2004-11 by Raw Material Software Ltd.
-
- ------------------------------------------------------------------------------
-
- JUCE can be redistributed and/or modified under the terms of the GNU General
- Public License (Version 2), as published by the Free Software Foundation.
- A copy of the license is included in the JUCE distribution, or can be found
- online at www.gnu.org/licenses.
-
- JUCE 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.
-
- ------------------------------------------------------------------------------
-
- To release a closed-source product which uses JUCE, commercial licenses are
- available: visit www.rawmaterialsoftware.com/juce for more information.
-
- ==============================================================================
- */
-
- BEGIN_JUCE_NAMESPACE
-
- //==============================================================================
- NamedValueSet::NamedValue::NamedValue() noexcept
- {
- }
-
- inline NamedValueSet::NamedValue::NamedValue (const Identifier& name_, const var& value_)
- : name (name_), value (value_)
- {
- }
-
- NamedValueSet::NamedValue::NamedValue (const NamedValue& other)
- : name (other.name), value (other.value)
- {
- }
-
- NamedValueSet::NamedValue& NamedValueSet::NamedValue::operator= (const NamedValueSet::NamedValue& other)
- {
- name = other.name;
- value = other.value;
- return *this;
- }
-
- #if JUCE_COMPILER_SUPPORTS_MOVE_SEMANTICS
- NamedValueSet::NamedValue::NamedValue (NamedValue&& other) noexcept
- : nextListItem (static_cast <LinkedListPointer<NamedValue>&&> (other.nextListItem)),
- name (static_cast <Identifier&&> (other.name)),
- value (static_cast <var&&> (other.value))
- {
- }
-
- inline NamedValueSet::NamedValue::NamedValue (const Identifier& name_, var&& value_)
- : name (name_), value (static_cast <var&&> (value_))
- {
- }
-
- NamedValueSet::NamedValue& NamedValueSet::NamedValue::operator= (NamedValue&& other) noexcept
- {
- nextListItem = static_cast <LinkedListPointer<NamedValue>&&> (other.nextListItem);
- name = static_cast <Identifier&&> (other.name);
- value = static_cast <var&&> (other.value);
- return *this;
- }
- #endif
-
- bool NamedValueSet::NamedValue::operator== (const NamedValueSet::NamedValue& other) const noexcept
- {
- return name == other.name && value == other.value;
- }
-
- //==============================================================================
- NamedValueSet::NamedValueSet() noexcept
- {
- }
-
- NamedValueSet::NamedValueSet (const NamedValueSet& other)
- {
- values.addCopyOfList (other.values);
- }
-
- NamedValueSet& NamedValueSet::operator= (const NamedValueSet& other)
- {
- clear();
- values.addCopyOfList (other.values);
- return *this;
- }
-
- #if JUCE_COMPILER_SUPPORTS_MOVE_SEMANTICS
- NamedValueSet::NamedValueSet (NamedValueSet&& other) noexcept
- : values (static_cast <LinkedListPointer<NamedValue>&&> (other.values))
- {
- }
-
- NamedValueSet& NamedValueSet::operator= (NamedValueSet&& other) noexcept
- {
- other.values.swapWith (values);
- return *this;
- }
- #endif
-
- NamedValueSet::~NamedValueSet()
- {
- clear();
- }
-
- void NamedValueSet::clear()
- {
- values.deleteAll();
- }
-
- bool NamedValueSet::operator== (const NamedValueSet& other) const
- {
- const NamedValue* i1 = values;
- const NamedValue* i2 = other.values;
-
- while (i1 != nullptr && i2 != nullptr)
- {
- if (! (*i1 == *i2))
- return false;
-
- i1 = i1->nextListItem;
- i2 = i2->nextListItem;
- }
-
- return true;
- }
-
- bool NamedValueSet::operator!= (const NamedValueSet& other) const
- {
- return ! operator== (other);
- }
-
- int NamedValueSet::size() const noexcept
- {
- return values.size();
- }
-
- const var& NamedValueSet::operator[] (const Identifier& name) const
- {
- for (NamedValue* i = values; i != nullptr; i = i->nextListItem)
- if (i->name == name)
- return i->value;
-
- return var::null;
- }
-
- var NamedValueSet::getWithDefault (const Identifier& name, const var& defaultReturnValue) const
- {
- const var* const v = getVarPointer (name);
- return v != nullptr ? *v : defaultReturnValue;
- }
-
- var* NamedValueSet::getVarPointer (const Identifier& name) const noexcept
- {
- for (NamedValue* i = values; i != nullptr; i = i->nextListItem)
- if (i->name == name)
- return &(i->value);
-
- return nullptr;
- }
-
- #if JUCE_COMPILER_SUPPORTS_MOVE_SEMANTICS
- bool NamedValueSet::set (const Identifier& name, var&& newValue)
- {
- LinkedListPointer<NamedValue>* i = &values;
-
- while (i->get() != nullptr)
- {
- NamedValue* const v = i->get();
-
- if (v->name == name)
- {
- if (v->value.equalsWithSameType (newValue))
- return false;
-
- v->value = static_cast <var&&> (newValue);
- return true;
- }
-
- i = &(v->nextListItem);
- }
-
- i->insertNext (new NamedValue (name, static_cast <var&&> (newValue)));
- return true;
- }
- #endif
-
- bool NamedValueSet::set (const Identifier& name, const var& newValue)
- {
- LinkedListPointer<NamedValue>* i = &values;
-
- while (i->get() != nullptr)
- {
- NamedValue* const v = i->get();
-
- if (v->name == name)
- {
- if (v->value.equalsWithSameType (newValue))
- return false;
-
- v->value = newValue;
- return true;
- }
-
- i = &(v->nextListItem);
- }
-
- i->insertNext (new NamedValue (name, newValue));
- return true;
- }
-
- bool NamedValueSet::contains (const Identifier& name) const
- {
- return getVarPointer (name) != nullptr;
- }
-
- bool NamedValueSet::remove (const Identifier& name)
- {
- LinkedListPointer<NamedValue>* i = &values;
-
- for (;;)
- {
- NamedValue* const v = i->get();
-
- if (v == nullptr)
- break;
-
- if (v->name == name)
- {
- delete i->removeNext();
- return true;
- }
-
- i = &(v->nextListItem);
- }
-
- return false;
- }
-
- const Identifier NamedValueSet::getName (const int index) const
- {
- const NamedValue* const v = values[index];
- jassert (v != nullptr);
- return v->name;
- }
-
- const var& NamedValueSet::getValueAt (const int index) const
- {
- const NamedValue* const v = values[index];
- jassert (v != nullptr);
- return v->value;
- }
-
- void NamedValueSet::setFromXmlAttributes (const XmlElement& xml)
- {
- clear();
- LinkedListPointer<NamedValue>::Appender appender (values);
-
- const int numAtts = xml.getNumAttributes(); // xxx inefficient - should write an att iterator..
-
- for (int i = 0; i < numAtts; ++i)
- appender.append (new NamedValue (xml.getAttributeName (i), var (xml.getAttributeValue (i))));
- }
-
- void NamedValueSet::copyToXmlAttributes (XmlElement& xml) const
- {
- for (NamedValue* i = values; i != nullptr; i = i->nextListItem)
- {
- jassert (! i->value.isObject()); // DynamicObjects can't be stored as XML!
-
- xml.setAttribute (i->name.toString(),
- i->value.toString());
- }
- }
-
-
- END_JUCE_NAMESPACE
|