[network-manager-applet/aleksander/mobile-providers-mccmnc: 1/2] libnm-gtk, mobile-providers: use always MCCMNC strings in the API
- From: Aleksander Morgado <aleksm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [network-manager-applet/aleksander/mobile-providers-mccmnc: 1/2] libnm-gtk, mobile-providers: use always MCCMNC strings in the API
- Date: Mon, 26 Nov 2012 20:06:56 +0000 (UTC)
commit 39753eed1342c7055a8cf735cabaed263677a143
Author: Aleksander Morgado <aleksander lanedo com>
Date: Mon Nov 26 21:04:33 2012 +0100
libnm-gtk,mobile-providers: use always MCCMNC strings in the API
Skip using a specific type for the MCC+MNC pair, just concatenate both in a
string. Not a big deal, as MCC is always 3 digit long.
src/libnm-gtk/nm-mobile-providers.c | 105 ++++++++++++++++-------------------
src/libnm-gtk/nm-mobile-providers.h | 12 ----
2 files changed, 47 insertions(+), 70 deletions(-)
---
diff --git a/src/libnm-gtk/nm-mobile-providers.c b/src/libnm-gtk/nm-mobile-providers.c
index 96ff96d..d293921 100644
--- a/src/libnm-gtk/nm-mobile-providers.c
+++ b/src/libnm-gtk/nm-mobile-providers.c
@@ -40,45 +40,6 @@
#define ISO_CODES_LOCALESDIR ISO_CODES_PREFIX"/share/locale"
/******************************************************************************/
-/* MCCMNC type */
-
-static NMAMccMnc *mcc_mnc_copy (const NMAMccMnc *other);
-static void mcc_mnc_free (NMAMccMnc *m);
-
-G_DEFINE_BOXED_TYPE (NMAMccMnc, nma_mcc_mnc, mcc_mnc_copy, mcc_mnc_free)
-
-static NMAMccMnc *
-mcc_mnc_new (const char *mcc, const char *mnc)
-{
- NMAMccMnc *m;
-
- m = g_slice_new0 (NMAMccMnc);
- m->mcc = g_strstrip (g_strdup (mcc));
- m->mnc = g_strstrip (g_strdup (mnc));
- return m;
-}
-
-static NMAMccMnc *
-mcc_mnc_copy (const NMAMccMnc *other)
-{
- NMAMccMnc *ret;
-
- ret = g_slice_new (NMAMccMnc);
- ret->mcc = g_strdup (other->mcc);
- ret->mnc = g_strdup (other->mnc);
- return ret;
-}
-
-static void
-mcc_mnc_free (NMAMccMnc *m)
-{
- g_return_if_fail (m != NULL);
- g_free (m->mcc);
- g_free (m->mnc);
- g_slice_free (NMAMccMnc, m);
-}
-
-/******************************************************************************/
/* Access method type */
G_DEFINE_BOXED_TYPE (NMAMobileAccessMethod,
@@ -257,7 +218,7 @@ struct _NMAMobileProvider {
GSList *methods; /* GSList of NmaMobileAccessMethod */
- GSList *mcc_mnc; /* GSList of NmaMccMnc */
+ GSList *mcc_mnc; /* GSList of strings */
GSList *cdma_sid; /* GSList of guint32 */
};
@@ -296,7 +257,7 @@ nma_mobile_provider_unref (NMAMobileProvider *provider)
g_slist_foreach (provider->methods, (GFunc) nma_mobile_access_method_unref, NULL);
g_slist_free (provider->methods);
- g_slist_foreach (provider->mcc_mnc, (GFunc) mcc_mnc_free, NULL);
+ g_slist_foreach (provider->mcc_mnc, (GFunc) g_free, NULL);
g_slist_free (provider->mcc_mnc);
g_slist_free (provider->cdma_sid);
@@ -337,8 +298,8 @@ nma_mobile_provider_get_methods (NMAMobileProvider *provider)
* nma_mobile_provider_get_3gpp_mcc_mnc:
* @provider: a #NMAMobileProvider
*
- * Returns: (element-type NMGtk.MccMnc) (transfer none): the
- * list of #NMAMccMnc this provider exposes
+ * Returns: (element-type utf8) (transfer none): a
+ * list of strings with the MCC and MNC codes this provider exposes.
*/
GSList *
nma_mobile_provider_get_3gpp_mcc_mnc (NMAMobileProvider *provider)
@@ -669,7 +630,7 @@ parser_gsm_start (MobileParser *parser,
if (mcc && strlen (mcc) && mnc && strlen (mnc)) {
parser->current_provider->mcc_mnc = g_slist_prepend (parser->current_provider->mcc_mnc,
- mcc_mnc_new (mcc, mnc));
+ g_strdup_printf("%s%s", mcc, mnc));
break;
}
}
@@ -1068,8 +1029,7 @@ dump_country (gpointer key, gpointer value, gpointer user_data)
for (liter = provider->mcc_mnc; liter; liter = g_slist_next (liter)) {
- NMAMccMnc *m = liter->data;
- g_print (" MCC/MNC: %s-%s\n", m->mcc, m->mnc);
+ g_print (" MCC/MNC: %s\n", (gchar *)liter->data);
}
for (liter = provider->cdma_sid; liter; liter = g_slist_next (liter))
@@ -1112,9 +1072,13 @@ nma_mobile_providers_find_for_3gpp_mcc_mnc (GHashTable *country_infos,
gpointer value;
GSList *piter, *siter;
NMAMobileProvider *provider_match_2mnc = NULL;
+ guint mccmnc_len;
- if (!mccmnc)
- return NULL;
+ g_return_val_if_fail (mccmnc != NULL, NULL);
+
+ /* Expect only 5 or 6 digit MCCMNC strings */
+ mccmnc_len = strlen (mccmnc);
+ g_return_val_if_fail (mccmnc_len != 5 && mccmnc_len != 6, NULL);
g_hash_table_iter_init (&iter, country_infos);
/* Search through each country */
@@ -1131,25 +1095,50 @@ nma_mobile_providers_find_for_3gpp_mcc_mnc (GHashTable *country_infos,
for (siter = nma_mobile_provider_get_3gpp_mcc_mnc (provider);
siter;
siter = g_slist_next (siter)) {
- NMAMccMnc *mcc = siter->data;
+ gchar *mccmnc_iter = siter->data;
+ guint mccmnc_iter_len = strlen (mccmnc_iter);
/* Match both 2-digit and 3-digit MNC; prefer a
* 3-digit match if found, otherwise a 2-digit one.
*/
- if (strncmp (mcc->mcc, mccmnc, 3))
+
+ if (strncmp (mccmnc_iter, mccmnc, 3))
/* MCC was wrong */
continue;
- if ( (strlen (mccmnc) == 6)
- && !strncmp (mccmnc + 3, mcc->mnc, 3))
- /* 3-digit MNC match! */
- return provider;
+ /* Now we have the following match cases, examples given:
+ * a) input: 123/456 --> iter: 123/456 (3-digit match)
+ * b) input: 123/45 --> iter: 123/045 (3-digit match)
+ * c) input: 123/045 --> iter: 123/45 (2-digit match)
+ * d) input: 123/45 --> iter: 123/45 (2-digit match)
+ */
+
+ if (mccmnc_iter_len == 6) {
+ /* Covers cases a) and b) */
+ if ( (mccmnc_len == 6 && !strncmp (mccmnc + 3, mccmnc_iter + 3, 3))
+ || (mccmnc_len == 5 && mccmnc_iter[3] == '0' && !strncmp (mccmnc + 3, mccmnc_iter + 4, 2)))
+ /* 3-digit MNC match! */
+ return provider;
+
+ /* MNC was wrong */
+ continue;
+ }
if ( !provider_match_2mnc
- && !strncmp (mccmnc + 3, mcc->mnc, 2))
- /* Store the 2-digit MNC match, but keep looking,
- * we may have a 3-digit MNC match */
- provider_match_2mnc = provider;
+ && mccmnc_iter_len == 5) {
+ if ( (mccmnc_len == 5 && !strncmp (mccmnc + 3, mccmnc_iter + 3, 2))
+ || (mccmnc_len == 6 && mccmnc[3] == '0' && !strncmp (mccmnc + 4, mccmnc_iter + 3, 2))) {
+ /* Store the 2-digit MNC match, but keep looking,
+ * we may have a 3-digit MNC match */
+ provider_match_2mnc = provider;
+ continue;
+ }
+
+ /* MNC was wrong */
+ continue;
+ }
+
+ g_warn_if_reached();
}
}
}
diff --git a/src/libnm-gtk/nm-mobile-providers.h b/src/libnm-gtk/nm-mobile-providers.h
index e77c3e8..53e30a8 100644
--- a/src/libnm-gtk/nm-mobile-providers.h
+++ b/src/libnm-gtk/nm-mobile-providers.h
@@ -33,18 +33,6 @@
#include <glib-object.h>
/******************************************************************************/
-/* MCCMNC type */
-
-#define NMA_TYPE_MCC_MNC (nma_mcc_mnc_get_type ())
-
-typedef struct {
- char *mcc;
- char *mnc;
-} NMAMccMnc;
-
-GType nma_mcc_mnc_get_type (void);
-
-/******************************************************************************/
/* Access method type */
typedef enum {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]