Blame src/nmtui/nmt-utils.c

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
}