annotate man/external-widget.texi @ 412:697ef44129c6 r21-2-14

Import from CVS: tag r21-2-14
author cvs
date Mon, 13 Aug 2007 11:20:41 +0200
parents 74fd4e045ea6
children da8ed4261e83
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
1 \input texinfo @c -*-texinfo-*-
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
2 @setfilename ../info/external-widget.info
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
3
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
4 @ifinfo
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
5 @dircategory XEmacs Editor
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
6 @direntry
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
7 * External Widget: (external-widget) External Client Widget.
412
697ef44129c6 Import from CVS: tag r21-2-14
cvs
parents: 398
diff changeset
8 package.
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
9 @end direntry
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
10 @end ifinfo
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents: 371
diff changeset
11
0
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
12 @node Top, Using an External Client Widget,, (dir)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
13
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
14 An @dfn{external client widget} is a widget that is part of another program
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
15 but functions as an Emacs frame. This is intended to be a more
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
16 powerful replacement for standard text widgets.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
17
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
18 @menu
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
19 * Using an External Client Widget::
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
20 * External Client Widget Resource Settings::
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
21 * Motif-Specific Info About the External Client Widget::
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
22 @end menu
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
23
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
24
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
25 @node Using an External Client Widget, External Client Widget Resource Settings, Top, Top
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
26 @chapter Using an External Client Widget
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
27
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
28 There are three different implementations of the external client widget.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
29 One is designed for use in Motif applications and is linked with the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
30 option @code{-lextcli_Xm}. Another is designed for non-Motif
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
31 applications that still use the X toolkit; it is linked with the option
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
32 @code{-lextcli_Xt}. The third is designed for applications that do not
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
33 use the X toolkit; it is linked with the option @code{-lextcli_Xlib}.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
34 In order to use an external client widget in a client program that uses
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
35 the X toolkit (i.e. either of the first two options described above),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
36 simply create an instance of widget type ExternalClient and link your
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
37 program with the appropriate library. The corresponding header file is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
38 called @file{ExternalClient.h}.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
39
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
40 Documentation still needs to be provided for using the raw Xlib
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
41 version of the external client widget.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
42
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
43 The external client widget will not do anything until an instance of
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
44 Emacs is told about this particular widget. To do that, call the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
45 function @code{make-frame}, specifying a value for the frame parameter
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
46 @code{window-id}. This value should be a string containing the decimal
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
47 representation of the widget's X window ID number (this can be obtained
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
48 by the Xt function @code{XtWindow()}). In order for the client program
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
49 to communicate this information to Emacs, a method such as sending a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
50 ToolTalk message needs to be used.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
51
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
52 Once @code{make-frame} has been called, Emacs will create a frame
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
53 that occupies the client widget's window. This frame can be used just
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
54 like any other frame in Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
55
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
56
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
57 @node External Client Widget Resource Settings, Motif-Specific Info About the External Client Widget, Using an External Client Widget, Top
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
58 @chapter External Client Widget Resource Settings
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
59
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
60 The external client widget is a subclass of the Motif widget XmPrimitive
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
61 and thus inherits all its resources. In addition, the following new
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
62 resources are defined:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
63
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
64 @table @samp
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
65 @item deadShell (class DeadShell)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
66 A boolean resource indicating whether the last request to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
67 ExternalShell widget that contains the frame corresponding to this
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
68 widget timed out. If true, no further requests will be made (all
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
69 requests will automatically fail) until a response to the last
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
70 request is received. This resource should normally not be set by the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
71 user.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
72
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
73 @item shellTimeout (class ShellTimeout)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
74 A value specifying how long (in milliseconds) the client should wait
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
75 for a response when making a request to the corresponding ExternalShell
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
76 widget. If this timeout is exceeded, the client will assume that the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
77 shell is dead and will fail the request and all subsequent requests
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
78 until a response to the request is received. Default value is 5000,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
79 or 5 seconds.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
80 @end table
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
81
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
82 The shell that contains the frame corresponding to an external client
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
83 widget is of type ExternalShell, as opposed to standard frames, whose
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
84 shell is of type TopLevelShell. The ExternalShell widget is a direct
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
85 subclass of Shell and thus inherits its resources. In addition, the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
86 following new resources are defined:
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
87
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
88 @table @samp
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
89 @item window (class Window)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
90 The X window ID of the widget to use for this Emacs frame. This is
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
91 normally set by the call to @code{x-create-frame} and should not be
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
92 modified by the user.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
93
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
94 @item deadClient (class DeadClient)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
95 A boolean resource indicating whether the last request to the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
96 corresponding ExternalClient widget timed out. If true, no further
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
97 requests will be made (all requests will automatically fail) until a
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
98 response to the last request is received. This resource should
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
99 normally not be set by the user.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
100
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
101 @item ClientTimeout (class ClientTimeout)
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
102 A value specifying how long (in milliseconds) the shell should wait
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
103 for a response when making a request to the corresponding ExternalClient
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
104 widget. If this timeout is exceeded, the shell will assume that the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
105 client is dead and will fail the request and all subsequent requests
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
106 until a response to the request is received. Default value is 5000,
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
107 or 5 seconds.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
108 @end table
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
109
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
110 Note that the requests that are made between the client and the shell
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
111 are primarily for handling query-geometry and geometry-manager requests
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
112 made by parent or child widgets.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
113
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
114
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
115 @node Motif-Specific Info About the External Client Widget, , External Client Widget Resource Settings, Top
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
116 @chapter Motif-Specific Info About the External Client Widget
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
117
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
118 By default, the external client widget has navigation type
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
119 @samp{XmTAB_GROUP}.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
120
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
121 The widget traversal keystrokes are modified slightly from the standard
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
122 XmPrimitive keystrokes. In particular, @kbd{@key{TAB}} alone does not
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
123 traverse to the next widget (@kbd{Ctrl-@key{TAB}} must be used instead),
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
124 but functions like a normal @key{TAB} in Emacs. This follows the
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
125 semantics of the Motif text widget. The traversal keystrokes
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
126 @kbd{Ctrl-@key{TAB}} and @kbd{Shift-@key{TAB}} are silently filtered by
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
127 the external client widget and are not seen by Emacs.
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
128
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
129 @summarycontents
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
130 @contents
376386a54a3c Import from CVS: tag r19-14
cvs
parents:
diff changeset
131 @bye