mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2024-10-31 10:23:09 +00:00
c8238579fb
Historically, we declared pointer type to our types: typedef struct _virXXX virXXX; typedef virXXX *virXXXPtr; But usefulness of such declaration is questionable, at best. Unfortunately, we can't drop every such declaration - we have to carry some over, because they are part of public API (e.g. virDomainPtr). But for internal types - we can do drop them and use what every other C project uses 'virXXX *'. This change was generated by a very ugly shell script that generated sed script which was then called over each file in the repository. For the shell script refer to the cover letter: https://listman.redhat.com/archives/libvir-list/2021-March/msg00537.html Signed-off-by: Michal Privoznik <mprivozn@redhat.com> Reviewed-by: Peter Krempa <pkrempa@redhat.com>
105 lines
3.6 KiB
C
105 lines
3.6 KiB
C
/*
|
|
* object_event_private.h: object event queue processing helpers
|
|
*
|
|
* Copyright (C) 2012-2014 Red Hat, Inc.
|
|
* Copyright (C) 2008 VirtualIron
|
|
* Copyright (C) 2013 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
|
*
|
|
* 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.1 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, see
|
|
* <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "datatypes.h"
|
|
|
|
struct _virObjectMeta {
|
|
int id;
|
|
char *name;
|
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
|
char *key;
|
|
};
|
|
typedef struct _virObjectMeta virObjectMeta;
|
|
|
|
typedef struct _virObjectEventCallbackList virObjectEventCallbackList;
|
|
|
|
typedef void
|
|
(*virObjectEventDispatchFunc)(virConnectPtr conn,
|
|
virObjectEvent *event,
|
|
virConnectObjectEventGenericCallback cb,
|
|
void *cbopaque);
|
|
|
|
struct __attribute__((aligned(8))) _virObjectEvent {
|
|
virObject parent;
|
|
int eventID;
|
|
virObjectMeta meta;
|
|
int remoteID;
|
|
virObjectEventDispatchFunc dispatch;
|
|
};
|
|
|
|
/**
|
|
* virObjectEventCallbackFilter:
|
|
* @conn: the connection pointer
|
|
* @event: the event about to be dispatched
|
|
* @opaque: opaque data registered with the filter
|
|
*
|
|
* Callback to do final filtering for a reason not tracked directly by
|
|
* virObjectEventStateRegisterID(). Return false if @event must not
|
|
* be sent to @conn.
|
|
*/
|
|
typedef bool (*virObjectEventCallbackFilter)(virConnectPtr conn,
|
|
virObjectEvent *event,
|
|
void *opaque);
|
|
|
|
virClass *
|
|
virClassForObjectEvent(void);
|
|
|
|
int
|
|
virObjectEventStateRegisterID(virConnectPtr conn,
|
|
virObjectEventState *state,
|
|
const char *key,
|
|
virObjectEventCallbackFilter filter,
|
|
void *filter_opaque,
|
|
virClass *klass,
|
|
int eventID,
|
|
virConnectObjectEventGenericCallback cb,
|
|
void *opaque,
|
|
virFreeCallback freecb,
|
|
bool legacy,
|
|
int *callbackID,
|
|
bool remoteFilter)
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(6)
|
|
ATTRIBUTE_NONNULL(8) ATTRIBUTE_NONNULL(12);
|
|
|
|
int
|
|
virObjectEventStateCallbackID(virConnectPtr conn,
|
|
virObjectEventState *state,
|
|
virClass *klass,
|
|
int eventID,
|
|
virConnectObjectEventGenericCallback callback,
|
|
int *remoteID)
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
|
|
ATTRIBUTE_NONNULL(5);
|
|
|
|
void *
|
|
virObjectEventNew(virClass *klass,
|
|
virObjectEventDispatchFunc dispatcher,
|
|
int eventID,
|
|
int id,
|
|
const char *name,
|
|
const unsigned char *uuid,
|
|
const char *key)
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(5)
|
|
ATTRIBUTE_NONNULL(7);
|