2000-06-04 21:39:33 +00:00
|
|
|
<HTML
|
|
|
|
><HEAD
|
|
|
|
><TITLE
|
|
|
|
>Window Manager Protocols</TITLE
|
|
|
|
><META
|
|
|
|
NAME="GENERATOR"
|
2002-08-21 07:37:55 +00:00
|
|
|
CONTENT="Modular DocBook HTML Stylesheet Version 1.72
|
|
|
|
"><LINK
|
2000-06-04 21:39:33 +00:00
|
|
|
REL="HOME"
|
|
|
|
HREF="index.html"><LINK
|
|
|
|
REL="PREVIOUS"
|
|
|
|
TITLE="Application Window Properties"
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x225.html"><LINK
|
2000-06-04 21:39:33 +00:00
|
|
|
REL="NEXT"
|
|
|
|
TITLE="Implementation notes"
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x351.html"></HEAD
|
2000-06-04 21:39:33 +00:00
|
|
|
><BODY
|
|
|
|
CLASS="SECT1"
|
2002-08-21 07:37:55 +00:00
|
|
|
BGCOLOR="#FFFFFF"
|
|
|
|
TEXT="#000000"
|
|
|
|
LINK="#0000FF"
|
|
|
|
VLINK="#840084"
|
|
|
|
ALINK="#0000FF"
|
2000-06-04 21:39:33 +00:00
|
|
|
><DIV
|
|
|
|
CLASS="NAVHEADER"
|
|
|
|
><TABLE
|
2002-08-21 07:37:55 +00:00
|
|
|
SUMMARY="Header navigation table"
|
2000-06-04 21:39:33 +00:00
|
|
|
WIDTH="100%"
|
|
|
|
BORDER="0"
|
|
|
|
CELLPADDING="0"
|
|
|
|
CELLSPACING="0"
|
|
|
|
><TR
|
|
|
|
><TH
|
|
|
|
COLSPAN="3"
|
|
|
|
ALIGN="center"
|
2002-08-21 07:37:55 +00:00
|
|
|
></TH
|
2000-06-04 21:39:33 +00:00
|
|
|
></TR
|
|
|
|
><TR
|
|
|
|
><TD
|
|
|
|
WIDTH="10%"
|
|
|
|
ALIGN="left"
|
|
|
|
VALIGN="bottom"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x225.html"
|
|
|
|
ACCESSKEY="P"
|
2000-06-04 21:39:33 +00:00
|
|
|
>Prev</A
|
|
|
|
></TD
|
|
|
|
><TD
|
|
|
|
WIDTH="80%"
|
|
|
|
ALIGN="center"
|
|
|
|
VALIGN="bottom"
|
|
|
|
></TD
|
|
|
|
><TD
|
|
|
|
WIDTH="10%"
|
|
|
|
ALIGN="right"
|
|
|
|
VALIGN="bottom"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x351.html"
|
|
|
|
ACCESSKEY="N"
|
2000-06-04 21:39:33 +00:00
|
|
|
>Next</A
|
|
|
|
></TD
|
|
|
|
></TR
|
|
|
|
></TABLE
|
|
|
|
><HR
|
|
|
|
ALIGN="LEFT"
|
|
|
|
WIDTH="100%"></DIV
|
|
|
|
><DIV
|
|
|
|
CLASS="SECT1"
|
|
|
|
><H1
|
|
|
|
CLASS="SECT1"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
NAME="AEN340"
|
|
|
|
>6. Window Manager Protocols</A
|
2000-06-04 21:39:33 +00:00
|
|
|
></H1
|
|
|
|
><DIV
|
|
|
|
CLASS="SECT2"
|
|
|
|
><H2
|
|
|
|
CLASS="SECT2"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
NAME="AEN342"
|
|
|
|
>6.1. _NET_WM_PING</A
|
2000-06-04 21:39:33 +00:00
|
|
|
></H2
|
|
|
|
><P
|
|
|
|
>This protocol allows the Window Manager to determine if the Client is still
|
|
|
|
processing X events. This can be used by the Window Manager to determine if a
|
|
|
|
window which fails to close after being sent WM_DELETE_WINDOW has stopped
|
|
|
|
responding, or has stalled for some other reason, such as waiting for user
|
|
|
|
confirmation. A Client SHOULD indicate that it is willing to participate in
|
|
|
|
this protocol by listing _NET_WM_PING in the WM_PROTOCOLS property of the
|
|
|
|
client window.
|
|
|
|
</P
|
|
|
|
><P
|
|
|
|
>A Window Manager can use this protocol at any time by sending a client message
|
|
|
|
as follows:
|
|
|
|
</P
|
|
|
|
><PRE
|
|
|
|
CLASS="PROGRAMLISTING"
|
|
|
|
>type = ClientMessage
|
2002-08-21 07:37:55 +00:00
|
|
|
window = the respective client window
|
2000-06-04 21:39:33 +00:00
|
|
|
message_type = WM_PROTOCOLS
|
|
|
|
format = 32
|
|
|
|
data.l[0] = _NET_WM_PING
|
2002-08-21 07:37:55 +00:00
|
|
|
data.l[1] = timestamp</PRE
|
2000-06-04 21:39:33 +00:00
|
|
|
><P
|
|
|
|
>A participating Client receiving this message MUST send it back to the root
|
|
|
|
window immediately, by setting window = root, and calling XSendEvent. The
|
|
|
|
Client MUST NOT alter the timestamp, as this can be used by the Window Manager
|
|
|
|
to uniquely identify the ping.
|
|
|
|
</P
|
|
|
|
><P
|
|
|
|
>The Window Manager MAY kill the Client (using _NET_WM_PID) if it fails to
|
|
|
|
respond to this protocol within a reasonable time.
|
|
|
|
</P
|
2002-08-21 07:37:55 +00:00
|
|
|
><P
|
|
|
|
>See also the implementation notes on <A
|
|
|
|
HREF="x351.html#KILLINGWINDOWS"
|
|
|
|
>killing hung processes</A
|
|
|
|
>.
|
|
|
|
</P
|
2000-06-04 21:39:33 +00:00
|
|
|
></DIV
|
|
|
|
></DIV
|
|
|
|
><DIV
|
|
|
|
CLASS="NAVFOOTER"
|
|
|
|
><HR
|
|
|
|
ALIGN="LEFT"
|
|
|
|
WIDTH="100%"><TABLE
|
2002-08-21 07:37:55 +00:00
|
|
|
SUMMARY="Footer navigation table"
|
2000-06-04 21:39:33 +00:00
|
|
|
WIDTH="100%"
|
|
|
|
BORDER="0"
|
|
|
|
CELLPADDING="0"
|
|
|
|
CELLSPACING="0"
|
|
|
|
><TR
|
|
|
|
><TD
|
|
|
|
WIDTH="33%"
|
|
|
|
ALIGN="left"
|
|
|
|
VALIGN="top"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x225.html"
|
|
|
|
ACCESSKEY="P"
|
2000-06-04 21:39:33 +00:00
|
|
|
>Prev</A
|
|
|
|
></TD
|
|
|
|
><TD
|
|
|
|
WIDTH="34%"
|
|
|
|
ALIGN="center"
|
|
|
|
VALIGN="top"
|
|
|
|
><A
|
|
|
|
HREF="index.html"
|
2002-08-21 07:37:55 +00:00
|
|
|
ACCESSKEY="H"
|
2000-06-04 21:39:33 +00:00
|
|
|
>Home</A
|
|
|
|
></TD
|
|
|
|
><TD
|
|
|
|
WIDTH="33%"
|
|
|
|
ALIGN="right"
|
|
|
|
VALIGN="top"
|
|
|
|
><A
|
2002-08-21 07:37:55 +00:00
|
|
|
HREF="x351.html"
|
|
|
|
ACCESSKEY="N"
|
2000-06-04 21:39:33 +00:00
|
|
|
>Next</A
|
|
|
|
></TD
|
|
|
|
></TR
|
|
|
|
><TR
|
|
|
|
><TD
|
|
|
|
WIDTH="33%"
|
|
|
|
ALIGN="left"
|
|
|
|
VALIGN="top"
|
|
|
|
>Application Window Properties</TD
|
|
|
|
><TD
|
|
|
|
WIDTH="34%"
|
|
|
|
ALIGN="center"
|
|
|
|
VALIGN="top"
|
|
|
|
> </TD
|
|
|
|
><TD
|
|
|
|
WIDTH="33%"
|
|
|
|
ALIGN="right"
|
|
|
|
VALIGN="top"
|
|
|
|
>Implementation notes</TD
|
|
|
|
></TR
|
|
|
|
></TABLE
|
|
|
|
></DIV
|
|
|
|
></BODY
|
|
|
|
></HTML
|
|
|
|
>
|