diff --git a/renderers/video_renderer_gstreamer.c b/renderers/video_renderer_gstreamer.c index 3c8573a..c4b9184 100644 --- a/renderers/video_renderer_gstreamer.c +++ b/renderers/video_renderer_gstreamer.c @@ -30,8 +30,9 @@ struct video_renderer_s { logger_t *logger; GstElement *appsrc, *pipeline, *sink; GstBus *bus; -#ifdef X_DISPLAY_FIX - window_t *X11; + const char * server_name; +#ifdef X_DISPLAY_FIX + X11_Window_t * gst_window; #endif }; @@ -147,10 +148,14 @@ video_renderer_t *video_renderer_init(logger_t *logger, const char *server_name, renderer->appsrc = gst_bin_get_by_name (GST_BIN (renderer->pipeline), "video_source"); renderer->sink = gst_bin_get_by_name (GST_BIN (renderer->pipeline), "video_sink"); + + + + renderer->server_name = server_name; #ifdef X_DISPLAY_FIX - renderer->X11 = calloc(1, sizeof(window_t)); - assert(renderer->X11); - get_x_display(renderer->X11, server_name); + renderer->gst_window = calloc(1, sizeof(X11_Window_t)); + assert(renderer->gst_window); + get_X11_Display(renderer->gst_window); #endif return renderer; } @@ -173,8 +178,8 @@ void video_renderer_render_buffer(video_renderer_t *renderer, raop_ntp_t *ntp, u gst_app_src_push_buffer (GST_APP_SRC(renderer->appsrc), buffer); #ifdef X_DISPLAY_FIX - if(!renderer->X11->window) { - fix_x_window_name(renderer->X11); + if(!(renderer->gst_window->window)) { + fix_x_window_name(renderer->gst_window, renderer->server_name); } #endif } @@ -223,7 +228,7 @@ void video_renderer_destroy(video_renderer_t *renderer) { gst_element_set_state (renderer->pipeline, GST_STATE_NULL); gst_object_unref (renderer->pipeline); #ifdef X_DISPLAY_FIX - free(renderer->X11); + free(renderer->gst_window); #endif if (renderer) { free(renderer); diff --git a/renderers/x_display_fix.h b/renderers/x_display_fix.h index 7c01e77..4bc948d 100644 --- a/renderers/x_display_fix.h +++ b/renderers/x_display_fix.h @@ -30,20 +30,17 @@ extern "C" { #include #include -struct window_s { - Display * display; - Window window, root; - const char * name; -} typedef window_t; +struct X11_Window_s { + Display * display; + Window window; +} typedef X11_Window_t; -void get_x_display(window_t * X11, const char * window_name) { +void get_X11_Display(X11_Window_t * X11) { X11->display = XOpenDisplay(NULL); - X11->root = XDefaultRootWindow(X11->display); X11->window = (Window) NULL; - X11->name = window_name; } -Window enum_windows(const char * str, Display* display, Window window, int depth) { +Window enum_windows(const char * str, Display * display, Window window, int depth) { int i; XTextProperty text; XGetWMName(display, window, &text); @@ -66,13 +63,14 @@ Window enum_windows(const char * str, Display* display, Window window, int depth return (Window) NULL; } -void fix_x_window_name(window_t * X11) { - X11->window = enum_windows(X11->name, X11->display, X11->root, 0); +void fix_x_window_name(X11_Window_t * X11, const char * name) { + Window root = XDefaultRootWindow(X11->display); + X11->window = enum_windows(name, X11->display, root, 0); if (X11->window) { Atom _NET_WM_NAME = XInternAtom(X11->display, "_NET_WM_NAME", 0); Atom UTF8_STRING = XInternAtom(X11->display, "UTF8_STRING", 0); - XChangeProperty(X11->display, X11->window, _NET_WM_NAME, UTF8_STRING, 8, 0, - (const unsigned char *) X11->name, strlen(X11->name)); + XChangeProperty(X11->display, X11->window, _NET_WM_NAME, UTF8_STRING, + 8, 0, (const unsigned char *) name, strlen(name)); XSync(X11->display, False); } } diff --git a/uxplay.cpp b/uxplay.cpp index 45a509d..f719947 100755 --- a/uxplay.cpp +++ b/uxplay.cpp @@ -33,7 +33,7 @@ #include "renderers/video_renderer.h" #include "renderers/audio_renderer.h" -#define VERSION "1.33" +#define VERSION "1.34" #define DEFAULT_NAME "UxPlay" #define DEFAULT_DEBUG_LOG false