Initial commit of OpenSPARC T2 design and verification files.
[OpenSPARC-T2-DV] / tools / src / nas,5.n2.os.2 / lib / python / man / man3 / Tcl_DeleteChannelHandler.3
CommitLineData
86530b38
AT
1'\"
2'\" Copyright (c) 1996 Sun Microsystems, Inc.
3'\"
4'\" See the file "license.terms" for information on usage and redistribution
5'\" of this file, and for a DISCLAIMER OF ALL WARRANTIES.
6'\"
7'\" RCS: @(#) $Id: CrtChnlHdlr.3,v 1.2 1998/09/14 18:39:46 stanton Exp $
8'\" The definitions below are for supplemental macros used in Tcl/Tk
9'\" manual entries.
10'\"
11'\" .AP type name in/out ?indent?
12'\" Start paragraph describing an argument to a library procedure.
13'\" type is type of argument (int, etc.), in/out is either "in", "out",
14'\" or "in/out" to describe whether procedure reads or modifies arg,
15'\" and indent is equivalent to second arg of .IP (shouldn't ever be
16'\" needed; use .AS below instead)
17'\"
18'\" .AS ?type? ?name?
19'\" Give maximum sizes of arguments for setting tab stops. Type and
20'\" name are examples of largest possible arguments that will be passed
21'\" to .AP later. If args are omitted, default tab stops are used.
22'\"
23'\" .BS
24'\" Start box enclosure. From here until next .BE, everything will be
25'\" enclosed in one large box.
26'\"
27'\" .BE
28'\" End of box enclosure.
29'\"
30'\" .CS
31'\" Begin code excerpt.
32'\"
33'\" .CE
34'\" End code excerpt.
35'\"
36'\" .VS ?version? ?br?
37'\" Begin vertical sidebar, for use in marking newly-changed parts
38'\" of man pages. The first argument is ignored and used for recording
39'\" the version when the .VS was added, so that the sidebars can be
40'\" found and removed when they reach a certain age. If another argument
41'\" is present, then a line break is forced before starting the sidebar.
42'\"
43'\" .VE
44'\" End of vertical sidebar.
45'\"
46'\" .DS
47'\" Begin an indented unfilled display.
48'\"
49'\" .DE
50'\" End of indented unfilled display.
51'\"
52'\" .SO
53'\" Start of list of standard options for a Tk widget. The
54'\" options follow on successive lines, in four columns separated
55'\" by tabs.
56'\"
57'\" .SE
58'\" End of list of standard options for a Tk widget.
59'\"
60'\" .OP cmdName dbName dbClass
61'\" Start of description of a specific option. cmdName gives the
62'\" option's name as specified in the class command, dbName gives
63'\" the option's name in the option database, and dbClass gives
64'\" the option's class in the option database.
65'\"
66'\" .UL arg1 arg2
67'\" Print arg1 underlined, then print arg2 normally.
68'\"
69'\" RCS: @(#) $Id: man.macros,v 1.4 2000/08/25 06:18:32 ericm Exp $
70'\"
71'\" # Set up traps and other miscellaneous stuff for Tcl/Tk man pages.
72.if t .wh -1.3i ^B
73.nr ^l \n(.l
74.ad b
75'\" # Start an argument description
76.de AP
77.ie !"\\$4"" .TP \\$4
78.el \{\
79. ie !"\\$2"" .TP \\n()Cu
80. el .TP 15
81.\}
82.ta \\n()Au \\n()Bu
83.ie !"\\$3"" \{\
84\&\\$1 \\fI\\$2\\fP (\\$3)
85.\".b
86.\}
87.el \{\
88.br
89.ie !"\\$2"" \{\
90\&\\$1 \\fI\\$2\\fP
91.\}
92.el \{\
93\&\\fI\\$1\\fP
94.\}
95.\}
96..
97'\" # define tabbing values for .AP
98.de AS
99.nr )A 10n
100.if !"\\$1"" .nr )A \\w'\\$1'u+3n
101.nr )B \\n()Au+15n
102.\"
103.if !"\\$2"" .nr )B \\w'\\$2'u+\\n()Au+3n
104.nr )C \\n()Bu+\\w'(in/out)'u+2n
105..
106.AS Tcl_Interp Tcl_CreateInterp in/out
107'\" # BS - start boxed text
108'\" # ^y = starting y location
109'\" # ^b = 1
110.de BS
111.br
112.mk ^y
113.nr ^b 1u
114.if n .nf
115.if n .ti 0
116.if n \l'\\n(.lu\(ul'
117.if n .fi
118..
119'\" # BE - end boxed text (draw box now)
120.de BE
121.nf
122.ti 0
123.mk ^t
124.ie n \l'\\n(^lu\(ul'
125.el \{\
126.\" Draw four-sided box normally, but don't draw top of
127.\" box if the box started on an earlier page.
128.ie !\\n(^b-1 \{\
129\h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
130.\}
131.el \}\
132\h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
133.\}
134.\}
135.fi
136.br
137.nr ^b 0
138..
139'\" # VS - start vertical sidebar
140'\" # ^Y = starting y location
141'\" # ^v = 1 (for troff; for nroff this doesn't matter)
142.de VS
143.if !"\\$2"" .br
144.mk ^Y
145.ie n 'mc \s12\(br\s0
146.el .nr ^v 1u
147..
148'\" # VE - end of vertical sidebar
149.de VE
150.ie n 'mc
151.el \{\
152.ev 2
153.nf
154.ti 0
155.mk ^t
156\h'|\\n(^lu+3n'\L'|\\n(^Yu-1v\(bv'\v'\\n(^tu+1v-\\n(^Yu'\h'-|\\n(^lu+3n'
157.sp -1
158.fi
159.ev
160.\}
161.nr ^v 0
162..
163'\" # Special macro to handle page bottom: finish off current
164'\" # box/sidebar if in box/sidebar mode, then invoked standard
165'\" # page bottom macro.
166.de ^B
167.ev 2
168'ti 0
169'nf
170.mk ^t
171.if \\n(^b \{\
172.\" Draw three-sided box if this is the box's first page,
173.\" draw two sides but no top otherwise.
174.ie !\\n(^b-1 \h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c
175.el \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c
176.\}
177.if \\n(^v \{\
178.nr ^x \\n(^tu+1v-\\n(^Yu
179\kx\h'-\\nxu'\h'|\\n(^lu+3n'\ky\L'-\\n(^xu'\v'\\n(^xu'\h'|0u'\c
180.\}
181.bp
182'fi
183.ev
184.if \\n(^b \{\
185.mk ^y
186.nr ^b 2
187.\}
188.if \\n(^v \{\
189.mk ^Y
190.\}
191..
192'\" # DS - begin display
193.de DS
194.RS
195.nf
196.sp
197..
198'\" # DE - end display
199.de DE
200.fi
201.RE
202.sp
203..
204'\" # SO - start of list of standard options
205.de SO
206.SH "STANDARD OPTIONS"
207.LP
208.nf
209.ta 5.5c 11c
210.ft B
211..
212'\" # SE - end of list of standard options
213.de SE
214.fi
215.ft R
216.LP
217See the \\fBoptions\\fR manual entry for details on the standard options.
218..
219'\" # OP - start of full description for a single option
220.de OP
221.LP
222.nf
223.ta 4c
224Command-Line Name: \\fB\\$1\\fR
225Database Name: \\fB\\$2\\fR
226Database Class: \\fB\\$3\\fR
227.fi
228.IP
229..
230'\" # CS - begin code excerpt
231.de CS
232.RS
233.nf
234.ta .25i .5i .75i 1i
235..
236'\" # CE - end code excerpt
237.de CE
238.fi
239.RE
240..
241.de UL
242\\$1\l'|0\(ul'\\$2
243..
244.TH Tcl_CreateChannelHandler 3 7.5 Tcl "Tcl Library Procedures"
245.BS
246'\" Note: do not modify the .SH NAME line immediately below!
247.SH NAME
248Tcl_CreateChannelHandler, Tcl_DeleteChannelHandler \- call a procedure when a channel becomes readable or writable
249.SH SYNOPSIS
250.nf
251.nf
252\fB#include <tcl.h>\fR
253.sp
254void
255\fBTcl_CreateChannelHandler\fR(\fIchannel, mask, proc, clientData\fR)
256.sp
257void
258\fBTcl_DeleteChannelHandler\fR(\fIchannel, proc, clientData\fR)
259.sp
260.SH ARGUMENTS
261.AS Tcl_ChannelProc clientData
262.AP Tcl_Channel channel in
263Tcl channel such as returned by \fBTcl_CreateChannel\fR.
264.AP int mask in
265Conditions under which \fIproc\fR should be called: OR-ed combination of
266\fBTCL_READABLE\fR, \fBTCL_WRITABLE\fR and \fBTCL_EXCEPTION\fR. Specify
267a zero value to temporarily disable an existing handler.
268.AP Tcl_FileProc *proc in
269Procedure to invoke whenever the channel indicated by \fIchannel\fR meets
270the conditions specified by \fImask\fR.
271.AP ClientData clientData in
272Arbitrary one-word value to pass to \fIproc\fR.
273.BE
274
275.SH DESCRIPTION
276.PP
277\fBTcl_CreateChannelHandler\fR arranges for \fIproc\fR to be called in the
278future whenever input or output becomes possible on the channel identified
279by \fIchannel\fR, or whenever an exceptional condition exists for
280\fIchannel\fR. The conditions of interest under which \fIproc\fR will be
281invoked are specified by the \fImask\fR argument.
282See the manual entry for \fBfileevent\fR for a precise description of
283what it means for a channel to be readable or writable.
284\fIProc\fR must conform to the following prototype:
285.CS
286typedef void Tcl_ChannelProc(
287 ClientData \fIclientData\fR,
288 int \fImask\fR);
289.CE
290.PP
291The \fIclientData\fR argument is the same as the value passed to
292\fBTcl_CreateChannelHandler\fR when the handler was created. Typically,
293\fIclientData\fR points to a data structure containing application-specific
294information about the channel. \fIMask\fR is an integer mask indicating
295which of the requested conditions actually exists for the channel; it will
296contain a subset of the bits from the \fImask\fR argument to
297\fBTcl_CreateChannelHandler\fR when the handler was created.
298.PP
299Each channel handler is identified by a unique combination of \fIchannel\fR,
300\fIproc\fR and \fIclientData\fR.
301There may be many handlers for a given channel as long as they don't
302have the same \fIchannel\fR, \fIproc\fR, and \fIclientData\fR.
303If \fBTcl_CreateChannelHandler\fR is invoked when there is already a handler
304for \fIchannel\fR, \fIproc\fR, and \fIclientData\fR, then no new
305handler is created; instead, the \fImask\fR is changed for the
306existing handler.
307.PP
308\fBTcl_DeleteChannelHandler\fR deletes a channel handler identified by
309\fIchannel\fR, \fIproc\fR and \fIclientData\fR; if no such handler exists,
310the call has no effect.
311.PP
312Channel handlers are invoked via the Tcl event mechanism, so they
313are only useful in applications that are event-driven.
314Note also that the conditions specified in the \fImask\fR argument
315to \fIproc\fR may no longer exist when \fIproc\fR is invoked: for
316example, if there are two handlers for \fBTCL_READABLE\fR on the same
317channel, the first handler could consume all of the available input
318so that the channel is no longer readable when the second handler
319is invoked.
320For this reason it may be useful to use nonblocking I/O on channels
321for which there are event handlers.
322
323.SH "SEE ALSO"
324Notifier(3), Tcl_CreateChannel(3), Tcl_OpenFileChannel(3), vwait(n).
325
326.SH KEYWORDS
327blocking, callback, channel, events, handler, nonblocking.