|
Packit Service |
dff8e4 |
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
Packit Service |
dff8e4 |
/*
|
|
Packit Service |
dff8e4 |
* Copyright (C) 2013 Red Hat, Inc.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* SECTION:nmt-utils
|
|
Packit Service |
dff8e4 |
* @short_description: Miscellaneous nmtui-specific utilities
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#include "libnm-client-aux-extern/nm-default-client.h"
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
#include "nmt-utils.h"
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* NmtSyncOp:
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* A helper object used when synchronously waiting for an asynchronous
|
|
Packit Service |
dff8e4 |
* operation to complete.
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* The caller first does:
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* |[
|
|
Packit Service |
dff8e4 |
* NmtSyncOp op;
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_init (&op);
|
|
Packit Service |
dff8e4 |
* ]|
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* It then passes the op as the user_data to the async operation's
|
|
Packit Service |
dff8e4 |
* callback function, and then calls nmt_sync_op_wait_boolean() or
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_wait_pointer() to wait for the result.
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* When the async callback is invoked, it should call
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_complete_boolean() or nmt_sync_op_complete_pointer() to
|
|
Packit Service |
dff8e4 |
* return a result or an error to the caller.
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* There is no free/clear function; any memory that needs to be freed
|
|
Packit Service |
dff8e4 |
* will have been returned to the caller from
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_wait_boolean() or nmt_sync_op_wait_pointer(), so there
|
|
Packit Service |
dff8e4 |
* is nothing left that needs to be freed.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
typedef struct {
|
|
Packit Service |
dff8e4 |
gpointer result;
|
|
Packit Service |
dff8e4 |
GError * error;
|
|
Packit Service |
dff8e4 |
gpointer complete;
|
|
Packit Service |
dff8e4 |
} NmtSyncOpReal;
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_init:
|
|
Packit Service |
dff8e4 |
* @op: pointer to a stack-allocated #NmtSyncOp
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* Initializes @op before use.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
void
|
|
Packit Service |
dff8e4 |
nmt_sync_op_init(NmtSyncOp *op)
|
|
Packit Service |
dff8e4 |
{
|
|
Packit Service |
dff8e4 |
memset(op, 0, sizeof(*op));
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_wait_boolean:
|
|
Packit Service |
dff8e4 |
* @op: the #NmtSyncOp
|
|
Packit Service |
dff8e4 |
* @error: return location for a #GError
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* This runs the main loop until @op's operation returns, and then
|
|
Packit Service |
dff8e4 |
* returns the result or error.
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* Returns: the result of the operation.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
gboolean
|
|
Packit Service |
dff8e4 |
nmt_sync_op_wait_boolean(NmtSyncOp *op, GError **error)
|
|
Packit Service |
dff8e4 |
{
|
|
Packit Service |
dff8e4 |
return GPOINTER_TO_UINT(nmt_sync_op_wait_pointer(op, error));
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_complete_boolean:
|
|
Packit Service |
dff8e4 |
* @op: the #NmtSyncOp
|
|
Packit Service |
dff8e4 |
* @result: the result of the operation
|
|
Packit Service |
dff8e4 |
* @error: (allow-none): the error, or %NULL
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* Completes @op and returns @result and/or @error to the caller.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
void
|
|
Packit Service |
dff8e4 |
nmt_sync_op_complete_boolean(NmtSyncOp *op, gboolean result, GError *error)
|
|
Packit Service |
dff8e4 |
{
|
|
Packit Service |
dff8e4 |
nmt_sync_op_complete_pointer(op, GUINT_TO_POINTER(result), error);
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_wait_pointer:
|
|
Packit Service |
dff8e4 |
* @op: the #NmtSyncOp
|
|
Packit Service |
dff8e4 |
* @error: return location for a #GError
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* This runs the main loop until @op's operation returns, and then
|
|
Packit Service |
dff8e4 |
* returns the result or error.
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* Returns: the result of the operation.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
gpointer
|
|
Packit Service |
dff8e4 |
nmt_sync_op_wait_pointer(NmtSyncOp *op, GError **error)
|
|
Packit Service |
dff8e4 |
{
|
|
Packit Service |
dff8e4 |
NmtSyncOpReal *real = (NmtSyncOpReal *) op;
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
while (!real->complete)
|
|
Packit Service |
dff8e4 |
g_main_context_iteration(NULL, TRUE);
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
if (real->error)
|
|
Packit Service |
dff8e4 |
g_propagate_error(error, real->error);
|
|
Packit Service |
dff8e4 |
return real->result;
|
|
Packit Service |
dff8e4 |
}
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
/**
|
|
Packit Service |
dff8e4 |
* nmt_sync_op_complete_pointer:
|
|
Packit Service |
dff8e4 |
* @op: the #NmtSyncOp
|
|
Packit Service |
dff8e4 |
* @result: the result of the operation
|
|
Packit Service |
dff8e4 |
* @error: (allow-none): the error, or %NULL
|
|
Packit Service |
dff8e4 |
*
|
|
Packit Service |
dff8e4 |
* Completes @op and returns @result and/or @error to the caller.
|
|
Packit Service |
dff8e4 |
*/
|
|
Packit Service |
dff8e4 |
void
|
|
Packit Service |
dff8e4 |
nmt_sync_op_complete_pointer(NmtSyncOp *op, gpointer result, GError *error)
|
|
Packit Service |
dff8e4 |
{
|
|
Packit Service |
dff8e4 |
NmtSyncOpReal *real = (NmtSyncOpReal *) op;
|
|
Packit Service |
dff8e4 |
|
|
Packit Service |
dff8e4 |
real->result = result;
|
|
Packit Service |
dff8e4 |
real->error = error ? g_error_copy(error) : NULL;
|
|
Packit Service |
dff8e4 |
real->complete = GUINT_TO_POINTER(TRUE);
|
|
Packit Service |
dff8e4 |
}
|