… | |
… | |
1401 | case ButtonRelease: |
1401 | case ButtonRelease: |
1402 | button_release (ev.xbutton); |
1402 | button_release (ev.xbutton); |
1403 | break; |
1403 | break; |
1404 | |
1404 | |
1405 | case ClientMessage: |
1405 | case ClientMessage: |
1406 | if (ev.xclient.format == 32) |
1406 | if (ev.xclient.format == 32 |
|
|
1407 | && !HOOK_INVOKE ((this, HOOK_CLIENT_MESSAGE, DT_XEVENT, &ev, DT_END))) |
1407 | { |
1408 | { |
1408 | if (ev.xclient.message_type == xa[XA_WM_PROTOCOLS]) |
1409 | if (ev.xclient.message_type == xa[XA_WM_PROTOCOLS]) |
1409 | { |
1410 | { |
1410 | if (ev.xclient.data.l[0] == xa[XA_WM_DELETE_WINDOW]) |
1411 | if (!HOOK_INVOKE ((this, HOOK_WM_PROTOCOLS, DT_XEVENT, &ev, DT_END))) |
1411 | { |
1412 | { |
|
|
1413 | if (ev.xclient.data.l[0] == xa[XA_WM_DELETE_WINDOW]) |
|
|
1414 | { |
1412 | if (!HOOK_INVOKE ((this, HOOK_WM_DELETE_WINDOW, DT_XEVENT, ev, DT_END))) |
1415 | if (!HOOK_INVOKE ((this, HOOK_WM_DELETE_WINDOW, DT_XEVENT, &ev, DT_END))) |
1413 | destroy (); |
1416 | destroy (); |
|
|
1417 | } |
|
|
1418 | #if ENABLE_EWMH |
|
|
1419 | else if (ev.xclient.data.l[0] == xa[XA_NET_WM_PING]) |
|
|
1420 | XSendEvent (disp, ev.xclient.window = display->root, |
|
|
1421 | False, SubstructureRedirectMask | SubstructureNotifyMask, |
|
|
1422 | &ev); |
|
|
1423 | #endif |
1414 | } |
1424 | } |
1415 | #if ENABLE_EWMH |
|
|
1416 | else if (ev.xclient.data.l[0] == xa[XA_NET_WM_PING]) |
|
|
1417 | XSendEvent (disp, ev.xclient.window = display->root, |
|
|
1418 | False, SubstructureRedirectMask | SubstructureNotifyMask, |
|
|
1419 | &ev); |
|
|
1420 | #endif |
|
|
1421 | } |
1425 | } |
1422 | #if ENABLE_XEMBED |
1426 | #if ENABLE_XEMBED |
1423 | else if (ev.xclient.format == 32 && ev.xclient.message_type == xa[XA_XEMBED]) |
1427 | else if (ev.xclient.format == 32 && ev.xclient.message_type == xa[XA_XEMBED]) |
1424 | { |
1428 | { |
1425 | if (ev.xclient.data.l[1] == XEMBED_FOCUS_IN) |
1429 | if (ev.xclient.data.l[1] == XEMBED_FOCUS_IN) |
… | |
… | |
1488 | #endif |
1492 | #endif |
1489 | } |
1493 | } |
1490 | break; |
1494 | break; |
1491 | |
1495 | |
1492 | case PropertyNotify: |
1496 | case PropertyNotify: |
|
|
1497 | if (!HOOK_INVOKE ((this, HOOK_PROPERTY_NOTIFY, DT_XEVENT, &ev, DT_END))) |
1493 | if (ev.xproperty.atom == xa[XA_VT_SELECTION] |
1498 | if (ev.xproperty.atom == xa[XA_VT_SELECTION] |
1494 | && ev.xproperty.state == PropertyNewValue) |
1499 | && ev.xproperty.state == PropertyNewValue) |
1495 | selection_property (ev.xproperty.window, ev.xproperty.atom); |
1500 | selection_property (ev.xproperty.window, ev.xproperty.atom); |
1496 | |
1501 | |
1497 | break; |
1502 | break; |
1498 | |
1503 | |
1499 | case SelectionClear: |
1504 | case SelectionClear: |
1500 | selection_clear (); |
1505 | selection_clear (); |
… | |
… | |
2624 | am_transparent = 0; |
2629 | am_transparent = 0; |
2625 | /* XXX: also turn off Opt_transparent? */ |
2630 | /* XXX: also turn off Opt_transparent? */ |
2626 | } |
2631 | } |
2627 | else |
2632 | else |
2628 | { |
2633 | { |
2629 | #if WAIT_FOR_WM |
|
|
2630 | /* wait (an arbitrary period) for the WM to do its thing |
|
|
2631 | * needed for fvwm2.2.2 (and before?) */ |
|
|
2632 | sleep (1); |
|
|
2633 | #endif |
|
|
2634 | for (n = 0; n < (unsigned int)i; n++) |
2634 | for (n = 0; n < (unsigned int)i; n++) |
2635 | { |
2635 | { |
2636 | XSetWindowBackgroundPixmap (disp, parent[n], ParentRelative); |
2636 | XSetWindowBackgroundPixmap (disp, parent[n], ParentRelative); |
2637 | XClearWindow (disp, parent[n]); |
2637 | XClearWindow (disp, parent[n]); |
2638 | } |
2638 | } |