diff options
author | Jeremy White <jwhite@codeweavers.com> | 2012-09-05 09:59:33 -0500 |
---|---|---|
committer | Alon Levy <alevy@redhat.com> | 2012-09-05 19:18:34 +0300 |
commit | 5819976c7ed6669f4334bb5ec8b25cd213dd7e8a (patch) | |
tree | f144aab131cf3c2e986c5df39bfe70dd04910f73 /server | |
parent | bf29ff4296ad6462d2382f9166e79c043cc7e08c (diff) | |
download | spice-5819976c7ed6669f4334bb5ec8b25cd213dd7e8a.tar.gz spice-5819976c7ed6669f4334bb5ec8b25cd213dd7e8a.tar.xz spice-5819976c7ed6669f4334bb5ec8b25cd213dd7e8a.zip |
Implement spice_server_set_exit_on_disconnect to enable an option whereby the spice server shuts down on client disconnect.
Diffstat (limited to 'server')
-rw-r--r-- | server/reds.c | 14 | ||||
-rw-r--r-- | server/spice-server.syms | 4 | ||||
-rw-r--r-- | server/spice.h | 1 |
3 files changed, 19 insertions, 0 deletions
diff --git a/server/reds.c b/server/reds.c index 8ad8425d..98b316dd 100644 --- a/server/reds.c +++ b/server/reds.c @@ -119,6 +119,7 @@ void *red_tunnel = NULL; #endif int agent_mouse = TRUE; int agent_copypaste = TRUE; +static bool exit_on_disconnect = FALSE; #define MIGRATE_TIMEOUT (1000 * 10) /* 10sec */ #define MM_TIMER_GRANULARITY_MS (1000 / 30) @@ -673,6 +674,12 @@ void reds_client_disconnect(RedClient *client) { RedsMigTargetClient *mig_client; + if (exit_on_disconnect) + { + spice_info("Exiting server because of client disconnect.\n"); + exit(0); + } + if (!client || client->disconnecting) { return; } @@ -4061,6 +4068,13 @@ SPICE_GNUC_VISIBLE int spice_server_set_listen_socket_fd(SpiceServer *s, int lis return 0; } +SPICE_GNUC_VISIBLE int spice_server_set_exit_on_disconnect(SpiceServer *s, int flag) +{ + spice_assert(reds == s); + exit_on_disconnect = !!flag; + return 0; +} + SPICE_GNUC_VISIBLE int spice_server_set_noauth(SpiceServer *s) { spice_assert(reds == s); diff --git a/server/spice-server.syms b/server/spice-server.syms index 359791cf..fd2a423b 100644 --- a/server/spice-server.syms +++ b/server/spice-server.syms @@ -123,3 +123,7 @@ global: spice_server_vm_stop; spice_server_set_seamless_migration; } SPICE_SERVER_0.10.4; + +SPICE_SERVER_0.11.4 { + spice_server_set_exit_on_disconnect; +} SPICE_SERVER_0.11.2; diff --git a/server/spice.h b/server/spice.h index 0dc9d05b..fdcfbb76 100644 --- a/server/spice.h +++ b/server/spice.h @@ -427,6 +427,7 @@ int spice_server_set_compat_version(SpiceServer *s, int spice_server_set_port(SpiceServer *s, int port); void spice_server_set_addr(SpiceServer *s, const char *addr, int flags); int spice_server_set_listen_socket_fd(SpiceServer *s, int listen_fd); +int spice_server_set_exit_on_disconnect(SpiceServer *s, int flag); int spice_server_set_noauth(SpiceServer *s); int spice_server_set_sasl(SpiceServer *s, int enabled); int spice_server_set_sasl_appname(SpiceServer *s, const char *appname); |