forked from organicmaps/organicmaps-tmp
[downloader] Fix behavior for absent description
This commit is contained in:
parent
81edaa14e2
commit
c294c3c212
3 changed files with 15 additions and 5 deletions
|
@ -15,14 +15,19 @@ void CountryNameGetter::SetLocaleForTesting(string const & jsonBuffer, string co
|
|||
m_getCurLang = platform::ForTestingGetTextByIdFactory(jsonBuffer, locale);
|
||||
}
|
||||
|
||||
string CountryNameGetter::operator()(TCountryId const & countryId) const
|
||||
string CountryNameGetter::Get(string const & key) const
|
||||
{
|
||||
ASSERT(!countryId.empty(), ());
|
||||
ASSERT(!key.empty(), ());
|
||||
|
||||
if (m_getCurLang == nullptr)
|
||||
return countryId;
|
||||
return string();
|
||||
|
||||
string name = (*m_getCurLang)(countryId);
|
||||
return (*m_getCurLang)(key);
|
||||
}
|
||||
|
||||
string CountryNameGetter::operator()(TCountryId const & countryId) const
|
||||
{
|
||||
string const name = Get(countryId);
|
||||
if (name.empty())
|
||||
return countryId;
|
||||
|
||||
|
|
|
@ -27,6 +27,11 @@ public:
|
|||
/// \note See countries/languages.txt for the full list of available locales.
|
||||
void SetLocale(string const & locale);
|
||||
|
||||
/// \brief Gets localized string for key. If not found returns empty string.
|
||||
/// @param key is a string for lookup.
|
||||
/// \note Unlike operator (), does not return key if localized string is not found.
|
||||
string Get(string const & key) const;
|
||||
|
||||
string operator()(TCountryId const & countryId) const;
|
||||
|
||||
// for testing
|
||||
|
|
|
@ -1332,7 +1332,7 @@ void Storage::GetNodeAttrs(TCountryId const & countryId, NodeAttrs & nodeAttrs)
|
|||
nodeAttrs.m_status = statusAndErr.status;
|
||||
nodeAttrs.m_error = statusAndErr.error;
|
||||
nodeAttrs.m_nodeLocalName = m_countryNameGetter(countryId);
|
||||
nodeAttrs.m_nodeLocalDescription = m_countryNameGetter(countryId + LOCALIZATION_DESCRIPTION_SUFFIX);
|
||||
nodeAttrs.m_nodeLocalDescription = m_countryNameGetter.Get(countryId + LOCALIZATION_DESCRIPTION_SUFFIX);
|
||||
|
||||
// Progress.
|
||||
if (nodeAttrs.m_status == NodeStatus::OnDisk)
|
||||
|
|
Loading…
Add table
Reference in a new issue