From: Victor Toso <me@xxxxxxxxxxxxxx> As spice_usb_device_manager_get() can fail for different reasons, we should ignore and continue but at least give a warning" Signed-off-by: Victor Toso <victortoso@xxxxxxxxxx> --- src/spice-option.c | 24 ++++++++++++++++++++---- 1 file changed, 20 insertions(+), 4 deletions(-) diff --git a/src/spice-option.c b/src/spice-option.c index c2b059e..08d449e 100644 --- a/src/spice-option.c +++ b/src/spice-option.c @@ -212,6 +212,18 @@ GOptionGroup* spice_get_option_group(void) return grp; } +SpiceUsbDeviceManager * +get_usb_device_manager_for_option(SpiceSession *session, const char *option) +{ + GError *err = NULL; + SpiceUsbDeviceManager *m = spice_usb_device_manager_get(session, &err); + if (!m) { + g_warning("Option %s is set but failed: %s", option, err->message); + g_error_free(err); + } + return m; +} + /** * spice_set_session_option: * @session: a #SpiceSession to set option upon @@ -261,16 +273,20 @@ void spice_set_session_option(SpiceSession *session) g_object_set(session, "smartcard-db", smartcard_db, NULL); } if (usbredir_auto_redirect_filter) { - SpiceUsbDeviceManager *m = spice_usb_device_manager_get(session, NULL); - if (m) + SpiceUsbDeviceManager *m = + get_usb_device_manager_for_option(session, "--spice-usbredir-auto-redirect-filter"); + if (m) { g_object_set(m, "auto-connect-filter", usbredir_auto_redirect_filter, NULL); + } } if (usbredir_redirect_on_connect) { - SpiceUsbDeviceManager *m = spice_usb_device_manager_get(session, NULL); - if (m) + SpiceUsbDeviceManager *m = + get_usb_device_manager_for_option(session, "--spice-usbredir-redirect-on-connect"); + if (m) { g_object_set(m, "redirect-on-connect", usbredir_redirect_on_connect, NULL); + } } if (disable_usbredir) g_object_set(session, "enable-usbredir", FALSE, NULL); -- 2.21.0 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel