diff options
author | Aleksander Morgado <aleksander@lanedo.com> | 2012-02-18 08:57:06 +0100 |
---|---|---|
committer | Aleksander Morgado <aleksander@lanedo.com> | 2012-03-16 14:28:13 +0100 |
commit | 6f1a4514da5041ee57437e651e357bc3a3b86418 (patch) | |
tree | e214960a657ee96e921a79e304a396d5c9d68d7c /libmm-common/mm-common-helpers.c | |
parent | 91416a3e3dc1f880a958726e4a8db737bf960a1e (diff) |
libmm-common: new bands array comparator
Diffstat (limited to 'libmm-common/mm-common-helpers.c')
-rw-r--r-- | libmm-common/mm-common-helpers.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/libmm-common/mm-common-helpers.c b/libmm-common/mm-common-helpers.c index d0dd83c5..d7209cb2 100644 --- a/libmm-common/mm-common-helpers.c +++ b/libmm-common/mm-common-helpers.c @@ -255,6 +255,44 @@ mm_common_bands_garray_to_variant (GArray *array) return mm_common_bands_array_to_variant (NULL, 0); } +static guint +cmp_band (MMModemBand *a, MMModemBand *b) +{ + return (*a - *b); +} + +gboolean +mm_common_bands_garray_cmp (GArray *a, GArray *b) +{ + GArray *dup_a; + GArray *dup_b; + guint i; + gboolean different; + + if (a->len != b->len) + return FALSE; + + dup_a = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), a->len); + g_array_append_vals (dup_a, a->data, a->len); + + dup_b = g_array_sized_new (FALSE, FALSE, sizeof (MMModemBand), b->len); + g_array_append_vals (dup_b, b->data, b->len); + + g_array_sort (dup_a, (GCompareFunc)cmp_band); + g_array_sort (dup_b, (GCompareFunc)cmp_band); + + different = FALSE; + for (i = 0; !different && i < a->len; i++) { + if (g_array_index (dup_a, MMModemBand, i) != g_array_index (dup_b, MMModemBand, i)) + different = TRUE; + } + + g_array_unref (dup_a); + g_array_unref (dup_b); + + return !different; +} + gboolean mm_common_get_boolean_from_string (const gchar *value, GError **error) |