aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2011-12-21 15:14:40 +0100
committerAleksander Morgado <aleksander@lanedo.com>2012-03-15 14:14:36 +0100
commit8fc2050e768157076dfa5445d52541904602e832 (patch)
treeb3099d421d2927e823e57f24655fa14881ec252b
parent6cce67a45103052b2adba360ba5d438923fa907c (diff)
libmm-glib: provide a list of opaque structs with network info in scan reply
-rw-r--r--libmm-glib/mm-modem-3gpp.c138
-rw-r--r--libmm-glib/mm-modem-3gpp.h31
2 files changed, 145 insertions, 24 deletions
diff --git a/libmm-glib/mm-modem-3gpp.c b/libmm-glib/mm-modem-3gpp.c
index 7a8129f4..8e18ebd4 100644
--- a/libmm-glib/mm-modem-3gpp.c
+++ b/libmm-glib/mm-modem-3gpp.c
@@ -266,6 +266,112 @@ mm_modem_3gpp_register_sync (MMModem3gpp *self,
error);
}
+struct _MMModem3gppNetwork {
+ MMModem3gppNetworkAvailability availability;
+ gchar *operator_long;
+ gchar *operator_short;
+ gchar *operator_code;
+ MMModemAccessTechnology access_technology;
+};
+
+void
+mm_modem_3gpp_network_free (MMModem3gppNetwork *network)
+{
+ if (!network)
+ return;
+
+ g_free (network->operator_long);
+ g_free (network->operator_short);
+ g_free (network->operator_code);
+ g_slice_free (MMModem3gppNetwork, network);
+}
+
+MMModem3gppNetworkAvailability
+mm_modem_3gpp_network_get_availability (const MMModem3gppNetwork *network)
+{
+ g_return_val_if_fail (network != NULL, MM_MODEM_3GPP_NETWORK_AVAILABILITY_UNKNOWN);
+
+ return network->availability;
+}
+
+const gchar *
+mm_modem_3gpp_network_get_operator_long (const MMModem3gppNetwork *network)
+{
+ g_return_val_if_fail (network != NULL, NULL);
+
+ return network->operator_long;
+}
+
+const gchar *
+mm_modem_3gpp_network_get_operator_short (const MMModem3gppNetwork *network)
+{
+ g_return_val_if_fail (network != NULL, NULL);
+
+ return network->operator_short;
+}
+
+const gchar *
+mm_modem_3gpp_network_get_operator_code (const MMModem3gppNetwork *network)
+{
+ g_return_val_if_fail (network != NULL, NULL);
+
+ return network->operator_code;
+}
+
+MMModemAccessTechnology
+mm_modem_3gpp_network_get_access_technology (const MMModem3gppNetwork *network)
+{
+ g_return_val_if_fail (network != NULL, MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN);
+
+ return network->access_technology;
+}
+
+static GList *
+create_networks_list (GVariant *variant)
+{
+ GList *list = NULL;
+ GVariantIter dict_iter;
+ GVariant *dict;
+
+ /* Input is aa{sv} */
+ g_variant_iter_init (&dict_iter, variant);
+ while ((dict = g_variant_iter_next_value (&dict_iter))) {
+ GVariantIter iter;
+ gchar *key;
+ GVariant *value;
+ MMModem3gppNetwork *network;
+
+ network = g_slice_new0 (MMModem3gppNetwork);
+
+ g_variant_iter_init (&iter, dict);
+ while (g_variant_iter_next (&iter, "{sv}", &key, &value)) {
+ if (g_str_equal (key, "status")) {
+ network->availability = (MMModem3gppNetworkAvailability)g_variant_get_uint32 (value);
+ } else if (g_str_equal (key, "operator-long")) {
+ g_warn_if_fail (network->operator_long == NULL);
+ network->operator_long = g_variant_dup_string (value, NULL);
+ } else if (g_str_equal (key, "operator-short")) {
+ g_warn_if_fail (network->operator_short == NULL);
+ network->operator_short = g_variant_dup_string (value, NULL);
+ } else if (g_str_equal (key, "operator-code")) {
+ g_warn_if_fail (network->operator_code == NULL);
+ network->operator_code = g_variant_dup_string (value, NULL);
+ } else if (g_str_equal (key, "access-technology")) {
+ network->access_technology = (MMModemAccessTechnology)g_variant_get_uint32 (value);
+ } else
+ g_warning ("Unexpected property '%s' found in Network info", key);
+
+ g_free (key);
+ g_variant_unref (value);
+ }
+
+ list = g_list_prepend (list, network);
+ g_variant_unref (dict);
+ }
+
+ return list;
+}
+
void
mm_modem_3gpp_scan (MMModem3gpp *self,
GCancellable *cancellable,
@@ -280,30 +386,38 @@ mm_modem_3gpp_scan (MMModem3gpp *self,
user_data);
}
-gboolean
+GList *
mm_modem_3gpp_scan_finish (MMModem3gpp *self,
- GVariant **results,
GAsyncResult *res,
GError **error)
{
+ GVariant *result = NULL;
+
g_return_val_if_fail (MM_GDBUS_IS_MODEM3GPP (self), FALSE);
- return mm_gdbus_modem3gpp_call_scan_finish (self,
- results,
- res,
- error);
+ if (!mm_gdbus_modem3gpp_call_scan_finish (self,
+ &result,
+ res,
+ error))
+ return NULL;
+
+ return create_networks_list (result);
}
-gboolean
+GList *
mm_modem_3gpp_scan_sync (MMModem3gpp *self,
- GVariant **results,
GCancellable *cancellable,
GError **error)
{
+ GVariant *result = NULL;
+
g_return_val_if_fail (MM_GDBUS_IS_MODEM3GPP (self), FALSE);
- return mm_gdbus_modem3gpp_call_scan_sync (self,
- results,
- cancellable,
- error);
+ if (!mm_gdbus_modem3gpp_call_scan_sync (self,
+ &result,
+ cancellable,
+ error))
+ return NULL;
+
+ return create_networks_list (result);
}
diff --git a/libmm-glib/mm-modem-3gpp.h b/libmm-glib/mm-modem-3gpp.h
index ca784b85..5e4bded5 100644
--- a/libmm-glib/mm-modem-3gpp.h
+++ b/libmm-glib/mm-modem-3gpp.h
@@ -28,6 +28,8 @@
G_BEGIN_DECLS
+typedef struct _MMModem3gppNetwork MMModem3gppNetwork;
+
typedef MmGdbusModem3gpp MMModem3gpp;
#define MM_TYPE_MODEM_3GPP(o) MM_GDBUS_TYPE_MODEM3GPP (o)
#define MM_MODEM_3GPP(o) MM_GDBUS_MODEM3GPP(o)
@@ -59,18 +61,23 @@ gboolean mm_modem_3gpp_register_sync (MMModem3gpp *self,
GCancellable *cancellable,
GError **error);
-void mm_modem_3gpp_scan (MMModem3gpp *self,
- GCancellable *cancellable,
- GAsyncReadyCallback callback,
- gpointer user_data);
-gboolean mm_modem_3gpp_scan_finish (MMModem3gpp *self,
- GVariant **results,
- GAsyncResult *res,
- GError **error);
-gboolean mm_modem_3gpp_scan_sync (MMModem3gpp *self,
- GVariant **results,
- GCancellable *cancellable,
- GError **error);
+MMModem3gppNetworkAvailability mm_modem_3gpp_network_get_availability (const MMModem3gppNetwork *network);
+const gchar *mm_modem_3gpp_network_get_operator_long (const MMModem3gppNetwork *network);
+const gchar *mm_modem_3gpp_network_get_operator_short (const MMModem3gppNetwork *network);
+const gchar *mm_modem_3gpp_network_get_operator_code (const MMModem3gppNetwork *network);
+MMModemAccessTechnology mm_modem_3gpp_network_get_access_technology (const MMModem3gppNetwork *network);
+void mm_modem_3gpp_network_free (MMModem3gppNetwork *network);
+
+void mm_modem_3gpp_scan (MMModem3gpp *self,
+ GCancellable *cancellable,
+ GAsyncReadyCallback callback,
+ gpointer user_data);
+GList *mm_modem_3gpp_scan_finish (MMModem3gpp *self,
+ GAsyncResult *res,
+ GError **error);
+GList *mm_modem_3gpp_scan_sync (MMModem3gpp *self,
+ GCancellable *cancellable,
+ GError **error);
G_END_DECLS