Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
8d53d6ab
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看板
提交
8d53d6ab
编写于
11月 22, 2013
作者:
C
Cédric Bosdonnat
提交者:
Daniel P. Berrange
12月 10, 2013
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Create virDomainEventTrayChange to get rid of the huge union
上级
bc7b3043
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
40 addition
and
17 deletion
+40
-17
src/conf/domain_event.c
src/conf/domain_event.c
+40
-17
未找到文件。
src/conf/domain_event.c
浏览文件 @
8d53d6ab
...
...
@@ -92,6 +92,7 @@ static virClassPtr virDomainEventIOErrorClass;
static
virClassPtr
virDomainEventGraphicsClass
;
static
virClassPtr
virDomainEventBlockJobClass
;
static
virClassPtr
virDomainEventDiskChangeClass
;
static
virClassPtr
virDomainEventTrayChangeClass
;
static
void
virObjectEventDispose
(
void
*
obj
);
static
void
virDomainEventDispose
(
void
*
obj
);
...
...
@@ -102,6 +103,7 @@ static void virDomainEventIOErrorDispose(void *obj);
static
void
virDomainEventGraphicsDispose
(
void
*
obj
);
static
void
virDomainEventBlockJobDispose
(
void
*
obj
);
static
void
virDomainEventDiskChangeDispose
(
void
*
obj
);
static
void
virDomainEventTrayChangeDispose
(
void
*
obj
);
struct
_virObjectEvent
{
virObject
parent
;
...
...
@@ -114,10 +116,6 @@ struct _virDomainEvent {
virObjectMeta
meta
;
union
{
struct
{
char
*
devAlias
;
int
reason
;
}
trayChange
;
struct
{
/* In unit of 1024 bytes */
unsigned
long
long
actual
;
...
...
@@ -197,6 +195,15 @@ struct _virDomainEventDiskChange {
typedef
struct
_virDomainEventDiskChange
virDomainEventDiskChange
;
typedef
virDomainEventDiskChange
*
virDomainEventDiskChangePtr
;
struct
_virDomainEventTrayChange
{
virDomainEvent
parent
;
char
*
devAlias
;
int
reason
;
};
typedef
struct
_virDomainEventTrayChange
virDomainEventTrayChange
;
typedef
virDomainEventTrayChange
*
virDomainEventTrayChangePtr
;
static
int
virObjectEventOnceInit
(
void
)
{
...
...
@@ -254,6 +261,12 @@ static int virObjectEventOnceInit(void)
sizeof
(
virDomainEventDiskChange
),
virDomainEventDiskChangeDispose
)))
return
-
1
;
if
(
!
(
virDomainEventTrayChangeClass
=
virClassNew
(
virDomainEventClass
,
"virDomainEventTrayChange"
,
sizeof
(
virDomainEventTrayChange
),
virDomainEventTrayChangeDispose
)))
return
-
1
;
return
0
;
}
...
...
@@ -286,9 +299,6 @@ static void virDomainEventDispose(void *obj)
switch
(
virObjectEventGetEventID
(
event
))
{
case
VIR_DOMAIN_EVENT_ID_TRAY_CHANGE
:
VIR_FREE
(
event
->
data
.
trayChange
.
devAlias
);
break
;
case
VIR_DOMAIN_EVENT_ID_DEVICE_REMOVED
:
VIR_FREE
(
event
->
data
.
deviceRemoved
.
devAlias
);
break
;
...
...
@@ -369,6 +379,14 @@ static void virDomainEventDiskChangeDispose(void *obj)
VIR_FREE
(
event
->
devAlias
);
}
static
void
virDomainEventTrayChangeDispose
(
void
*
obj
)
{
virDomainEventTrayChangePtr
event
=
obj
;
VIR_DEBUG
(
"obj=%p"
,
event
);
VIR_FREE
(
event
->
devAlias
);
}
/**
* virObjectEventCallbackListFree:
* @list: event callback list head
...
...
@@ -1332,22 +1350,22 @@ virDomainEventTrayChangeNew(int id, const char *name,
const
char
*
devAlias
,
int
reason
)
{
virDomainEventPtr
ev
;
virDomainEvent
TrayChange
Ptr
ev
;
if
(
virObjectEventInitialize
()
<
0
)
return
NULL
;
if
(
!
(
ev
=
virDomainEventNew
(
virDomainEventClass
,
if
(
!
(
ev
=
virDomainEventNew
(
virDomainEvent
TrayChange
Class
,
VIR_DOMAIN_EVENT_ID_TRAY_CHANGE
,
id
,
name
,
uuid
)))
return
NULL
;
if
(
VIR_STRDUP
(
ev
->
d
ata
.
trayChange
.
d
evAlias
,
devAlias
)
<
0
)
if
(
VIR_STRDUP
(
ev
->
devAlias
,
devAlias
)
<
0
)
goto
error
;
ev
->
data
.
trayChange
.
reason
=
reason
;
ev
->
reason
=
reason
;
return
ev
;
return
(
virDomainEventPtr
)
ev
;
error:
virObjectUnref
(
ev
);
...
...
@@ -1705,11 +1723,16 @@ virDomainEventDispatchDefaultFunc(virConnectPtr conn,
}
case
VIR_DOMAIN_EVENT_ID_TRAY_CHANGE
:
((
virConnectDomainEventTrayChangeCallback
)
cb
)(
conn
,
dom
,
event
->
data
.
trayChange
.
devAlias
,
event
->
data
.
trayChange
.
reason
,
cbopaque
);
goto
cleanup
;
{
virDomainEventTrayChangePtr
trayChangeEvent
;
trayChangeEvent
=
(
virDomainEventTrayChangePtr
)
event
;
((
virConnectDomainEventTrayChangeCallback
)
cb
)(
conn
,
dom
,
trayChangeEvent
->
devAlias
,
trayChangeEvent
->
reason
,
cbopaque
);
goto
cleanup
;
}
case
VIR_DOMAIN_EVENT_ID_PMWAKEUP
:
((
virConnectDomainEventPMWakeupCallback
)
cb
)(
conn
,
dom
,
0
,
cbopaque
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录