mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
86 lines
1.8 KiB
C++
86 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include <QString>
|
|
#include <functional>
|
|
#include <set>
|
|
#include <unordered_map>
|
|
|
|
namespace chatterino {
|
|
|
|
class Prefix
|
|
{
|
|
public:
|
|
Prefix(const QString &string);
|
|
bool operator==(const Prefix &other) const;
|
|
bool operator!=(const Prefix &other) const;
|
|
bool isStartOf(const QString &string) const;
|
|
|
|
private:
|
|
QChar first;
|
|
QChar second;
|
|
|
|
friend struct std::hash<Prefix>;
|
|
};
|
|
|
|
} // namespace chatterino
|
|
|
|
namespace std {
|
|
|
|
template <>
|
|
struct hash<chatterino::Prefix> {
|
|
size_t operator()(const chatterino::Prefix &prefix) const
|
|
{
|
|
return (size_t(prefix.first.unicode()) << 16) |
|
|
size_t(prefix.second.unicode());
|
|
}
|
|
};
|
|
|
|
} // namespace std
|
|
|
|
namespace chatterino {
|
|
|
|
struct CaseInsensitiveLess {
|
|
bool operator()(const QString &lhs, const QString &rhs) const
|
|
{
|
|
return lhs.compare(rhs, Qt::CaseInsensitive) < 0;
|
|
}
|
|
};
|
|
|
|
class UsernameSet
|
|
{
|
|
public:
|
|
static constexpr int PrefixLength = 2;
|
|
|
|
using Iterator = std::set<QString>::iterator;
|
|
using ConstIterator = std::set<QString>::const_iterator;
|
|
|
|
class Range
|
|
{
|
|
public:
|
|
Range(ConstIterator start, ConstIterator end);
|
|
|
|
ConstIterator begin();
|
|
ConstIterator end();
|
|
|
|
private:
|
|
ConstIterator start_;
|
|
ConstIterator end_;
|
|
};
|
|
|
|
ConstIterator begin() const;
|
|
ConstIterator end() const;
|
|
Range subrange(const Prefix &prefix) const;
|
|
|
|
std::set<QString>::size_type size() const;
|
|
|
|
std::pair<Iterator, bool> insert(const QString &value);
|
|
std::pair<Iterator, bool> insert(QString &&value);
|
|
|
|
private:
|
|
void insertPrefix(const QString &string);
|
|
|
|
std::set<QString, CaseInsensitiveLess> items;
|
|
std::unordered_map<Prefix, QString> firstKeyForPrefix;
|
|
};
|
|
|
|
} // namespace chatterino
|