Review fixes.

This commit is contained in:
Maxim Pimenov 2017-02-14 17:38:13 +03:00
parent a1f4ac5953
commit 0ddbe71640
4 changed files with 29 additions and 13 deletions

View file

@ -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;

View file

@ -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;

View file

@ -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

View file

@ -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));