2010-08-18 18:45:44 +02:00
|
|
|
#ifndef COMPONENTS_TOUTF8_H
|
|
|
|
#define COMPONENTS_TOUTF8_H
|
|
|
|
|
|
|
|
#include <string>
|
2013-01-02 23:02:13 +01:00
|
|
|
#include <cstring>
|
|
|
|
#include <vector>
|
2010-08-18 18:45:44 +02:00
|
|
|
|
|
|
|
namespace ToUTF8
|
|
|
|
{
|
2013-01-02 23:02:13 +01:00
|
|
|
// These are all the currently supported code pages
|
|
|
|
enum FromType
|
2010-08-18 18:45:44 +02:00
|
|
|
{
|
2013-01-02 23:02:13 +01:00
|
|
|
WINDOWS_1250, // Central ane Eastern European languages
|
|
|
|
WINDOWS_1251, // Cyrillic languages
|
2013-06-06 22:13:30 +02:00
|
|
|
WINDOWS_1252, // Used by English version of Morrowind (and
|
2013-01-02 23:02:13 +01:00
|
|
|
// probably others)
|
2013-06-06 22:13:30 +02:00
|
|
|
CP437 // Used for fonts (*.fnt) if data files encoding is 1252. Otherwise, uses the same encoding as the data files.
|
2010-08-18 18:45:44 +02:00
|
|
|
};
|
|
|
|
|
2013-01-02 23:02:13 +01:00
|
|
|
FromType calculateEncoding(const std::string& encodingName);
|
|
|
|
std::string encodingUsingMessage(const std::string& encodingName);
|
|
|
|
|
|
|
|
// class
|
|
|
|
|
|
|
|
class Utf8Encoder
|
|
|
|
{
|
|
|
|
public:
|
2013-01-06 01:37:58 +01:00
|
|
|
Utf8Encoder(FromType sourceEncoding);
|
2013-01-02 23:02:13 +01:00
|
|
|
|
|
|
|
// Convert to UTF8 from the previously given code page.
|
2013-02-14 21:38:27 -08:00
|
|
|
std::string getUtf8(const char *input, size_t size);
|
2013-01-02 23:02:13 +01:00
|
|
|
inline std::string getUtf8(const std::string &str)
|
|
|
|
{
|
|
|
|
return getUtf8(str.c_str(), str.size());
|
|
|
|
}
|
|
|
|
|
2013-02-14 21:38:27 -08:00
|
|
|
std::string getLegacyEnc(const char *input, size_t size);
|
2013-01-02 23:02:13 +01:00
|
|
|
inline std::string getLegacyEnc(const std::string &str)
|
|
|
|
{
|
|
|
|
return getLegacyEnc(str.c_str(), str.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
void resize(size_t size);
|
|
|
|
size_t getLength(const char* input, bool &ascii);
|
|
|
|
void copyFromArray(unsigned char chp, char* &out);
|
|
|
|
size_t getLength2(const char* input, bool &ascii);
|
|
|
|
void copyFromArray2(const char*& chp, char* &out);
|
|
|
|
|
|
|
|
std::vector<char> mOutput;
|
2013-02-02 10:17:20 -05:00
|
|
|
signed char* translationArray;
|
2013-01-02 23:02:13 +01:00
|
|
|
};
|
2010-08-18 18:45:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|