480fb7b931
In an attempt to reduce the size of Util.{c,h}pp which has grown to contain all sorts of unrelated helpers, we move StringVector helpers into the StringVector.{c,h}pp files. This makes the code better organized. Change-Id: I152f341606807ae66253415b951bc9f89b09df57 Signed-off-by: Ashod Nakashian <ashod.nakashian@collabora.co.uk>
128 lines
3.5 KiB
C++
128 lines
3.5 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
|
|
/*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
*/
|
|
|
|
#include "StringVector.hpp"
|
|
|
|
#include "Util.hpp"
|
|
|
|
bool StringVector::equals(std::size_t index, const StringVector& other, std::size_t otherIndex)
|
|
{
|
|
if (index >= _tokens.size())
|
|
{
|
|
return false;
|
|
}
|
|
|
|
if (otherIndex >= other._tokens.size())
|
|
{
|
|
return false;
|
|
}
|
|
|
|
const StringToken& token = _tokens[index];
|
|
const StringToken& otherToken = other._tokens[otherIndex];
|
|
int ret = _string.compare(token._index, token._length, other._string, otherToken._index,
|
|
otherToken._length);
|
|
return ret == 0;
|
|
}
|
|
|
|
bool StringVector::getUInt32(std::size_t index, const std::string& key, uint32_t& value) const
|
|
{
|
|
if (index >= _tokens.size())
|
|
{
|
|
return false;
|
|
}
|
|
|
|
const StringToken& token = _tokens[index];
|
|
|
|
size_t offset = key.size() + 1;
|
|
if (token._length > offset &&
|
|
_string.compare(token._index, key.size(), key, 0, key.size()) == 0 &&
|
|
_string[token._index + key.size()] == '=')
|
|
{
|
|
value = Util::safe_atoi(&_string[token._index + offset], token._length - offset);
|
|
return value < std::numeric_limits<uint32_t>::max();
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
bool StringVector::getNameIntegerPair(std::size_t index, std::string& name, int& value) const
|
|
{
|
|
if (index >= _tokens.size())
|
|
{
|
|
return false;
|
|
}
|
|
|
|
const StringToken& token = _tokens[index];
|
|
size_t mid = std::string::npos;
|
|
for (size_t i = token._index; i < token._index + token._length; ++i)
|
|
{
|
|
if (_string[i] != '=')
|
|
{
|
|
continue;
|
|
}
|
|
|
|
mid = i;
|
|
break;
|
|
}
|
|
if (mid == std::string::npos)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
name = _string.substr(token._index, mid - token._index);
|
|
size_t offset = mid + 1;
|
|
value = Util::safe_atoi(&_string[offset], token._index + token._length - offset);
|
|
return value > std::numeric_limits<int>::min() && value < std::numeric_limits<int>::max();
|
|
}
|
|
|
|
StringVector StringVector::tokenizeAnyOf(const std::string& s, const char* delimiters,
|
|
const std::size_t delimitersLength)
|
|
{
|
|
// trim from the end so that we do not have to check this exact case
|
|
// later
|
|
std::size_t length = s.length();
|
|
while (length > 0 && s[length - 1] == ' ')
|
|
--length;
|
|
|
|
if (length == 0 || delimiters == nullptr || delimitersLength == 0)
|
|
return StringVector();
|
|
|
|
std::size_t start = 0;
|
|
|
|
std::vector<StringToken> tokens;
|
|
tokens.reserve(16);
|
|
|
|
while (start < length)
|
|
{
|
|
// ignore the leading whitespace
|
|
while (start < length && s[start] == ' ')
|
|
++start;
|
|
|
|
// anything left?
|
|
if (start == length)
|
|
break;
|
|
|
|
std::size_t end = s.find_first_of(delimiters, start, delimitersLength);
|
|
if (end == std::string::npos)
|
|
end = length;
|
|
|
|
// trim the trailing whitespace
|
|
std::size_t trimEnd = end;
|
|
while (start < trimEnd && s[trimEnd - 1] == ' ')
|
|
--trimEnd;
|
|
|
|
// add only non-empty tokens
|
|
if (start < trimEnd)
|
|
tokens.emplace_back(start, trimEnd - start);
|
|
|
|
start = end + 1;
|
|
}
|
|
|
|
return StringVector(s, std::move(tokens));
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|