]> Dogcows Code - chaz/tint2/commitdiff
Drag n drop over Task bring Focus by Andreas.Fink85
authorThierry Lorthiois <lorthiois@bbsoft.fr>
Tue, 8 Sep 2009 21:29:32 +0000 (21:29 +0000)
committerThierry Lorthiois <lorthiois@bbsoft.fr>
Tue, 8 Sep 2009 21:29:32 +0000 (21:29 +0000)
ChangeLog
src/panel.c
src/server.c
src/server.h
src/tint.c
tintrc01

index e23497eff494ae7e29e56bba0ba90a6eb0eddfea..7fe06d1b3dce512197da131847cd2721465fc513 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,6 @@
+2009-09-08
+- Drag n drop over Task bring Focus by Andreas.Fink85
+
 2009-09-07
 - fixed issue 117 : support skip_taskbar by Andreas.Fink85
 - cleanup : switch space to tab
index 4c2093a23f0af2548b1e73895e116bea64c15754..5275d38c5c557344c05dbf58f9581bbbf39b2554 100644 (file)
@@ -376,6 +376,10 @@ void set_panel_properties(Panel *p)
        // Undecorated
        long prop[5] = { 2, 0, 0, 0, 0 };
        XChangeProperty(server.dsp, p->main_win, server.atom._MOTIF_WM_HINTS, server.atom._MOTIF_WM_HINTS, 32, PropModeReplace, (unsigned char *) prop, 5);
+
+       // XdndAware - Register for Xdnd events
+       int version=5;
+       XChangeProperty(server.dsp, p->main_win, server.atom.XdndAware, XA_ATOM, 32, PropModeReplace, (unsigned char*)&version, 1);
 }
 
 
index 61fa257b99ddd4a73f99044412e504d44403416e..4f655617df1e51e6259695c2f9fbe33a528c78e9 100644 (file)
@@ -83,6 +83,11 @@ void server_init_atoms ()
        server.atom._NET_SYSTEM_TRAY_ORIENTATION = XInternAtom(server.dsp, "_NET_SYSTEM_TRAY_ORIENTATION", False);
        server.atom._XEMBED = XInternAtom(server.dsp, "_XEMBED", False);
        server.atom._XEMBED_INFO = XInternAtom(server.dsp, "_XEMBED_INFO", False);
+
+       // drag 'n' drop
+       server.atom.XdndAware = XInternAtom(server.dsp, "XdndAware", False);
+       server.atom.XdndPosition = XInternAtom(server.dsp, "XdndPosition", False);
+       server.atom.XdndStatus = XInternAtom(server.dsp, "XdndStatus", False);
 }
 
 
index 48931ef68ca871c4a8317f364f3d82952b8435ec..5ece8a46e7bef235f7337134dd5e746161cb0826 100644 (file)
@@ -62,6 +62,9 @@ typedef struct Global_atom
        Atom _NET_SYSTEM_TRAY_ORIENTATION;
        Atom _XEMBED;
        Atom _XEMBED_INFO;
+       Atom XdndAware;
+       Atom XdndPosition;
+       Atom XdndStatus;
 } Global_atom;
 
 
index ac6980bdedc045696a62b7cfd7571422da5252d5..70c6f5bd314dd83df088f987c39211695c4a73d1 100644 (file)
@@ -51,12 +51,19 @@ void init (int argc, char *argv[])
        int c;
 
        // read options
-       c = getopt (argc, argv, "c:");
-       if (c != -1) {
-               config_path = strdup (optarg);
-               c = getopt (argc, argv, "j:");
-               if (c != -1)
+       while ((c = getopt(argc , argv, "c:j:v")) != -1) {
+               switch (c) {
+                       case 'c':
+                       config_path = strdup (optarg);
+                       break;
+                       case 'j':
                        thumbnail_path = strdup (optarg);
+                       break;
+                       case 'v':
+                       printf("tint2 version 0.7-svn\n");
+                       exit(0);
+                       break;
+               }
        }
 
        // Set signal handler
@@ -125,12 +132,11 @@ void cleanup()
 }
 
 
-Taskbar *click_taskbar (Panel *panel, XEvent *e)
+Taskbar *click_taskbar (Panel *panel, int x, int y)
 {
        GSList *l0;
        Taskbar *tskbar = NULL;
        if (panel_horizontal) {
-               int x = e->xbutton.x;
                for (l0 = panel->area.list; l0 ; l0 = l0->next) {
                        tskbar = l0->data;
                        if (!tskbar->area.on_screen) continue;
@@ -139,7 +145,6 @@ Taskbar *click_taskbar (Panel *panel, XEvent *e)
                }
        }
        else {
-               int y = e->xbutton.y;
                for (l0 = panel->area.list; l0 ; l0 = l0->next) {
                        tskbar = l0->data;
                        if (!tskbar->area.on_screen) continue;
@@ -151,14 +156,13 @@ Taskbar *click_taskbar (Panel *panel, XEvent *e)
 }
 
 
-Task *click_task (Panel *panel, XEvent *e)
+Task *click_task (Panel *panel, int x, int y)
 {
        GSList *l0;
        Taskbar *tskbar;
 
-       if ( (tskbar = click_taskbar(panel, e)) ) {
+       if ( (tskbar = click_taskbar(panel, x, y)) ) {
                if (panel_horizontal) {
-                       int x = e->xbutton.x;
                        Task *tsk;
                        for (l0 = tskbar->area.list; l0 ; l0 = l0->next) {
                                tsk = l0->data;
@@ -168,7 +172,6 @@ Task *click_task (Panel *panel, XEvent *e)
                        }
                }
                else {
-                       int y = e->xbutton.y;
                        Task *tsk;
                        for (l0 = tskbar->area.list; l0 ; l0 = l0->next) {
                                tsk = l0->data;
@@ -182,28 +185,28 @@ Task *click_task (Panel *panel, XEvent *e)
 }
 
 
-int click_padding(Panel *panel, XEvent *e)
+int click_padding(Panel *panel, int x, int y)
 {
        if (panel_horizontal) {
-               if (e->xbutton.x < panel->area.paddingxlr || e->xbutton.x > panel->area.width-panel->area.paddingxlr)
+               if (x < panel->area.paddingxlr || x > panel->area.width-panel->area.paddingxlr)
                return 1;
        }
        else {
-               if (e->xbutton.y < panel->area.paddingxlr || e->xbutton.y > panel->area.height-panel->area.paddingxlr)
+               if (y < panel->area.paddingxlr || y > panel->area.height-panel->area.paddingxlr)
                return 1;
        }
        return 0;
 }
 
 
-int click_clock(Panel *panel, XEvent *e)
+int click_clock(Panel *panel, int x, int y)
 {
        Clock clk = panel->clock;
        if (panel_horizontal) {
-               if (clk.area.on_screen && e->xbutton.x >= clk.area.posx && e->xbutton.x <= (clk.area.posx + clk.area.width))
+               if (clk.area.on_screen && x >= clk.area.posx && x <= (clk.area.posx + clk.area.width))
                        return TRUE;
        } else {
-               if (clk.area.on_screen && e->xbutton.y >= clk.area.posy && e->xbutton.y <= (clk.area.posy + clk.area.height))
+               if (clk.area.on_screen && y >= clk.area.posy && y <= (clk.area.posy + clk.area.height))
                        return TRUE;
        }
        return FALSE;
@@ -263,9 +266,9 @@ void event_button_press (XEvent *e)
        if (!panel) return;
 
        if (panel_mode == MULTI_DESKTOP)
-               task_drag = click_task(panel, e);
+               task_drag = click_task(panel, e->xbutton.x, e->xbutton.y);
 
-       if (wm_menu && !task_drag && !click_clock(panel, e) && (e->xbutton.button != 1) ) {
+       if (wm_menu && !task_drag && !click_clock(panel, e->xbutton.x, e->xbutton.y) && (e->xbutton.button != 1) ) {
                // forward the click to the desktop window (thanks conky)
                XUngrabPointer(server.dsp, e->xbutton.time);
                e->xbutton.window = server.root_win;
@@ -288,7 +291,7 @@ void event_button_release (XEvent *e)
        Panel *panel = get_panel(e->xany.window);
        if (!panel) return;
 
-       if (wm_menu && click_padding(panel, e)) {
+       if (wm_menu && click_padding(panel, e->xbutton.x, e->xbutton.y)) {
                        // forward the click to the desktop window (thanks conky)
                        e->xbutton.window = server.root_win;
                        XSendEvent(server.dsp, e->xbutton.window, False, ButtonReleaseMask, e);
@@ -317,7 +320,7 @@ void event_button_release (XEvent *e)
                        break;
        }
 
-       if ( click_clock(panel, e)) {
+       if ( click_clock(panel, e->xbutton.x, e->xbutton.y)) {
                clock_action(e->xbutton.button);
                XLowerWindow (server.dsp, panel->main_win);
                task_drag = 0;
@@ -325,7 +328,7 @@ void event_button_release (XEvent *e)
        }
 
        Taskbar *tskbar;
-       if ( !(tskbar = click_taskbar(panel, e)) ) {
+       if ( !(tskbar = click_taskbar(panel, e->xbutton.x, e->xbutton.y)) ) {
                // TODO: check better solution to keep window below
                XLowerWindow (server.dsp, panel->main_win);
                task_drag = 0;
@@ -353,7 +356,7 @@ void event_button_release (XEvent *e)
        }
 
        // action on task
-       window_action( click_task(panel, e), action);
+       window_action( click_task(panel, e->xbutton.x, e->xbutton.y), action);
 
        // to keep window below
        XLowerWindow (server.dsp, panel->main_win);
@@ -665,6 +668,36 @@ void event_timer()
 }
 
 
+void dnd_message(XClientMessageEvent *e)
+{
+       Panel *panel = get_panel(e->window);
+       int x, y, mapX, mapY;
+       Window child;
+       x = (e->data.l[2] >> 16) & 0xFFFF;
+       y = e->data.l[2] & 0xFFFF;
+       XTranslateCoordinates(server.dsp, server.root_win, e->window, x, y, &mapX, &mapY, &child);
+       Task* task = click_task(panel, mapX, mapY);
+       if (task) {
+               if (task->desktop != server.desktop )
+                       set_desktop (task->desktop);
+               window_action(task, TOGGLE);
+       }
+
+       // send XdndStatus event to get more XdndPosition events
+       XClientMessageEvent se;
+       se.type = ClientMessage;
+       se.window = e->data.l[0];
+       se.message_type = server.atom.XdndStatus;
+       se.format = 32;
+       se.data.l[0] = e->window;  // XID of the target window
+       se.data.l[1] = 0;          // bit 0: accept drop    bit 1: send XdndPosition events if inside rectangle
+       se.data.l[2] = 0;          // Rectangle x,y for which no more XdndPosition events
+       se.data.l[3] = (1 << 16) | 1;  // Rectangle w,h for which no more XdndPosition events
+       se.data.l[4] = None;       // None = drop will not be accepted
+       XSendEvent(server.dsp, e->data.l[0], False, NoEventMask, (XEvent*)&se);
+}
+
+
 int main (int argc, char *argv[])
 {
        XEvent e;
@@ -762,6 +795,9 @@ load_config:
                                                if (e.xclient.message_type == server.atom._NET_SYSTEM_TRAY_OPCODE && e.xclient.format == 32 && e.xclient.window == net_sel_win) {
                                                        net_message(&e.xclient);
                                                }
+                                               else if (e.xclient.message_type == server.atom.XdndPosition) {
+                                                       dnd_message(&e.xclient);
+                                               }
                                                break;
                                }
                        }
index d1398aeb8e9b7396d5f4a81cb022ce208ad636a5..9a24bcac884f3e37298694e5d24f68c75517771a 100644 (file)
--- a/tintrc01
+++ b/tintrc01
@@ -58,7 +58,7 @@ task_active_background_id = 2
 #---------------------------------------------
 # SYSTRAYBAR
 #---------------------------------------------
-systray_padding = 0 4 5
+#systray_padding = 0 4 5
 systray_background_id = 0
 
 #---------------------------------------------
This page took 0.034198 seconds and 4 git commands to generate.