89236aad75769e0fd8a916923a886b6602bab7c4
[ncmpc-debian.git] / src / charset.cxx
1 /* ncmpc (Ncurses MPD Client)
2  * (c) 2004-2018 The Music Player Daemon Project
3  * Project homepage: http://musicpd.org
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License along
16  * with this program; if not, write to the Free Software Foundation, Inc.,
17  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18  */
19
20 #include "charset.hxx"
21 #include "util/ScopeExit.hxx"
22 #include "util/StringUTF8.hxx"
23
24 #include <assert.h>
25 #include <string.h>
26 #include <glib.h>
27
28 #ifdef ENABLE_LOCALE
29 static bool noconvert = true;
30 static const char *charset;
31
32 const char *
33 charset_init()
34 {
35         noconvert = g_get_charset(&charset);
36         return charset;
37 }
38 #endif
39
40 unsigned
41 locale_width(const char *p)
42 {
43 #if defined(ENABLE_LOCALE) && defined(ENABLE_MULTIBYTE)
44         char *utf8;
45
46         if (noconvert)
47                 return utf8_width(p);
48
49         utf8 = locale_to_utf8(p);
50         AtScopeExit(utf8) { g_free(utf8); };
51
52         return utf8_width(utf8);
53 #else
54         return strlen(p);
55 #endif
56 }
57
58 char *
59 utf8_to_locale(const char *utf8str)
60 {
61 #ifdef ENABLE_LOCALE
62         assert(utf8str != nullptr);
63
64         if (noconvert)
65                 return g_strdup(utf8str);
66
67         gchar *str = g_convert_with_fallback(utf8str, -1,
68                                              charset, "utf-8",
69                                              nullptr, nullptr, nullptr, nullptr);
70         if (str == nullptr)
71                 return g_strdup(utf8str);
72
73         return str;
74 #else
75         return g_strdup(utf8str);
76 #endif
77 }
78
79 char *
80 locale_to_utf8(const char *localestr)
81 {
82 #ifdef ENABLE_LOCALE
83         assert(localestr != nullptr);
84
85         if (noconvert)
86                 return g_strdup(localestr);
87
88         gchar *str = g_convert_with_fallback(localestr, -1,
89                                              "utf-8", charset,
90                                              nullptr, nullptr, nullptr, nullptr);
91         if (str == nullptr)
92                 return g_strdup(localestr);
93
94         return str;
95 #else
96         return g_strdup(localestr);
97 #endif
98 }
99
100 char *
101 replace_utf8_to_locale(char *src)
102 {
103 #ifdef ENABLE_LOCALE
104         assert(src != nullptr);
105
106         if (noconvert)
107                 return src;
108
109         AtScopeExit(src) { g_free(src); };
110         return utf8_to_locale(src);
111 #else
112         return src;
113 #endif
114 }
115
116
117 char *
118 replace_locale_to_utf8(char *src)
119 {
120 #ifdef ENABLE_LOCALE
121         assert(src != nullptr);
122
123         if (noconvert)
124                 return src;
125
126         AtScopeExit(src) { g_free(src); };
127         return locale_to_utf8(src);
128 #else
129         return src;
130 #endif
131 }
132
133 #ifdef ENABLE_LOCALE
134
135 Utf8ToLocale::~Utf8ToLocale()
136 {
137         g_free(value);
138 }
139
140 LocaleToUtf8::~LocaleToUtf8()
141 {
142         g_free(value);
143 }
144
145 #endif