/* -*- 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 */ #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. * * 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. * * 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) { }