aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libmm-common/mm-common-helpers.c32
-rw-r--r--libmm-common/mm-common-helpers.h2
-rw-r--r--libmm-glib/mm-modem.c16
-rw-r--r--libmm-glib/mm-modem.h2
4 files changed, 52 insertions, 0 deletions
diff --git a/libmm-common/mm-common-helpers.c b/libmm-common/mm-common-helpers.c
index 937b8483..2b851d65 100644
--- a/libmm-common/mm-common-helpers.c
+++ b/libmm-common/mm-common-helpers.c
@@ -88,6 +88,38 @@ mm_common_get_access_technologies_string (MMModemAccessTechnology access_tech)
return g_string_free (str, FALSE);
}
+gchar *
+mm_common_get_bands_string (const MMModemBand *bands,
+ guint n_bands)
+{
+ GEnumClass *enum_class;
+ gboolean first = TRUE;
+ GString *str;
+ guint i;
+
+ str = g_string_new ("");
+ if (n_bands == 0) {
+ g_string_append (str, "none");
+ return g_string_free (str, FALSE);
+ }
+
+ enum_class = G_ENUM_CLASS (g_type_class_ref (MM_TYPE_MODEM_BAND));
+ for (i = 0; i < n_bands; i++) {
+ GEnumValue *value;
+
+ value = g_enum_get_value (enum_class, bands[i]);
+ g_string_append_printf (str, "%s%s",
+ first ? "" : ", ",
+ value->value_nick);
+
+ if (first)
+ first = FALSE;
+ }
+ g_type_class_unref (enum_class);
+
+ return g_string_free (str, FALSE);
+}
+
GArray *
mm_common_bands_variant_to_garray (GVariant *variant)
{
diff --git a/libmm-common/mm-common-helpers.h b/libmm-common/mm-common-helpers.h
index c1a4c6a7..dc09c555 100644
--- a/libmm-common/mm-common-helpers.h
+++ b/libmm-common/mm-common-helpers.h
@@ -21,6 +21,8 @@
gchar *mm_common_get_capabilities_string (MMModemCapability caps);
gchar *mm_common_get_access_technologies_string (MMModemAccessTechnology access_tech);
+gchar *mm_common_get_bands_string (const MMModemBand *bands,
+ guint n_bands);
GArray *mm_common_bands_variant_to_garray (GVariant *variant);
GVariant *mm_common_bands_array_to_variant (const MMModemBand *bands,
diff --git a/libmm-glib/mm-modem.c b/libmm-glib/mm-modem.c
index e89173e7..fd348a18 100644
--- a/libmm-glib/mm-modem.c
+++ b/libmm-glib/mm-modem.c
@@ -1698,3 +1698,19 @@ mm_modem_get_access_technologies_string (MMModemAccessTechnology access_tech)
{
return mm_common_get_access_technologies_string (access_tech);
}
+
+/**
+ * mm_modem_get_bands_string:
+ * @bands: List of #MMModemBand values.
+ * @n_bands: Number of values in @bands.
+ *
+ * Build a string with a list of bands.
+ *
+ * Returns: (transfer full): A string specifying the band names given in @bands. The returned value should be freed with g_free().
+ */
+gchar *
+mm_modem_get_bands_string (const MMModemBand *bands,
+ guint n_bands)
+{
+ return mm_common_get_bands_string (bands, n_bands);
+}
diff --git a/libmm-glib/mm-modem.h b/libmm-glib/mm-modem.h
index f8dced67..16015d53 100644
--- a/libmm-glib/mm-modem.h
+++ b/libmm-glib/mm-modem.h
@@ -212,6 +212,8 @@ MMSim *mm_modem_get_sim_sync (MMModem *self,
gchar *mm_modem_get_capabilities_string (MMModemCapability caps);
gchar *mm_modem_get_access_technologies_string (MMModemAccessTechnology access_tech);
+gchar *mm_modem_get_bands_string (const MMModemBand *bands,
+ guint n_bands);
G_END_DECLS