123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- /*
- ==============================================================================
- This file is part of the JUCE library.
- Copyright (c) 2017 - ROLI Ltd.
- JUCE is an open source library subject to commercial or open-source
- licensing.
- The code included in this file is provided under the terms of the ISC license
- http://www.isc.org/downloads/software-support-policy/isc-license. Permission
- To use, copy, modify, and/or distribute this software for any purpose with or
- without fee is hereby granted provided that the above copyright notice and
- this permission notice appear in all copies.
- JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
- EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
- DISCLAIMED.
- ==============================================================================
- */
- namespace juce
- {
- StringPairArray::StringPairArray (bool shouldIgnoreCase) : ignoreCase (shouldIgnoreCase)
- {
- }
- StringPairArray::StringPairArray (const StringPairArray& other)
- : keys (other.keys),
- values (other.values),
- ignoreCase (other.ignoreCase)
- {
- }
- StringPairArray::~StringPairArray()
- {
- }
- StringPairArray& StringPairArray::operator= (const StringPairArray& other)
- {
- keys = other.keys;
- values = other.values;
- return *this;
- }
- bool StringPairArray::operator== (const StringPairArray& other) const
- {
- auto num = size();
- if (num != other.size())
- return false;
- for (int i = 0; i < num; ++i)
- {
- if (keys[i] == other.keys[i]) // optimise for the case where the keys are in the same order
- {
- if (values[i] != other.values[i])
- return false;
- }
- else
- {
- // if we encounter keys that are in a different order, search remaining items by brute force..
- for (int j = i; j < num; ++j)
- {
- auto otherIndex = other.keys.indexOf (keys[j], other.ignoreCase);
- if (otherIndex < 0 || values[j] != other.values[otherIndex])
- return false;
- }
- return true;
- }
- }
- return true;
- }
- bool StringPairArray::operator!= (const StringPairArray& other) const
- {
- return ! operator== (other);
- }
- const String& StringPairArray::operator[] (StringRef key) const
- {
- return values[keys.indexOf (key, ignoreCase)];
- }
- String StringPairArray::getValue (StringRef key, const String& defaultReturnValue) const
- {
- auto i = keys.indexOf (key, ignoreCase);
- if (i >= 0)
- return values[i];
- return defaultReturnValue;
- }
- bool StringPairArray::containsKey (StringRef key) const noexcept
- {
- return keys.contains (key, ignoreCase);
- }
- void StringPairArray::set (const String& key, const String& value)
- {
- auto i = keys.indexOf (key, ignoreCase);
- if (i >= 0)
- {
- values.set (i, value);
- }
- else
- {
- keys.add (key);
- values.add (value);
- }
- }
- void StringPairArray::addArray (const StringPairArray& other)
- {
- for (int i = 0; i < other.size(); ++i)
- set (other.keys[i], other.values[i]);
- }
- void StringPairArray::clear()
- {
- keys.clear();
- values.clear();
- }
- void StringPairArray::remove (StringRef key)
- {
- remove (keys.indexOf (key, ignoreCase));
- }
- void StringPairArray::remove (int index)
- {
- keys.remove (index);
- values.remove (index);
- }
- void StringPairArray::setIgnoresCase (bool shouldIgnoreCase)
- {
- ignoreCase = shouldIgnoreCase;
- }
- String StringPairArray::getDescription() const
- {
- String s;
- for (int i = 0; i < keys.size(); ++i)
- {
- s << keys[i] << " = " << values[i];
- if (i < keys.size())
- s << ", ";
- }
- return s;
- }
- void StringPairArray::minimiseStorageOverheads()
- {
- keys.minimiseStorageOverheads();
- values.minimiseStorageOverheads();
- }
- } // namespace juce
|