diff options
-rw-r--r-- | src/mm-broadband-modem.c | 12 | ||||
-rw-r--r-- | src/mm-modem-helpers.c | 17 | ||||
-rw-r--r-- | src/mm-modem-helpers.h | 5 |
3 files changed, 31 insertions, 3 deletions
diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c index 77650490..4a2fdb8e 100644 --- a/src/mm-broadband-modem.c +++ b/src/mm-broadband-modem.c @@ -634,13 +634,23 @@ modem_load_model_finish (MMIfaceModem *self, GError **error) { GVariant *result; + const gchar *p; gchar *model; result = mm_base_modem_at_sequence_finish (MM_BASE_MODEM (self), res, NULL, error); if (!result) return NULL; - model = g_strstrip (g_variant_dup_string (result, NULL)); + p = g_variant_get_string (result, NULL); + + /* Some devices (e.g. ZTE MF820D) seem to include the command prefix */ + p = mm_strip_tag (p, "+CGMM:"); + p = mm_strip_tag (p, "+GMM:"); + model = g_strdup (p); + + /* Stripping quotes modifies string in place */ + model = mm_strip_quotes (model); + mm_dbg ("loaded model: %s", model); return model; } diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c index 60d7459b..db0bfbdf 100644 --- a/src/mm-modem-helpers.c +++ b/src/mm-modem-helpers.c @@ -32,6 +32,23 @@ /*****************************************************************************/ +gchar * +mm_strip_quotes (gchar *str) +{ + gsize len; + + if (!str) + return NULL; + + len = strlen (str); + if ((len >= 2) && (str[0] == '"') && (str[len - 1] == '"')) { + str[0] = ' '; + str[len - 1] = ' '; + } + + return g_strstrip (str); +} + const gchar * mm_strip_tag (const gchar *str, const gchar *cmd) { diff --git a/src/mm-modem-helpers.h b/src/mm-modem-helpers.h index 95b15ebc..b8573aa5 100644 --- a/src/mm-modem-helpers.h +++ b/src/mm-modem-helpers.h @@ -44,8 +44,9 @@ (MM_MODEM_CAPABILITY_GSM_UMTS | \ MM_MODEM_CAPABILITY_3GPP_LTE) -const gchar *mm_strip_tag (const gchar *str, - const gchar *cmd); +gchar *mm_strip_quotes (gchar *str); +const gchar *mm_strip_tag (const gchar *str, + const gchar *cmd); guint mm_count_bits_set (gulong number); |