summaryrefslogtreecommitdiff
path: root/src/charset.cpp
diff options
context:
space:
mode:
authorAndrzej Rybczak <electricityispower@gmail.com>2012-09-11 22:56:57 +0200
committerAndrzej Rybczak <electricityispower@gmail.com>2012-09-11 22:57:56 +0200
commita9bee35cca51c3a192477aa87ad03f2b75f726ed (patch)
treeb1991bae6449615e2dbe1549e4d8e47ce60b9098 /src/charset.cpp
parentc8097a898ef8ac1d0afb367bb6b368edd9cb558f (diff)
charset: put functions into namespace and change naming convention
Diffstat (limited to 'src/charset.cpp')
-rw-r--r--src/charset.cpp41
1 files changed, 14 insertions, 27 deletions
diff --git a/src/charset.cpp b/src/charset.cpp
index cfc7837f..0941419d 100644
--- a/src/charset.cpp
+++ b/src/charset.cpp
@@ -100,7 +100,9 @@ void charset_convert(const char *from, const char *to, const char *&inbuf,
}
-void iconv_convert_from_to(const char *from, const char *to, std::string &s)
+namespace IConv {//
+
+void convertFromTo(const char *from, const char *to, std::string &s)
{
const char *tmp = strdup(s.c_str());
charset_convert(from, to, tmp, true, s.length());
@@ -108,7 +110,13 @@ void iconv_convert_from_to(const char *from, const char *to, std::string &s)
free(const_cast<char *>(tmp));
}
-void utf_to_locale(std::string &s)
+std::string utf8ToLocale(std::string s)
+{
+ utf8ToLocale_(s);
+ return s;
+}
+
+void utf8ToLocale_(std::string &s)
{
if (Config.system_encoding.empty() || !has_non_ascii_chars(s.c_str()))
return;
@@ -118,14 +126,13 @@ void utf_to_locale(std::string &s)
free(const_cast<char *>(tmp));
}
-std::string utf_to_locale_cpy(const std::string &s)
+std::string localeToUtf8(std::string s)
{
- std::string result = s;
- utf_to_locale(result);
- return result;
+ localeToUtf8_(s);
+ return s;
}
-void locale_to_utf(std::string &s)
+void localeToUtf8_(std::string &s)
{
if (Config.system_encoding.empty() || !has_non_ascii_chars(s.c_str()) || is_utf8(s.c_str()))
return;
@@ -135,26 +142,6 @@ void locale_to_utf(std::string &s)
free(const_cast<char *>(tmp));
}
-std::string locale_to_utf_cpy(const std::string &s)
-{
- std::string result = s;
- locale_to_utf(result);
- return result;
-}
-
-void utf_to_locale(const char *&s, bool delete_old)
-{
- if (!s || Config.system_encoding.empty() || !has_non_ascii_chars(s))
- return;
- charset_convert("utf-8", Config.system_encoding.c_str(), s, delete_old);
-}
-
-void locale_to_utf(const char *&s, bool delete_old)
-{
- if (!s || Config.system_encoding.empty() || !has_non_ascii_chars(s) || is_utf8(s))
- return;
- charset_convert(Config.system_encoding.c_str(), "utf-8", s, delete_old);
}
#endif // HAVE_ICONV_H
-