# HG changeset patch # User nenolod # Date 1138053206 28800 # Node ID 59739d266dba2703800dbfb50628156ee398e779 # Parent fc968772e0969e3f589b11169bfa62211b9a28ac [svn] Convert Xlib stuff to GDK/GTK. This isn't entirely set in stone yet -- (Always on Top has a minor bug remaining involving the transient windows attached to mainwin still.) diff -r fc968772e096 -r 59739d266dba audacious/hints.c --- a/audacious/hints.c Mon Jan 23 12:24:48 2006 -0800 +++ b/audacious/hints.c Mon Jan 23 13:53:26 2006 -0800 @@ -1,4 +1,7 @@ -/* BMP - Cross-platform multimedia player +/* Audacious - the quite insane multimedia player. + * Copyright (C) 2005-2006 Audacious team + * + * BMP - Cross-platform multimedia player * Copyright (C) 2003-2004 BMP development team. * * Based on XMMS: @@ -30,66 +33,13 @@ #include #include -#include -#include -#include - -/* flags for the window layer */ -typedef enum { - WIN_LAYER_DESKTOP = 0, - WIN_LAYER_BELOW = 2, - WIN_LAYER_NORMAL = 4, - WIN_LAYER_ONTOP = 6, - WIN_LAYER_DOCK = 8, - WIN_LAYER_ABOVE_DOCK = 10 -} WinLayer; - -#define WIN_STATE_STICKY (1 << 0) - -#define WIN_HINTS_SKIP_WINLIST (1 << 1) /* not in win list */ -#define WIN_HINTS_SKIP_TASKBAR (1 << 2) /* not on taskbar */ - -#define _NET_WM_STATE_REMOVE 0 -#define _NET_WM_STATE_ADD 1 -#define _NET_WM_STATE_TOGGLE 2 - -#define _NET_WM_MOVERESIZE_SIZE_TOPLEFT 0 -#define _NET_WM_MOVERESIZE_SIZE_TOP 1 -#define _NET_WM_MOVERESIZE_SIZE_TOPRIGHT 2 -#define _NET_WM_MOVERESIZE_SIZE_RIGHT 3 -#define _NET_WM_MOVERESIZE_SIZE_BOTTOMRIGHT 4 -#define _NET_WM_MOVERESIZE_SIZE_BOTTOM 5 -#define _NET_WM_MOVERESIZE_SIZE_BOTTOMLEFT 6 -#define _NET_WM_MOVERESIZE_SIZE_LEFT 7 -#define _NET_WM_MOVERESIZE_MOVE 8 - - -static void (*set_always_func) (GtkWidget *, gboolean) = NULL; -static void (*set_sticky_func) (GtkWidget *, gboolean) = NULL; -static void (*set_skip_winlist_func) (GtkWidget *) = NULL; -static void (*move_resize_func) (GtkWidget *, gint, gint, gboolean) = NULL; - -void -hint_set_skip_winlist(GtkWidget * window) -{ - if (set_skip_winlist_func) - set_skip_winlist_func(window); -} void hint_set_always(gboolean always) { - if (set_always_func) { - set_always_func(mainwin, always); - set_always_func(equalizerwin, always); - set_always_func(playlistwin, always); - } -} - -gboolean -hint_always_on_top_available(void) -{ - return !!set_always_func; + gtk_window_set_keep_above(GTK_WINDOW(mainwin), always); + gtk_window_set_keep_above(GTK_WINDOW(equalizerwin), always); + gtk_window_set_keep_above(GTK_WINDOW(playlistwin), always); } void @@ -107,231 +57,3 @@ } } -gboolean -hint_move_resize_available(void) -{ - return !!move_resize_func; -} - -void -hint_move_resize(GtkWidget * window, gint x, gint y, gboolean move) -{ - move_resize_func(window, x, y, move); -} - -static gboolean -net_wm_found(void) -{ - Atom r_type, support_check; - gint r_format, p; - gulong count, bytes_remain; - guchar *prop = NULL, *prop2 = NULL; - gboolean ret = FALSE; - - gdk_error_trap_push(); - support_check = - XInternAtom(GDK_DISPLAY(), "_NET_SUPPORTING_WM_CHECK", FALSE); - - p = XGetWindowProperty(GDK_DISPLAY(), GDK_ROOT_WINDOW(), support_check, - 0, 1, False, XA_WINDOW, &r_type, &r_format, - &count, &bytes_remain, &prop); - - if (p == Success && prop && r_type == XA_WINDOW && - r_format == 32 && count == 1) { - Window n = *(Window *) prop; - - p = XGetWindowProperty(GDK_DISPLAY(), n, support_check, 0, 1, - False, XA_WINDOW, &r_type, &r_format, - &count, &bytes_remain, &prop2); - - if (p == Success && prop2 && *prop2 == *prop && - r_type == XA_WINDOW && r_format == 32 && count == 1) - ret = TRUE; - } - - if (prop) - XFree(prop); - if (prop2) - XFree(prop2); - if (gdk_error_trap_pop()) - return FALSE; - return ret; -} - -static void -net_wm_set_property(GtkWidget * window, gchar * atom, gboolean state) -{ - XEvent xev; - gint set = _NET_WM_STATE_ADD; - Atom type, property; - - if (state == FALSE) - set = _NET_WM_STATE_REMOVE; - - type = XInternAtom(GDK_DISPLAY(), "_NET_WM_STATE", FALSE); - property = XInternAtom(GDK_DISPLAY(), atom, FALSE); - - - xev.type = ClientMessage; - xev.xclient.type = ClientMessage; - xev.xclient.window = GDK_WINDOW_XWINDOW(window->window); - xev.xclient.message_type = type; - xev.xclient.format = 32; - xev.xclient.data.l[0] = set; - xev.xclient.data.l[1] = property; - xev.xclient.data.l[2] = 0; - - XSendEvent(GDK_DISPLAY(), GDK_ROOT_WINDOW(), False, - SubstructureNotifyMask, &xev); -} - -static void -net_wm_set_desktop(GtkWidget * window, gboolean all) -{ - XEvent xev; - guint32 current_desktop = 0; - - if (!all) { - gint r_format, p; - gulong count, bytes_remain; - guchar *prop; - Atom r_type; - Atom current = - XInternAtom(GDK_DISPLAY(), "_NET_CURRENT_DESKTOP", FALSE); - - p = XGetWindowProperty(GDK_DISPLAY(), GDK_ROOT_WINDOW(), current, - 0, 1, False, XA_CARDINAL, &r_type, - &r_format, &count, &bytes_remain, &prop); - - if (p == Success && prop && r_type == XA_CARDINAL && - r_format == 32 && count == 1) { - current_desktop = *(long *) prop; - XFree(prop); - } - } - else - current_desktop = 0xffffffff; - - xev.type = ClientMessage; - xev.xclient.type = ClientMessage; - xev.xclient.window = GDK_WINDOW_XWINDOW(window->window); - xev.xclient.message_type = - XInternAtom(GDK_DISPLAY(), "_NET_WM_DESKTOP", FALSE); - xev.xclient.format = 32; - xev.xclient.data.l[0] = current_desktop; - - XSendEvent(GDK_DISPLAY(), GDK_ROOT_WINDOW(), False, - SubstructureNotifyMask, &xev); -} - - - -static void -net_wm_set_window_always(GtkWidget * window, gboolean always) -{ - net_wm_set_property(window, "_NET_WM_STATE_STAYS_ON_TOP", always); -} - -static void -net_wm_set_window_above(GtkWidget * window, gboolean always) -{ - net_wm_set_property(window, "_NET_WM_STATE_ABOVE", always); -} - -static void -net_wm_move_resize(GtkWidget * window, gint x, gint y, gboolean move) -{ - XEvent xev; - gint dir; - Atom type; - - if (move) - dir = _NET_WM_MOVERESIZE_MOVE; - else - dir = _NET_WM_MOVERESIZE_SIZE_BOTTOMRIGHT; - - gdk_pointer_ungrab(GDK_CURRENT_TIME); - - type = XInternAtom(GDK_DISPLAY(), "_NET_WM_MOVERESIZE", FALSE); - - xev.type = ClientMessage; - xev.xclient.type = ClientMessage; - xev.xclient.window = GDK_WINDOW_XWINDOW(window->window); - xev.xclient.message_type = type; - xev.xclient.format = 32; - xev.xclient.data.l[0] = x; - xev.xclient.data.l[1] = y; - xev.xclient.data.l[2] = dir; - xev.xclient.data.l[3] = 1; /* button */ - - - XSendEvent(GDK_DISPLAY(), GDK_ROOT_WINDOW(), False, - SubstructureNotifyMask, &xev); -} - -static gboolean -find_atom(Atom * atoms, gint n, const gchar * name) -{ - Atom a = XInternAtom(GDK_DISPLAY(), name, FALSE); - gint i; - - for (i = 0; i < n; i++) - if (a == atoms[i]) - return TRUE; - return FALSE; -} - -static gboolean -get_supported_atoms(Atom ** atoms, gulong * natoms, const gchar * name) -{ - Atom supported = XInternAtom(GDK_DISPLAY(), name, FALSE), r_type; - gulong bremain; - gint r_format, p; - - *atoms = NULL; - gdk_error_trap_push(); - p = XGetWindowProperty(GDK_DISPLAY(), GDK_ROOT_WINDOW(), supported, - 0, 1000, False, XA_ATOM, &r_type, &r_format, - natoms, &bremain, (guchar **) atoms); - if (gdk_error_trap_pop() || p != Success || r_type != XA_ATOM || - *natoms == 0 || *atoms == NULL) - return FALSE; - - return TRUE; -} - -static void -net_wm_check_features(void) -{ - Atom *atoms; - gulong n_atoms; - - if (!get_supported_atoms(&atoms, &n_atoms, "_NET_SUPPORTED")) - return; - - if (find_atom(atoms, n_atoms, "_NET_WM_STATE")) { - if (!set_always_func && - find_atom(atoms, n_atoms, "_NET_WM_STATE_ABOVE")) - set_always_func = net_wm_set_window_above; - if (!set_always_func && - find_atom(atoms, n_atoms, "_NET_WM_STATE_STAYS_ON_TOP")) - set_always_func = net_wm_set_window_always; - if (!set_sticky_func && find_atom(atoms, n_atoms, "_NET_WM_DESKTOP")) - set_sticky_func = net_wm_set_desktop; - } - - if (find_atom(atoms, n_atoms, "_NET_WM_MOVERESIZE")) - move_resize_func = net_wm_move_resize; - - XFree(atoms); -} - -void -check_wm_hints(void) -{ - if (net_wm_found()) { - g_message("found NET_WM"); - net_wm_check_features(); - } - -} diff -r fc968772e096 -r 59739d266dba audacious/main.c --- a/audacious/main.c Mon Jan 23 12:24:48 2006 -0800 +++ b/audacious/main.c Mon Jan 23 13:53:26 2006 -0800 @@ -975,8 +975,6 @@ if (options.headless != 1) { - check_wm_hints(); - bmp_set_default_icon(); gtk_accel_map_load(bmp_paths[BMP_PATH_ACCEL_FILE]); diff -r fc968772e096 -r 59739d266dba audacious/mainwin.c --- a/audacious/mainwin.c Mon Jan 23 12:24:48 2006 -0800 +++ b/audacious/mainwin.c Mon Jan 23 13:53:26 2006 -0800 @@ -2595,13 +2595,7 @@ mainwin_lock_info_text(_("OPTIONS MENU")); break; case MENUROW_ALWAYS: - if (!hint_always_on_top_available()) { - if (mainwin_menurow->mr_always_selected) - mainwin_lock_info_text(_("DISABLE ALWAYS ON TOP (N/A)")); - else - mainwin_lock_info_text(_("ENABLE ALWAYS ON TOP (N/A)")); - } - else if (mainwin_menurow->mr_doublesize_selected) + if (mainwin_menurow->mr_doublesize_selected) mainwin_lock_info_text(_("DISABLE ALWAYS ON TOP")); else mainwin_lock_info_text(_("ENABLE ALWAYS ON TOP"));