aboutsummaryrefslogtreecommitdiff
path: root/src/mm-generic-gsm.c
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2010-04-09 13:50:45 -0700
committerDan Williams <dcbw@redhat.com>2010-04-09 13:50:45 -0700
commit0d381e2f11cbc3bdb7c7e69bc4c7169a9d247d3c (patch)
tree767e21734f1f8287d57df02359bf1339b7c0f8e5 /src/mm-generic-gsm.c
parentb51a9d27e5a793b4e33bfdd7999e7204c408f154 (diff)
gsm: fix CSCS=? parsing and add testcases
Some devices (at least one Blackberry we know about) don't include the () around the response. Handle that and add testcases for it.
Diffstat (limited to 'src/mm-generic-gsm.c')
-rw-r--r--src/mm-generic-gsm.c37
1 files changed, 3 insertions, 34 deletions
diff --git a/src/mm-generic-gsm.c b/src/mm-generic-gsm.c
index 66ebc489..003ee2ac 100644
--- a/src/mm-generic-gsm.c
+++ b/src/mm-generic-gsm.c
@@ -2676,9 +2676,6 @@ get_charsets_done (MMAtSerialPort *port,
{
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
MMGenericGsmPrivate *priv;
- GRegex *r = NULL;
- GMatchInfo *match_info;
- const char *p;
info->error = mm_modem_check_removed (info->modem, error);
if (info->error) {
@@ -2688,41 +2685,13 @@ get_charsets_done (MMAtSerialPort *port,
priv = MM_GENERIC_GSM_GET_PRIVATE (info->modem);
- /* Find the first '(' */
- p = strchr (response->str, '(');
- if (!p)
- goto done;
- p++;
-
- /* Now parse each charset */
- r = g_regex_new ("\\s*([^,\\)]+)\\s*", 0, 0, NULL);
- if (!r)
- goto done;
-
- if (!g_regex_match_full (r, p, strlen (p), 0, 0, &match_info, NULL))
- goto done;
-
priv->charsets = MM_MODEM_CHARSET_UNKNOWN;
-
- while (g_match_info_matches (match_info)) {
- char *str;
-
- str = g_match_info_fetch (match_info, 1);
- priv->charsets |= mm_modem_charset_from_string (str);
- g_free (str);
-
- g_match_info_next (match_info, NULL);
- }
- g_match_info_free (match_info);
-
- mm_callback_info_set_result (info, GUINT_TO_POINTER (priv->charsets), NULL);
-
-done:
- if (!info->error && !priv->charsets) {
+ if (!mm_gsm_parse_cscs_support_response (response->str, &priv->charsets)) {
info->error = g_error_new_literal (MM_MODEM_ERROR,
MM_MODEM_ERROR_GENERAL,
"Failed to parse the supported character sets response");
- }
+ } else
+ mm_callback_info_set_result (info, GUINT_TO_POINTER (priv->charsets), NULL);
mm_callback_info_schedule (info);
}