broadband-modem: implement MMIfaceModem interface
Currently just override the interface properties, and launch initialization and shutdown where appropriate.
This commit is contained in:
@@ -27,13 +27,28 @@
|
|||||||
#include <mm-enums-types.h>
|
#include <mm-enums-types.h>
|
||||||
|
|
||||||
#include "mm-broadband-modem.h"
|
#include "mm-broadband-modem.h"
|
||||||
|
#include "mm-iface-modem.h"
|
||||||
|
#include "mm-sim.h"
|
||||||
#include "mm-errors.h"
|
#include "mm-errors.h"
|
||||||
#include "mm-log.h"
|
#include "mm-log.h"
|
||||||
|
|
||||||
G_DEFINE_TYPE (MMBroadbandModem, mm_broadband_modem, MM_TYPE_BASE_MODEM);
|
static void iface_modem_init (MMIfaceModem *iface);
|
||||||
|
|
||||||
|
G_DEFINE_TYPE_EXTENDED (MMBroadbandModem, mm_broadband_modem, MM_TYPE_BASE_MODEM, 0,
|
||||||
|
G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM, iface_modem_init));
|
||||||
|
|
||||||
|
enum {
|
||||||
|
PROP_0,
|
||||||
|
PROP_MODEM_DBUS_SKELETON,
|
||||||
|
PROP_MODEM_SIM,
|
||||||
|
PROP_MODEM_STATE,
|
||||||
|
PROP_LAST
|
||||||
|
};
|
||||||
|
|
||||||
struct _MMBroadbandModemPrivate {
|
struct _MMBroadbandModemPrivate {
|
||||||
gpointer dummy;
|
GObject *modem_dbus_skeleton;
|
||||||
|
MMSim *modem_sim;
|
||||||
|
MMModemState modem_state;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
@@ -100,6 +115,35 @@ disable_finish (MMBaseModem *self,
|
|||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
initialize_finish (MMBaseModem *self,
|
||||||
|
GAsyncResult *res,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
iface_modem_initialize_ready (MMBroadbandModem *self,
|
||||||
|
GAsyncResult *result,
|
||||||
|
GAsyncResult *initialize_result)
|
||||||
|
{
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (!mm_iface_modem_initialize_finish (MM_IFACE_MODEM (self),
|
||||||
|
result,
|
||||||
|
&error))
|
||||||
|
g_simple_async_result_take_error (G_SIMPLE_ASYNC_RESULT (initialize_result), error);
|
||||||
|
else
|
||||||
|
g_simple_async_result_set_op_res_gboolean (G_SIMPLE_ASYNC_RESULT (initialize_result), TRUE);
|
||||||
|
|
||||||
|
g_simple_async_result_complete (G_SIMPLE_ASYNC_RESULT (initialize_result));
|
||||||
|
g_object_unref (initialize_result);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
initialize (MMBaseModem *self,
|
initialize (MMBaseModem *self,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
@@ -113,20 +157,10 @@ initialize (MMBaseModem *self,
|
|||||||
user_data,
|
user_data,
|
||||||
initialize);
|
initialize);
|
||||||
|
|
||||||
g_simple_async_result_set_op_res_gboolean (G_SIMPLE_ASYNC_RESULT (res), TRUE);
|
/* Initialize the Modem interface */
|
||||||
g_simple_async_result_complete_in_idle (G_SIMPLE_ASYNC_RESULT (res));
|
mm_iface_modem_initialize (MM_IFACE_MODEM (self),
|
||||||
g_object_unref (res);
|
(GAsyncReadyCallback)iface_modem_initialize_ready,
|
||||||
}
|
res);
|
||||||
|
|
||||||
static gboolean
|
|
||||||
initialize_finish (MMBaseModem *self,
|
|
||||||
GAsyncResult *res,
|
|
||||||
GError **error)
|
|
||||||
{
|
|
||||||
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
@@ -147,6 +181,54 @@ mm_broadband_modem_new (const gchar *device,
|
|||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
set_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
const GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
MMBroadbandModem *self = MM_BROADBAND_MODEM (object);
|
||||||
|
|
||||||
|
switch (prop_id) {
|
||||||
|
case PROP_MODEM_DBUS_SKELETON:
|
||||||
|
self->priv->modem_dbus_skeleton = g_value_dup_object (value);
|
||||||
|
break;
|
||||||
|
case PROP_MODEM_SIM:
|
||||||
|
self->priv->modem_sim = g_value_dup_object (value);
|
||||||
|
break;
|
||||||
|
case PROP_MODEM_STATE:
|
||||||
|
self->priv->modem_state = g_value_get_enum (value);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
get_property (GObject *object,
|
||||||
|
guint prop_id,
|
||||||
|
GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
MMBroadbandModem *self = MM_BROADBAND_MODEM (object);
|
||||||
|
|
||||||
|
switch (prop_id) {
|
||||||
|
case PROP_MODEM_DBUS_SKELETON:
|
||||||
|
g_value_set_object (value, self->priv->modem_dbus_skeleton);
|
||||||
|
break;
|
||||||
|
case PROP_MODEM_SIM:
|
||||||
|
g_value_set_object (value, self->priv->modem_sim);
|
||||||
|
break;
|
||||||
|
case PROP_MODEM_STATE:
|
||||||
|
g_value_set_enum (value, self->priv->modem_state);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
mm_broadband_modem_init (MMBroadbandModem *self)
|
mm_broadband_modem_init (MMBroadbandModem *self)
|
||||||
{
|
{
|
||||||
@@ -154,6 +236,35 @@ mm_broadband_modem_init (MMBroadbandModem *self)
|
|||||||
self->priv = G_TYPE_INSTANCE_GET_PRIVATE ((self),
|
self->priv = G_TYPE_INSTANCE_GET_PRIVATE ((self),
|
||||||
MM_TYPE_BROADBAND_MODEM,
|
MM_TYPE_BROADBAND_MODEM,
|
||||||
MMBroadbandModemPrivate);
|
MMBroadbandModemPrivate);
|
||||||
|
self->priv->modem_state = MM_MODEM_STATE_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
dispose (GObject *object)
|
||||||
|
{
|
||||||
|
MMBroadbandModem *self = MM_BROADBAND_MODEM (object);
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (self->priv->modem_dbus_skeleton) {
|
||||||
|
if (!mm_iface_modem_shutdown (MM_IFACE_MODEM (object), &error)) {
|
||||||
|
/* TODO: Cancel initialization */
|
||||||
|
mm_warn ("couldn't shutdown interface: '%s'",
|
||||||
|
error ? error->message : "unknown error");
|
||||||
|
g_clear_error (&error);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_clear_object (&self->priv->modem_dbus_skeleton);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (self->priv->modem_sim)
|
||||||
|
g_clear_object (&self->priv->modem_sim);
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (mm_broadband_modem_parent_class)->dispose (object);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
iface_modem_init (MMIfaceModem *iface)
|
||||||
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@@ -164,10 +275,27 @@ mm_broadband_modem_class_init (MMBroadbandModemClass *klass)
|
|||||||
|
|
||||||
g_type_class_add_private (object_class, sizeof (MMBroadbandModemPrivate));
|
g_type_class_add_private (object_class, sizeof (MMBroadbandModemPrivate));
|
||||||
|
|
||||||
|
/* Virtual methods */
|
||||||
|
object_class->set_property = set_property;
|
||||||
|
object_class->get_property = get_property;
|
||||||
|
object_class->dispose = dispose;
|
||||||
|
|
||||||
base_modem_class->initialize = initialize;
|
base_modem_class->initialize = initialize;
|
||||||
base_modem_class->initialize_finish = initialize_finish;
|
base_modem_class->initialize_finish = initialize_finish;
|
||||||
base_modem_class->enable = enable;
|
base_modem_class->enable = enable;
|
||||||
base_modem_class->enable_finish = enable_finish;
|
base_modem_class->enable_finish = enable_finish;
|
||||||
base_modem_class->disable = disable;
|
base_modem_class->disable = disable;
|
||||||
base_modem_class->disable_finish = disable_finish;
|
base_modem_class->disable_finish = disable_finish;
|
||||||
|
|
||||||
|
g_object_class_override_property (object_class,
|
||||||
|
PROP_MODEM_DBUS_SKELETON,
|
||||||
|
MM_IFACE_MODEM_DBUS_SKELETON);
|
||||||
|
|
||||||
|
g_object_class_override_property (object_class,
|
||||||
|
PROP_MODEM_SIM,
|
||||||
|
MM_IFACE_MODEM_SIM);
|
||||||
|
|
||||||
|
g_object_class_override_property (object_class,
|
||||||
|
PROP_MODEM_STATE,
|
||||||
|
MM_IFACE_MODEM_STATE);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user