diff options
Diffstat (limited to 'gisi/server.c')
-rw-r--r-- | gisi/server.c | 73 |
1 files changed, 5 insertions, 68 deletions
diff --git a/gisi/server.c b/gisi/server.c index e6cc9a5b..af183f25 100644 --- a/gisi/server.c +++ b/gisi/server.c @@ -32,30 +32,12 @@ #include "server.h" -struct pending_data { - GIsiServer *server; - GIsiNotifyFunc notify; - void *data; -}; - struct _GIsiServer { GIsiModem *modem; GIsiVersion version; uint8_t resource; - GSList *pending; }; -static void pending_notify(const GIsiMessage *msg, void *data) -{ - struct pending_data *pd = data; - - if (pd == NULL) - return; - - if (pd->notify != NULL) - pd->notify(msg, pd->data); -} - uint8_t g_isi_server_resource(GIsiServer *server) { return server != NULL ? server->resource : 0; @@ -87,30 +69,17 @@ GIsiServer *g_isi_server_create(GIsiModem *modem, uint8_t resource, server->resource = resource; server->modem = modem; - server->pending = NULL; return server; } -static void foreach_destroy(gpointer value, gpointer user) -{ - GIsiPending *op = value; - GIsiServer *server = user; - - if (op == NULL || server == NULL) - return; - - server->pending = g_slist_remove(server->pending, op); - g_isi_pending_remove(op); -} - void g_isi_server_destroy(GIsiServer *server) { if (server == NULL) return; - g_slist_foreach(server->pending, foreach_destroy, server); - g_slist_free(server->pending); + g_isi_remove_pending_by_owner(server->modem, server->resource, server); + g_free(server); } @@ -132,47 +101,15 @@ int g_isi_server_vsend(GIsiServer *server, const GIsiMessage *req, return g_isi_response_vsend(server->modem, req, iov, iovlen); } -static struct pending_data *pending_data_create(GIsiServer *server, - GIsiNotifyFunc notify, - void *data) -{ - struct pending_data *pd; - - if (server == NULL) { - errno = EINVAL; - return NULL; - } - - pd = g_try_new0(struct pending_data, 1); - if (pd == NULL) { - errno = ENOMEM; - return NULL; - } - - pd->server = server; - pd->notify = notify; - pd->data = data; - - return pd; -} - GIsiPending *g_isi_server_handle(GIsiServer *server, uint8_t type, GIsiNotifyFunc notify, void *data) { - struct pending_data *pd; GIsiPending *op; - pd = pending_data_create(server, notify, data); - if (pd == NULL) - return NULL; - op = g_isi_service_bind(server->modem, server->resource, type, - pending_notify, pd, g_free); - if (op == NULL) { - g_free(pd); - return NULL; - } + notify, data, NULL); + + g_isi_pending_set_owner(op, server); - server->pending = g_slist_append(server->pending, op); return op; } |