Compare commits

..

3 Commits

3 changed files with 30 additions and 25 deletions

View File

@ -7,14 +7,13 @@
#include <etranslate/debug.hpp> #include <etranslate/debug.hpp>
#include <etranslate/etranslate.hpp> #include <etranslate/etranslate.hpp>
#include <etk/Map.hpp> #include <etk/Map.hpp>
#include <etk/os/FSNode.hpp>
#include <ejson/ejson.hpp> #include <ejson/ejson.hpp>
#include <locale.h> #include <locale.h>
class LocalInstanceTranslation { class LocalInstanceTranslation {
private: private:
etk::Map<etk::String,etk::String> m_listPath; etk::Map<etk::String,etk::Uri> m_listPath;
etk::String m_major; etk::String m_major;
etk::String m_languageDefault; etk::String m_languageDefault;
etk::String m_language; etk::String m_language;
@ -29,8 +28,8 @@ class LocalInstanceTranslation {
// nothing to do ... // nothing to do ...
} }
public: public:
void addPath(const etk::String& _lib, const etk::String& _path, bool _major) { void addPath(const etk::String& _lib, const etk::Uri& _uri, bool _major) {
m_listPath.set(_lib, _path); m_listPath.set(_lib, _uri);
if (_major == true) { if (_major == true) {
m_major = _lib; m_major = _lib;
ETRANSLATE_INFO("Change major translation : '" << m_major << "'"); ETRANSLATE_INFO("Change major translation : '" << m_major << "'");
@ -39,10 +38,10 @@ class LocalInstanceTranslation {
m_translate.clear(); m_translate.clear();
}; };
const etk::String& getPaths(const etk::String& _lib) { const etk::Uri& getPaths(const etk::String& _lib) {
auto it = m_listPath.find(_lib); auto it = m_listPath.find(_lib);
if (it == m_listPath.end()) { if (it == m_listPath.end()) {
static const etk::String g_error(""); static const etk::Uri g_error("");
return g_error; return g_error;
} }
return it->second; return it->second;
@ -142,19 +141,21 @@ class LocalInstanceTranslation {
if (m_translateLoadad == true) { if (m_translateLoadad == true) {
return; return;
} }
ETRANSLATE_VERBOSE("Load Translation MAJOR='" << m_major << "' LANG='" << m_language << "' default=" << m_languageDefault ); ETRANSLATE_DEBUG("Load Translation MAJOR='" << m_major << "' LANG='" << m_language << "' default=" << m_languageDefault );
ETRANSLATE_DEBUG("list path=" << m_listPath.getKeys() );
// start parse language for Major: // start parse language for Major:
auto itMajor = m_listPath.find(m_major); auto itMajor = m_listPath.find(m_major);
if (itMajor != m_listPath.end()) { if (itMajor != m_listPath.end()) {
etk::String filename(itMajor->second + "/" + m_language + ".json"); etk::Uri uri = itMajor->second;
uri.setPath(itMajor->second.getPath() / m_language + ".json");
ejson::Document doc; ejson::Document doc;
doc.load(filename); doc.load(uri);
for (auto element : doc.getKeys()) { for (auto element : doc.getKeys()) {
etk::String val = doc[element].toString().get(); etk::String val = doc[element].toString().get();
m_translate.set(element, val); m_translate.set(element, val);
} }
filename = itMajor->second + "/" + m_languageDefault + ".json"; uri.setPath(itMajor->second.getPath() / m_languageDefault + ".json");
doc.load(filename); doc.load(uri);
for (auto element : doc.getKeys()) { for (auto element : doc.getKeys()) {
etk::String val = doc[element].toString().get(); etk::String val = doc[element].toString().get();
m_translate.set(element, val); m_translate.set(element, val);
@ -165,12 +166,13 @@ class LocalInstanceTranslation {
if (it.first == m_major) { if (it.first == m_major) {
continue; continue;
} }
etk::String filename(it.second + "/" + m_languageDefault + ".json"); etk::Uri uri = it.second;
if (etk::FSNodeExist(filename) == false) { uri.setPath(it.second.getPath() / m_languageDefault + ".json");
if (etk::uri::exist(uri) == false) {
continue; continue;
} }
ejson::Document doc; ejson::Document doc;
doc.load(filename); doc.load(uri);
for (auto element : doc.getKeys()) { for (auto element : doc.getKeys()) {
etk::String val = doc[element].toString().get(); etk::String val = doc[element].toString().get();
m_translate.set(element, val); m_translate.set(element, val);
@ -181,17 +183,19 @@ class LocalInstanceTranslation {
if (it.first == m_major) { if (it.first == m_major) {
continue; continue;
} }
etk::String filename(it.second + "/" + m_languageDefault + ".json"); etk::Uri uri = it.second;
if (etk::FSNodeExist(filename) == false) { uri.setPath(it.second.getPath() / m_languageDefault + ".json");
if (etk::uri::exist(uri) == false) {
continue; continue;
} }
ejson::Document doc; ejson::Document doc;
doc.load(filename); doc.load(uri);
for (auto element : doc.getKeys()) { for (auto element : doc.getKeys()) {
etk::String val = doc[element].toString().get(); etk::String val = doc[element].toString().get();
m_translate.set(element, val); m_translate.set(element, val);
} }
} }
m_translateLoadad = true;
} }
}; };
@ -234,14 +238,14 @@ void etranslate::unInit() {
ETRANSLATE_ERROR("E-translate system un-init (already done before)"); ETRANSLATE_ERROR("E-translate system un-init (already done before)");
} }
void etranslate::addPath(const etk::String& _lib, const etk::String& _path, bool _major) { void etranslate::addPath(const etk::String& _lib, const etk::Uri& _uri, bool _major) {
if (g_isInit <= 0) { if (g_isInit <= 0) {
ETRANSLATE_ERROR("E-translate system has not been init"); ETRANSLATE_ERROR("E-translate system has not been init");
} }
getInstanceTranslation().addPath(_lib, _path, _major); getInstanceTranslation().addPath(_lib, _uri, _major);
} }
const etk::String& etranslate::getPaths(const etk::String& _lib) { const etk::Uri& etranslate::getPaths(const etk::String& _lib) {
if (g_isInit <= 0) { if (g_isInit <= 0) {
ETRANSLATE_ERROR("E-translate system has not been init"); ETRANSLATE_ERROR("E-translate system has not been init");
} }

View File

@ -6,6 +6,7 @@
#pragma once #pragma once
#include <etk/types.hpp> #include <etk/types.hpp>
#include <etk/uri/uri.hpp>
/** /**
* @brief This is a simple interface to converte application display string in a generic current system language * @brief This is a simple interface to converte application display string in a generic current system language
@ -36,16 +37,16 @@ namespace etranslate {
/** /**
* @brief Set the path folder of the translation files * @brief Set the path folder of the translation files
* @param[in] _lib Library name that the path depend * @param[in] _lib Library name that the path depend
* @param[in] _path ETK generic path (DATA:... or /xxx) * @param[in] _uri ETK generic uri (DATA:... or /xxx)
* @param[in] _major This path is the major path (The last loaded, the one which overload all) * @param[in] _major This path is the major path (The last loaded, the one which overload all)
*/ */
void addPath(const etk::String& _lib, const etk::String& _path, bool _major = false); void addPath(const etk::String& _lib, const etk::Uri& _uri, bool _major = false);
/** /**
* @brief Get the current paths of the library * @brief Get the current paths of the library
* @param[in] _lib Library name that the path depend * @param[in] _lib Library name that the path depend
* @return Path name. * @return Uri value.
*/ */
const etk::String& getPaths(const etk::String& _lib); const etk::Uri& getPaths(const etk::String& _lib);
/** /**
* @brief Set the default language to load data (the default language might contain all internal data for the basic application) * @brief Set the default language to load data (the default language might contain all internal data for the basic application)
* @param[in] _lang Language to load : ("EN" for english, "FR" for french, "DE" for German, "SP" for spanish ...) * @param[in] _lang Language to load : ("EN" for english, "FR" for french, "DE" for German, "SP" for spanish ...)

View File

@ -1,5 +1,5 @@
#!/usr/bin/python #!/usr/bin/python
import lutin.debug as debug import realog.debug as debug
import lutin.tools as tools import lutin.tools as tools