aboutsummaryrefslogtreecommitdiff
path: root/src/mm-modem-helpers.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2017-03-25 21:39:44 +0100
committerAleksander Morgado <aleksander@aleksander.es>2017-04-02 10:06:07 +0200
commitf824602bdd922cdc9e15aa83fda545534c0b0542 (patch)
treeec4485609e19353f559e5b03f365d8d6b7dc3349 /src/mm-modem-helpers.c
parent822bfa4ca163ef17a0fc60d03bfae462091885bf (diff)
modem-helpers: if operator not in UCS2, see if already valid UTF-8
The method doing the operator name normalization takes as input the current configured modem charset. If this is UCS2, we will now just assume this is a hint: the string may or may not come in hex/UCS2. This logic makes the custom operator name loading in Huawei unneeded, if the modem is configured in UCS2, we still properly process operator names coming in plain ASCII.
Diffstat (limited to 'src/mm-modem-helpers.c')
-rw-r--r--src/mm-modem-helpers.c26
1 files changed, 17 insertions, 9 deletions
diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c
index fc95e28f..9266a5a0 100644
--- a/src/mm-modem-helpers.c
+++ b/src/mm-modem-helpers.c
@@ -3131,20 +3131,28 @@ mm_3gpp_normalize_operator_name (gchar **operator,
if (*operator == NULL)
return;
- /* Some modems (Option & HSO) return the operator name as a hexadecimal
- * string of the bytes of the operator name as encoded by the current
- * character set.
- */
+ /* Despite +CSCS? may claim supporting UCS2, Some modems (e.g. Huawei)
+ * always report the operator name in ASCII in a +COPS response. */
if (cur_charset == MM_MODEM_CHARSET_UCS2) {
+ gchar *tmp;
+
+ tmp = g_strdup (*operator);
/* In this case we're already checking UTF-8 validity */
- *operator = mm_charset_take_and_convert_to_utf8 (*operator, MM_MODEM_CHARSET_UCS2);
+ tmp = mm_charset_take_and_convert_to_utf8 (tmp, cur_charset);
+ if (tmp) {
+ g_clear_pointer (operator, g_free);
+ *operator = tmp;
+ goto out;
+ }
}
- /* Ensure the operator name is valid UTF-8 so that we can send it
- * through D-Bus and such.
- */
- else if (!g_utf8_validate (*operator, -1, NULL))
+
+ /* Charset is unknown or there was an error in conversion; try to see
+ * if the contents we got are valid UTF-8 already. */
+ if (!g_utf8_validate (*operator, -1, NULL))
g_clear_pointer (operator, g_free);
+out:
+
/* Some modems (Novatel LTE) return the operator name as "Unknown" when
* it fails to obtain the operator name. Return NULL in such case.
*/