summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMarc-André Lureau <marcandre.lureau@gmail.com>2014-07-03 18:42:37 +0200
committerMarc-André Lureau <marcandre.lureau@gmail.com>2014-07-08 16:36:52 +0200
commit225dff3cb068d8920d647d1e0a07f3f352bbc8d4 (patch)
tree385a40ba82b89d3381c794dfc383f7fbd694c1cb /src
parentdf28177c679e8ba0a7cf069c5f816167a0a96904 (diff)
downloadvirt-viewer-225dff3cb068d8920d647d1e0a07f3f352bbc8d4.tar.gz
virt-viewer-225dff3cb068d8920d647d1e0a07f3f352bbc8d4.tar.xz
virt-viewer-225dff3cb068d8920d647d1e0a07f3f352bbc8d4.zip
app: report disconnection error details
It may be useful to provide more detailed reason for disconnection. https://bugzilla.redhat.com/show_bug.cgi?id=1115986
Diffstat (limited to 'src')
-rw-r--r--src/virt-viewer-app.c6
-rw-r--r--src/virt-viewer-session-spice.c8
-rw-r--r--src/virt-viewer-session-vnc.c2
-rw-r--r--src/virt-viewer-session.c5
-rw-r--r--src/virt-viewer-session.h2
5 files changed, 13 insertions, 10 deletions
diff --git a/src/virt-viewer-app.c b/src/virt-viewer-app.c
index 1610a2e..45ab1c0 100644
--- a/src/virt-viewer-app.c
+++ b/src/virt-viewer-app.c
@@ -75,6 +75,7 @@ static void virt_viewer_app_connected(VirtViewerSession *session,
static void virt_viewer_app_initialized(VirtViewerSession *session,
VirtViewerApp *self);
static void virt_viewer_app_disconnected(VirtViewerSession *session,
+ const gchar *msg,
VirtViewerApp *self);
static void virt_viewer_app_auth_refused(VirtViewerSession *session,
const char *msg,
@@ -1326,7 +1327,7 @@ virt_viewer_app_initialized(VirtViewerSession *session G_GNUC_UNUSED,
}
static void
-virt_viewer_app_disconnected(VirtViewerSession *session G_GNUC_UNUSED,
+virt_viewer_app_disconnected(VirtViewerSession *session G_GNUC_UNUSED, const gchar *msg,
VirtViewerApp *self)
{
VirtViewerAppPrivate *priv = self->priv;
@@ -1342,6 +1343,7 @@ virt_viewer_app_disconnected(VirtViewerSession *session G_GNUC_UNUSED,
GtkWidget *dialog = virt_viewer_app_make_message_dialog(self,
_("Unable to connect to the graphic server %s"), priv->pretty_address);
+ g_object_set(dialog, "secondary-text", msg, NULL);
gtk_dialog_run(GTK_DIALOG(dialog));
gtk_widget_destroy(dialog);
}
@@ -1354,7 +1356,7 @@ static void virt_viewer_app_cancelled(VirtViewerSession *session,
{
VirtViewerAppPrivate *priv = self->priv;
priv->cancelled = TRUE;
- virt_viewer_app_disconnected(session, self);
+ virt_viewer_app_disconnected(session, NULL, self);
}
diff --git a/src/virt-viewer-session-spice.c b/src/virt-viewer-session-spice.c
index 255b3ee..2d4e67d 100644
--- a/src/virt-viewer-session-spice.c
+++ b/src/virt-viewer-session-spice.c
@@ -547,18 +547,18 @@ virt_viewer_session_spice_main_channel_event(SpiceChannel *channel G_GNUC_UNUSED
spice_session_connect(self->priv->session);
}
} else {
- g_signal_emit_by_name(session, "session-disconnected");
+ g_signal_emit_by_name(session, "session-disconnected", error->message);
}
}
#else
g_debug("main channel: failed to connect");
- g_signal_emit_by_name(session, "session-disconnected");
+ g_signal_emit_by_name(session, "session-disconnected", NULL);
#endif
break;
case SPICE_CHANNEL_ERROR_IO:
case SPICE_CHANNEL_ERROR_LINK:
case SPICE_CHANNEL_ERROR_TLS:
- g_signal_emit_by_name(session, "session-disconnected");
+ g_signal_emit_by_name(session, "session-disconnected", NULL);
break;
default:
g_warning("unhandled spice main channel event: %d", event);
@@ -850,7 +850,7 @@ virt_viewer_session_spice_channel_destroy(G_GNUC_UNUSED SpiceSession *s,
self->priv->channel_count--;
if (self->priv->channel_count == 0)
- g_signal_emit_by_name(self, "session-disconnected");
+ g_signal_emit_by_name(self, "session-disconnected", NULL);
}
#define UUID_LEN 16
diff --git a/src/virt-viewer-session-vnc.c b/src/virt-viewer-session-vnc.c
index 37e66c5..e2f90f2 100644
--- a/src/virt-viewer-session-vnc.c
+++ b/src/virt-viewer-session-vnc.c
@@ -113,7 +113,7 @@ virt_viewer_session_vnc_disconnected(VncDisplay *vnc G_GNUC_UNUSED,
virt_viewer_session_clear_displays(VIRT_VIEWER_SESSION(session));
display = virt_viewer_display_vnc_new(session->priv->vnc);
g_debug("Disconnected");
- g_signal_emit_by_name(session, "session-disconnected");
+ g_signal_emit_by_name(session, "session-disconnected", NULL);
virt_viewer_display_set_show_hint(VIRT_VIEWER_DISPLAY(display),
VIRT_VIEWER_DISPLAY_SHOW_HINT_READY, FALSE);
}
diff --git a/src/virt-viewer-session.c b/src/virt-viewer-session.c
index b600481..c432719 100644
--- a/src/virt-viewer-session.c
+++ b/src/virt-viewer-session.c
@@ -220,9 +220,10 @@ virt_viewer_session_class_init(VirtViewerSessionClass *class)
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET(VirtViewerSessionClass, session_disconnected),
NULL, NULL,
- g_cclosure_marshal_VOID__VOID,
+ g_cclosure_marshal_VOID__STRING,
G_TYPE_NONE,
- 0);
+ 1,
+ G_TYPE_STRING);
g_signal_new("session-channel-open",
G_OBJECT_CLASS_TYPE(object_class),
diff --git a/src/virt-viewer-session.h b/src/virt-viewer-session.h
index 388d675..316fdf0 100644
--- a/src/virt-viewer-session.h
+++ b/src/virt-viewer-session.h
@@ -78,7 +78,7 @@ struct _VirtViewerSessionClass {
/* signals */
void (*session_connected)(VirtViewerSession *session);
void (*session_initialized)(VirtViewerSession *session);
- void (*session_disconnected)(VirtViewerSession *session);
+ void (*session_disconnected)(VirtViewerSession *session, const gchar *msg);
void (*session_auth_refused)(VirtViewerSession *session, const gchar *msg);
void (*session_auth_failed)(VirtViewerSession *session, const gchar *msg);
void (*session_usb_failed)(VirtViewerSession *session, const gchar *msg);