Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
0d1d632d
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
0d1d632d
编写于
11月 21, 2013
作者:
C
Cédric Bosdonnat
提交者:
Daniel P. Berrange
12月 10, 2013
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Create virDomainEventLifecycle to start removing the huge union
上级
de463feb
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
41 addition
and
16 deletion
+41
-16
src/conf/domain_event.c
src/conf/domain_event.c
+41
-16
未找到文件。
src/conf/domain_event.c
浏览文件 @
0d1d632d
...
...
@@ -85,8 +85,10 @@ struct _virObjectEventCallback {
static
virClassPtr
virObjectEventClass
;
static
virClassPtr
virDomainEventClass
;
static
virClassPtr
virDomainEventLifecycleClass
;
static
void
virObjectEventDispose
(
void
*
obj
);
static
void
virDomainEventDispose
(
void
*
obj
);
static
void
virDomainEventLifecycleDispose
(
void
*
obj
);
struct
_virObjectEvent
{
virObject
parent
;
...
...
@@ -99,10 +101,6 @@ struct _virDomainEvent {
virObjectMeta
meta
;
union
{
struct
{
int
type
;
int
detail
;
}
lifecycle
;
struct
{
long
long
offset
;
}
rtcChange
;
...
...
@@ -147,6 +145,16 @@ struct _virDomainEvent {
}
data
;
};
struct
_virDomainEventLifecycle
{
virDomainEvent
parent
;
int
type
;
int
detail
;
};
typedef
struct
_virDomainEventLifecycle
virDomainEventLifecycle
;
typedef
virDomainEventLifecycle
*
virDomainEventLifecyclePtr
;
static
int
virObjectEventOnceInit
(
void
)
{
if
(
!
(
virObjectEventClass
=
...
...
@@ -161,6 +169,12 @@ static int virObjectEventOnceInit(void)
sizeof
(
virDomainEvent
),
virDomainEventDispose
)))
return
-
1
;
if
(
!
(
virDomainEventLifecycleClass
=
virClassNew
(
virDomainEventClass
,
"virDomainEventLifecycle"
,
sizeof
(
virDomainEventLifecycle
),
virDomainEventLifecycleDispose
)))
return
-
1
;
return
0
;
}
...
...
@@ -241,6 +255,12 @@ static void virDomainEventDispose(void *obj)
VIR_FREE
(
event
->
meta
.
name
);
}
static
void
virDomainEventLifecycleDispose
(
void
*
obj
)
{
virDomainEventLifecyclePtr
event
=
obj
;
VIR_DEBUG
(
"obj=%p"
,
event
);
}
/**
* virObjectEventCallbackListFree:
* @list: event callback list head
...
...
@@ -774,20 +794,20 @@ virDomainEventPtr virDomainEventNew(int id, const char *name,
const
unsigned
char
*
uuid
,
int
type
,
int
detail
)
{
virDomainEventPtr
event
;
virDomainEvent
Lifecycle
Ptr
event
;
if
(
virObjectEventInitialize
()
<
0
)
return
NULL
;
if
(
!
(
event
=
virDomainEventNewInternal
(
virDomainEventClass
,
VIR_DOMAIN_EVENT_ID_LIFECYCLE
,
id
,
name
,
uuid
)))
if
(
!
(
event
=
virDomainEventNewInternal
(
virDomainEvent
Lifecycle
Class
,
VIR_DOMAIN_EVENT_ID_LIFECYCLE
,
id
,
name
,
uuid
)))
return
NULL
;
event
->
data
.
lifecycle
.
type
=
type
;
event
->
d
ata
.
lifecycle
.
d
etail
=
detail
;
event
->
type
=
type
;
event
->
detail
=
detail
;
return
event
;
return
(
virDomainEventPtr
)
event
;
}
virDomainEventPtr
virDomainEventNewFromDom
(
virDomainPtr
dom
,
int
type
,
int
detail
)
...
...
@@ -1460,11 +1480,16 @@ virDomainEventDispatchDefaultFunc(virConnectPtr conn,
switch
((
virDomainEventID
)
eventID
)
{
case
VIR_DOMAIN_EVENT_ID_LIFECYCLE
:
((
virConnectDomainEventCallback
)
cb
)(
conn
,
dom
,
event
->
data
.
lifecycle
.
type
,
event
->
data
.
lifecycle
.
detail
,
cbopaque
);
goto
cleanup
;
{
virDomainEventLifecyclePtr
lifecycleEvent
;
lifecycleEvent
=
(
virDomainEventLifecyclePtr
)
event
;
((
virConnectDomainEventCallback
)
cb
)(
conn
,
dom
,
lifecycleEvent
->
type
,
lifecycleEvent
->
detail
,
cbopaque
);
goto
cleanup
;
}
case
VIR_DOMAIN_EVENT_ID_REBOOT
:
(
cb
)(
conn
,
dom
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录