-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
-
-// File: Config_Translator.cpp
-// Created: 31 May 2016
-// Author: Vitaly SMETANNIKOV
+// Copyright (C) 2014-2021 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
#include "Config_Translator.h"
#include "Config_XMLReader.h"
#include <fstream>
#include <ostream>
+#ifdef WIN32
+#pragma warning(disable : 4996) // for sprintf
+#endif
+
+// LCOV_EXCL_START
+/**
+ * \class Config_TSReader
+ * \ingroup Config
+ * \brief Class for reading translations from TS files (an XML format).
+ */
class Config_TSReader : public Config_XMLReader
{
public:
+ /// Constructor
+ /// \param theTSFile name of TS file
Config_TSReader(const std::string& theTSFile) : Config_XMLReader(theTSFile) {}
+ /// Returns content of TS file
const Config_Translator::Translator& translator() const { return myTranslator; }
+ /// Returns codecs defined in TS files
+ const Config_Translator::Dictionary& codecs() const { return myCodecs; }
+
protected:
/// Overloaded method. Defines how to process each node
virtual void processNode(xmlNodePtr theNode);
private:
Config_Translator::Translator myTranslator;
+ Config_Translator::Dictionary myCodecs;
};
void Config_TSReader::processNode(xmlNodePtr theNode)
aName = "";
} else if (isNode(theNode, "name", NULL)) {
aName = getContent(theNode);
+ myCodecs[aName] = encoding();
} else if (isNode(theNode, "message", NULL)) {
aSource = "";
} else if (isNode(theNode, "source", NULL)) {
//******************************************************************************
//******************************************************************************
Config_Translator::Translator Config_Translator::myTranslator;
+Config_Translator::Dictionary Config_Translator::myCodecs;
+
#ifdef _DEBUG
#ifdef MISSED_TRANSLATION
Config_Translator::Translator Config_Translator::myMissed;
}
}
+ const Dictionary aCodecs = aReader.codecs();
+ Dictionary::const_iterator aDictIt;
+ for (aDictIt = aCodecs.cbegin(); aDictIt != aCodecs.cend(); aDictIt++) {
+ myCodecs[aDictIt->first] = aDictIt->second;
+ }
return true;
}
+// LCOV_EXCL_STOP
-std::string Config_Translator::translate(std::shared_ptr<Events_InfoMessage> theInfo)
+std::string Config_Translator::translate(const Events_InfoMessage& theInfo)
{
- std::string aContext = theInfo->context();
- std::string aMessage = theInfo->message();
- std::list<std::string> aParameters = theInfo->parameters();
+ std::string aContext = theInfo.context();
+ std::string aMessage = theInfo.messageString();
+ std::list<std::string> aParameters = theInfo.parameters();
return translate(aContext, aMessage, aParameters);
}
-
std::string insertParameters(const std::string& theString, const std::list<std::string>& theParams)
{
std::string aResult = theString;
std::string aParam;
for (i=1, aIt = theParams.cbegin(); aIt != theParams.cend(); aIt++, i++) {
aParam = (*aIt);
- sprintf_s(aBuf, "%d", i);
+ sprintf(aBuf, "%d", i);
std::string aCode = std::string("%") + std::string(aBuf);
size_t aPos = aResult.find(aCode);
if (aPos != std::string::npos) {
}
std::string Config_Translator::translate(const std::string& theContext,
- const std::string& theMessage,
+ const std::string& theMessage,
const std::list<std::string>& theParams)
{
if (myTranslator.count(theContext) > 0) {
if (theParams.size() > 0) {
aTranslation = insertParameters(aTranslation, theParams);
}
- return aTranslation;
+ if (aTranslation.size() > 0)
+ return aTranslation;
}
}
std::string aMsg = theMessage;
return aMsg;
}
+// LCOV_EXCL_START
+std::string Config_Translator::codec(const std::string& theContext)
+{
+ return (myCodecs.count(theContext) > 0)? myCodecs[theContext] : "UTF-8";
+}
+
+std::string Config_Translator::codec(const Events_InfoMessage& theInfo)
+{
+ return codec(theInfo.context());
+}
+// LCOV_EXCL_STOP
+
#ifdef _DEBUG
#ifdef MISSED_TRANSLATION
void Config_Translator::saveMissedTranslations()
std::ofstream oFStream;
// Delete old file
- int aa = remove(aFile.c_str());
+ remove(aFile.c_str());
oFStream.open(aFile, std::ofstream::out | std::ofstream::app);
if (oFStream.is_open()) {