Skip to content

Commit

Permalink
vnc: factor out qmp_query_client_list
Browse files Browse the repository at this point in the history
so we can reuse it for the new vnc query command.

Signed-off-by: Gerd Hoffmann <[email protected]>
  • Loading branch information
kraxel committed Jan 22, 2015
1 parent e5f34cd commit 2d29a43
Showing 1 changed file with 15 additions and 15 deletions.
30 changes: 15 additions & 15 deletions ui/vnc.c
Original file line number Diff line number Diff line change
Expand Up @@ -385,6 +385,20 @@ static VncDisplay *vnc_display_find(const char *id)
return NULL;
}

static VncClientInfoList *qmp_query_client_list(VncDisplay *vd)
{
VncClientInfoList *cinfo, *prev = NULL;
VncState *client;

QTAILQ_FOREACH(client, &vd->clients, next) {
cinfo = g_new0(VncClientInfoList, 1);
cinfo->value = qmp_query_vnc_client(client);
cinfo->next = prev;
prev = cinfo;
}
return prev;
}

VncInfo *qmp_query_vnc(Error **errp)
{
VncInfo *info = g_malloc0(sizeof(*info));
Expand All @@ -393,30 +407,16 @@ VncInfo *qmp_query_vnc(Error **errp)
if (vd == NULL || vd->display == NULL) {
info->enabled = false;
} else {
VncClientInfoList *cur_item = NULL;
struct sockaddr_storage sa;
socklen_t salen = sizeof(sa);
char host[NI_MAXHOST];
char serv[NI_MAXSERV];
VncState *client;

info->enabled = true;

/* for compatibility with the original command */
info->has_clients = true;

QTAILQ_FOREACH(client, &vd->clients, next) {
VncClientInfoList *cinfo = g_malloc0(sizeof(*info));
cinfo->value = qmp_query_vnc_client(client);

/* XXX: waiting for the qapi to support GSList */
if (!cur_item) {
info->clients = cur_item = cinfo;
} else {
cur_item->next = cinfo;
cur_item = cinfo;
}
}
info->clients = qmp_query_client_list(vd);

if (vd->lsock == -1) {
return info;
Expand Down

0 comments on commit 2d29a43

Please sign in to comment.