diff options
Diffstat (limited to 'libmm-glib/mm-cbm.c')
-rw-r--r-- | libmm-glib/mm-cbm.c | 226 |
1 files changed, 226 insertions, 0 deletions
diff --git a/libmm-glib/mm-cbm.c b/libmm-glib/mm-cbm.c new file mode 100644 index 00000000..5044408f --- /dev/null +++ b/libmm-glib/mm-cbm.c @@ -0,0 +1,226 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* + * libmm-glib -- Access modem status & information from glib applications + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the + * Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301 USA. + * + * Copyright (C) 2024 Guido Günther <agx@sigxcpu.org> + */ + +#include "string.h" + +#include "mm-helpers.h" +#include "mm-cbm.h" +#include "mm-modem.h" + +/** + * SECTION: mm-cbm + * @title: MMCbm + * @short_description: The CBM interface + * + * The #MMCbm is an object providing access to the methods, signals and + * properties of the CBM interface. + * + * When the CBM is exposed and available in the bus, it is ensured that at + * least this interface is also available. + */ + +G_DEFINE_TYPE (MMCbm, mm_cbm, MM_GDBUS_TYPE_CBM_PROXY) + +/*****************************************************************************/ + +/** + * mm_cbm_get_path: + * @self: A #MMCbm. + * + * Gets the DBus path of the #MMCbm object. + * + * Returns: (transfer none): The DBus path of the #MMCbm object. + * + * Since: 1.24 + */ +const gchar * +mm_cbm_get_path (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_CONSTANT_STRING ( + g_dbus_proxy_get_object_path (G_DBUS_PROXY (self))); +} + +/** + * mm_cbm_dup_path: + * @self: A #MMCbm. + * + * Gets a copy of the DBus path of the #MMCbm object. + * + * Returns: (transfer full): The DBus path of the #MMCbm object. The returned + * value should be freed with g_free(). + * + * Since: 1.24 + */ +gchar * +mm_cbm_dup_path (MMCbm *self) +{ + gchar *value; + + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + g_object_get (G_OBJECT (self), + "g-object-path", &value, + NULL); + + RETURN_NON_EMPTY_STRING (value); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_text: + * @self: A #MMCbm. + * + * Gets the message text, in UTF-8. + * + * <warning>The returned value is only valid until the property changes so it is + * only safe to use this function on the thread where @self was constructed. Use + * mm_cbm_dup_text() if on another thread.</warning> + * + * Returns: (transfer none): The message text, or %NULL if it doesn't contain + * any (e.g. contains data instead). + * + * Since: 1.24 + */ +const gchar * +mm_cbm_get_text (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_CONSTANT_STRING ( + mm_gdbus_cbm_get_text (MM_GDBUS_CBM (self))); +} + +/** + * mm_cbm_dup_text: + * @self: A #MMCbm. + * + * Gets the message text, in UTF-8. + * + * Returns: (transfer full): The message text, or %NULL if it doesn't contain + * any (e.g. contains data instead). The returned value should be freed with + * g_free(). + * + * Since: 1.24 + */ +gchar * +mm_cbm_dup_text (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), NULL); + + RETURN_NON_EMPTY_STRING ( + mm_gdbus_cbm_dup_text (MM_GDBUS_CBM (self))); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_state: + * @self: A #MMCbm. + * + * Gets the state of this CBM. + * + * Returns: A #MMCbmState specifying the state. + * + * Since: 1.24 + */ +MMCbmState +mm_cbm_get_state (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), MM_CBM_STATE_UNKNOWN); + + return (MMCbmState)mm_gdbus_cbm_get_state (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_channel: + * @self: A #MMCbm. + * + * Gets the channel of this CBM. + * + * Returns: The channel + * + * Since: 1.24 + */ +guint +mm_cbm_get_channel (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_channel (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_message_code: + * @self: A #MMCbm. + * + * Gets the message code of this CBM. + * + * Returns: The message code + * + * Since: 1.24 + */ +guint +mm_cbm_get_message_code (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_message_code (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +/** + * mm_cbm_get_update: + * @self: A #MMCbm. + * + * Gets the update number of this CBM. + * + * Returns: The update number + * + * Since: 1.24 + */ +guint +mm_cbm_get_update (MMCbm *self) +{ + g_return_val_if_fail (MM_IS_CBM (self), 0); + + return mm_gdbus_cbm_get_update (MM_GDBUS_CBM (self)); +} + +/*****************************************************************************/ + +static void +mm_cbm_init (MMCbm *self) +{ +} + +static void +mm_cbm_class_init (MMCbmClass *cbm_class) +{ +} |