Blame bluez-try-utf8-harder.patch
|
Bastien Nocera |
ebbc29 |
diff --git a/src/security.c b/src/security.c
|
|
Bastien Nocera |
1fb2c4 |
index 905cf61..67fd266 100644
|
|
Bastien Nocera |
ebbc29 |
--- a/src/security.c
|
|
Bastien Nocera |
ebbc29 |
+++ b/src/security.c
|
|
Bastien Nocera |
1fb2c4 |
@@ -705,8 +705,16 @@ static inline void remote_name_information(int dev, bdaddr_t *sba, void *ptr)
|
|
Bastien Nocera |
1fb2c4 |
memcpy(name, evt->name, MAX_NAME_LENGTH);
|
|
Bastien Nocera |
ebbc29 |
/* It's ok to cast end between const and non-const since
|
|
Bastien Nocera |
ebbc29 |
* we know it points to inside of name which is non-const */
|
|
Bastien Nocera |
ebbc29 |
- if (!g_utf8_validate(name, -1, (const char **) &end))
|
|
Bastien Nocera |
ebbc29 |
- *end = '\0';
|
|
Bastien Nocera |
ebbc29 |
+ if (!g_utf8_validate(name, -1, (const char **) &end)) {
|
|
Bastien Nocera |
ebbc29 |
+ char *utf8_name;
|
|
Bastien Nocera |
ebbc29 |
+
|
|
Bastien Nocera |
ebbc29 |
+ utf8_name = g_convert(name, -1, "UTF-8", "ISO-8859-1", NULL, NULL, NULL);
|
|
Bastien Nocera |
ebbc29 |
+ if (utf8_name) {
|
|
Bastien Nocera |
ebbc29 |
+ memcpy(name, utf8_name, 248);
|
|
Bastien Nocera |
ebbc29 |
+ g_free(utf8_name);
|
|
Bastien Nocera |
ebbc29 |
+ } else
|
|
Bastien Nocera |
ebbc29 |
+ *end = '\0';
|
|
Bastien Nocera |
ebbc29 |
+ }
|
|
Bastien Nocera |
ebbc29 |
write_device_name(sba, &dba, name);
|
|
Bastien Nocera |
ebbc29 |
}
|
|
Bastien Nocera |
ebbc29 |
|