forked from organicmaps/organicmaps
Review fixes.
This commit is contained in:
parent
a1f4ac5953
commit
0ddbe71640
4 changed files with 29 additions and 13 deletions
|
@ -29,7 +29,7 @@ public:
|
|||
{
|
||||
m_root = std::move(rhs.m_root);
|
||||
m_numNodes = rhs.m_numNodes;
|
||||
rhs.m_numNodes = 1;
|
||||
rhs.Clear();
|
||||
return *this;
|
||||
}
|
||||
|
||||
|
@ -103,6 +103,12 @@ public:
|
|||
ForEachInSubtree(*root, prefix, std::forward<ToDo>(toDo));
|
||||
}
|
||||
|
||||
void Clear()
|
||||
{
|
||||
m_root.Clear();
|
||||
m_numNodes = 1;
|
||||
}
|
||||
|
||||
size_t GetNumNodes() const { return m_numNodes; }
|
||||
Iterator GetRootIterator() const { return Iterator(m_root); }
|
||||
Node const & GetRoot() const { return m_root; }
|
||||
|
@ -134,6 +140,12 @@ private:
|
|||
|
||||
void AddValue(Value const & value) { m_values.push_back(value); }
|
||||
|
||||
void Clear()
|
||||
{
|
||||
m_moves.clear();
|
||||
m_values.clear();
|
||||
}
|
||||
|
||||
std::map<Char, std::unique_ptr<Node>> m_moves;
|
||||
std::vector<Value> m_values;
|
||||
|
||||
|
|
|
@ -69,7 +69,7 @@ bool ParseEmoji(CategoriesHolder::Category::Name & name)
|
|||
return false;
|
||||
}
|
||||
|
||||
name.m_name = ToUtf8(UniString(1, static_cast<UniChar>(c)));
|
||||
name.m_name = ToUtf8(UniString(1 /* numChars */, static_cast<UniChar>(c)));
|
||||
|
||||
if (IsASCIIString(ToUtf8(search::NormalizeAndSimplifyString(name.m_name))))
|
||||
{
|
||||
|
@ -215,7 +215,7 @@ void CategoriesHolder::AddCategory(Category & cat, vector<uint32_t> & types)
|
|||
if (!ValidKeyToken(token))
|
||||
continue;
|
||||
for (uint32_t const t : types)
|
||||
m_name2type->Add(localePrefix + token, t);
|
||||
m_name2type.Add(localePrefix + token, t);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -242,7 +242,7 @@ bool CategoriesHolder::ValidKeyToken(String const & s)
|
|||
void CategoriesHolder::LoadFromStream(istream & s)
|
||||
{
|
||||
m_type2cat.clear();
|
||||
m_name2type = make_unique<Trie>();
|
||||
m_name2type.Clear();
|
||||
m_groupTranslations.clear();
|
||||
|
||||
State state = EParseTypes;
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
#include "base/stl_helpers.hpp"
|
||||
#include "base/string_utils.hpp"
|
||||
|
||||
#include "std/algorithm.hpp"
|
||||
#include "std/deque.hpp"
|
||||
#include "std/iostream.hpp"
|
||||
#include "std/map.hpp"
|
||||
|
@ -57,7 +58,7 @@ private:
|
|||
|
||||
// Maps locale and category token to the list of corresponding types.
|
||||
// Locale is treated as a special symbol prepended to the token.
|
||||
unique_ptr<Trie> m_name2type;
|
||||
Trie m_name2type;
|
||||
|
||||
GroupTranslations m_groupTranslations;
|
||||
|
||||
|
@ -111,7 +112,7 @@ public:
|
|||
void ForEachTypeByName(int8_t locale, String const & name, ToDo && toDo) const
|
||||
{
|
||||
auto const localePrefix = String(1, static_cast<strings::UniChar>(locale));
|
||||
m_name2type->ForEachInNode(localePrefix + name,
|
||||
m_name2type.ForEachInNode(localePrefix + name,
|
||||
my::MakeIgnoreFirstArgument(forward<ToDo>(toDo)));
|
||||
}
|
||||
|
||||
|
@ -126,13 +127,13 @@ public:
|
|||
string GetReadableFeatureType(uint32_t type, int8_t locale) const;
|
||||
|
||||
// Exposes the tries that map category tokens to types.
|
||||
Trie const & GetNameToTypesTrie() const { return *m_name2type; }
|
||||
Trie const & GetNameToTypesTrie() const { return m_name2type; }
|
||||
bool IsTypeExist(uint32_t type) const;
|
||||
|
||||
inline void Swap(CategoriesHolder & r)
|
||||
{
|
||||
m_type2cat.swap(r.m_type2cat);
|
||||
m_name2type.swap(r.m_name2type);
|
||||
std::swap(m_name2type, r.m_name2type);
|
||||
}
|
||||
|
||||
// Converts any language |locale| from UI to the corresponding
|
||||
|
|
|
@ -15,7 +15,7 @@
|
|||
#include <cctype>
|
||||
#include <functional>
|
||||
#include <queue>
|
||||
#include <set>
|
||||
#include <vector>
|
||||
|
||||
namespace search
|
||||
{
|
||||
|
@ -102,16 +102,19 @@ void ForEachCategoryTypeFuzzy(StringSliceBase const & slice, TLocales const & lo
|
|||
|
||||
auto const & trie = categories.GetNameToTypesTrie();
|
||||
auto const & trieRootIt = trie.GetRootIterator();
|
||||
std::set<int8_t> localeSet(locales.begin(), locales.end());
|
||||
vector<int8_t> sortedLocales(locales.begin(), locales.end());
|
||||
my::SortUnique(sortedLocales);
|
||||
|
||||
for (size_t i = 0; i < slice.Size(); ++i)
|
||||
{
|
||||
auto const & token = slice.Get(i);
|
||||
auto const & dfa =
|
||||
strings::LevenshteinDFA(token, 1 /* prefixCharsToKeep */, GetMaxErrorsForToken(token));
|
||||
// todo(@m, @y). We build dfa twice for each token: here and in geocoder.cpp.
|
||||
// A possible optimization is to build each dfa once and save it. Note that
|
||||
// dfas for the prefix tokens differ, i.e. we ignore slice.IsPrefix(i) here.
|
||||
strings::LevenshteinDFA const dfa(token, 1 /* prefixCharsToKeep */, GetMaxErrorsForToken(token));
|
||||
|
||||
trieRootIt.ForEachMove([&](Trie::Char const & c, Trie::Iterator const & moveIt) {
|
||||
if (localeSet.count(static_cast<int8_t>(c)) != 0)
|
||||
if (std::binary_search(sortedLocales.begin(), sortedLocales.end(), static_cast<int8_t>(c)))
|
||||
{
|
||||
MatchInTrie(trie /* passed to infer the iterator's type */, moveIt, dfa,
|
||||
std::bind<void>(todo, i, std::placeholders::_1));
|
||||
|
|
Loading…
Add table
Reference in a new issue