OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [tcl/] [doc/] [CrtChannel.3] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 578 markom
'\"
2
'\" Copyright (c) 1996-1997 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: CrtChannel.3,v 1.1.1.1 2002-01-16 10:25:23 markom Exp $
8
.so man.macros
9
.TH Tcl_CreateChannel 3 8.0 Tcl "Tcl Library Procedures"
10
.BS
11
'\" Note:  do not modify the .SH NAME line immediately below!
12
.SH NAME
13
Tcl_CreateChannel, Tcl_GetChannelInstanceData, Tcl_GetChannelType, Tcl_GetChannelName, Tcl_GetChannelHandle, Tcl_GetChannelMode, Tcl_GetChannelBufferSize, Tcl_SetDefaultTranslation, Tcl_SetChannelBufferSize, Tcl_NotifyChannel, Tcl_BadChannelOption \- procedures for creating and manipulating channels
14
.SH SYNOPSIS
15
.nf
16
\fB#include \fR
17
.sp
18
Tcl_Channel
19
\fBTcl_CreateChannel\fR(\fItypePtr, channelName, instanceData, mask\fR)
20
.sp
21
ClientData
22
\fBTcl_GetChannelInstanceData\fR(\fIchannel\fR)
23
.sp
24
Tcl_ChannelType *
25
\fBTcl_GetChannelType\fR(\fIchannel\fR)
26
.sp
27
char *
28
\fBTcl_GetChannelName\fR(\fIchannel\fR)
29
.VS
30
.sp
31
int
32
\fBTcl_GetChannelHandle\fR(\fIchannel, direction, handlePtr\fR)
33
.VE
34
.sp
35
int
36
\fBTcl_GetChannelFlags\fR(\fIchannel\fR)
37
.sp
38
\fBTcl_SetDefaultTranslation\fR(\fIchannel, transMode\fR)
39
.sp
40
int
41
\fBTcl_GetChannelBufferSize\fR(\fIchannel\fR)
42
.sp
43
\fBTcl_SetChannelBufferSize\fR(\fIchannel, size\fR)
44
.sp
45
.VS
46
\fBTcl_NotifyChannel\fR(\fIchannel, mask\fR)
47
.sp
48
int
49
\fBTcl_BadChannelOption\fR(\fIinterp, optionName, optionList\fR)
50
.VE
51
.sp
52
.SH ARGUMENTS
53
.AS Tcl_EolTranslation *channelName in
54
.AP Tcl_ChannelType *typePtr in
55
Points to a structure containing the addresses of procedures that
56
can be called to perform I/O and other functions on the channel.
57
.AP char *channelName in
58
The name of this channel, such as \fBfile3\fR; must not be in use
59
by any other channel. Can be NULL, in which case the channel is
60
created without a name.
61
.AP ClientData instanceData in
62
Arbitrary one-word value to be associated with this channel.  This
63
value is passed to procedures in \fItypePtr\fR when they are invoked.
64
.AP int mask in
65
OR-ed combination of \fBTCL_READABLE\fR and \fBTCL_WRITABLE\fR to indicate
66
whether a channel is readable and writable.
67
.AP Tcl_Channel channel in
68
The channel to operate on.
69
.VS
70
.AP int direction in
71
\fBTCL_READABLE\fR means the input handle is wanted; \fBTCL_WRITABLE\fR
72
means the output handle is wanted.
73
.AP ClientData *handlePtr out
74
Points to the location where the desired OS-specific handle should be
75
stored.
76
.VE
77
.AP Tcl_EolTranslation transMode in
78
The translation mode; one of the constants \fBTCL_TRANSLATE_AUTO\fR,
79
\fBTCL_TRANSLATE_CR\fR, \fBTCL_TRANSLATE_LF\fR and \fBTCL_TRANSLATE_CRLF\fR.
80
.AP int size in
81
The size, in bytes, of buffers to allocate in this channel.
82
.VS
83
.AP int mask in
84
An OR-ed combination of \fBTCL_READABLE\fR, \fBTCL_WRITABLE\fR
85
and \fBTCL_EXCEPTION\fR that indicates events that have occurred on
86
this channel.
87
.AP Tcl_Interp *interp in
88
Current interpreter. (can be NULL)
89
.AP char *optionName in
90
Name of the invalid option.
91
.AP char *optionList in
92
Specific options list (space separated words, without "-")
93
to append to the standard generic options list.
94
Can be NULL for generic options error message only.
95
.VE
96
 
97
.BE
98
 
99
.SH DESCRIPTION
100
.PP
101
Tcl uses a two-layered channel architecture. It provides a generic upper
102
layer to enable C and Tcl programs to perform input and output using the
103
same APIs for a variety of files, devices, sockets etc. The generic C APIs
104
are described in the manual entry for \fBTcl_OpenFileChannel\fR.
105
.PP
106
The lower layer provides type-specific channel drivers for each type
107
of device supported on each platform.  This manual entry describes the
108
C APIs used to communicate between the generic layer and the
109
type-specific channel drivers.  It also explains how new types of
110
channels can be added by providing new channel drivers.
111
.PP
112
Channel drivers consist of a number of components: First, each channel
113
driver provides a \fBTcl_ChannelType\fR structure containing pointers to
114
functions implementing the various operations used by the generic layer to
115
communicate with the channel driver. The \fBTcl_ChannelType\fR structure
116
and the functions referenced by it are described in the section
117
TCL_CHANNELTYPE, below.
118
.PP
119
Second, channel drivers usually provide a Tcl command to create
120
instances of that type of channel. For example, the Tcl \fBopen\fR
121
command creates channels that use the file and command channel
122
drivers, and the Tcl \fBsocket\fR command creates channels that use
123
TCP sockets for network communication.
124
.PP
125
Third, a channel driver optionally provides a C function to open
126
channel instances of that type. For example, \fBTcl_OpenFileChannel\fR
127
opens a channel that uses the file channel driver, and
128
\fBTcl_OpenTcpClient\fR opens a channel that uses the TCP network
129
protocol.  These creation functions typically use
130
\fBTcl_CreateChannel\fR internally to open the channel.
131
.PP
132
To add a new type of channel you must implement a C API or a Tcl command
133
that opens a channel by invoking \fBTcl_CreateChannel\fR.
134
When your driver calls \fBTcl_CreateChannel\fR it passes in
135
a \fBTcl_ChannelType\fR structure describing the driver's I/O
136
procedures.
137
The generic layer will then invoke the functions referenced in that
138
structure to perform operations on the channel.
139
.PP
140
\fBTcl_CreateChannel\fR opens a new channel and associates the supplied
141
\fItypePtr\fR and \fIinstanceData\fR with it. The channel is opened in the
142
mode indicated by \fImask\fR.
143
For a discussion of channel drivers, their operations and the
144
\fBTcl_ChannelType\fR structure, see the section TCL_CHANNELTYPE, below.
145
.PP
146
\fBTcl_GetChannelInstanceData\fR returns the instance data associated with
147
the channel in \fIchannel\fR. This is the same as the \fIinstanceData\fR
148
argument in the call to \fBTcl_CreateChannel\fR that created this channel.
149
.PP
150
\fBTcl_GetChannelType\fR returns a pointer to the \fBTcl_ChannelType\fR
151
structure used by the channel in the \fIchannel\fR argument. This is
152
the same as the \fItypePtr\fR argument in the call to
153
\fBTcl_CreateChannel\fR that created this channel.
154
.PP
155
\fBTcl_GetChannelName\fR returns a string containing the name associated
156
with the channel, or NULL if the \fIchannelName\fR argument to
157
\fBTcl_CreateChannel\fR was NULL.
158
.PP
159
.VS
160
\fBTcl_GetChannelHandle\fR places the OS-specific device handle
161
associated with \fIchannel\fR for the given \fIdirection\fR in the
162
location specified by \fIhandlePtr\fR and returns \fBTCL_OK\fR.  If
163
the channel does not have a device handle for the specified direction,
164
then \fBTCL_ERROR\fR is returned instead.  Different channel drivers
165
will return different types of handle.  Refer to the manual entries
166
for each driver to determine what type of handle is returned.
167
.VE
168
.PP
169
\fBTcl_GetChannelMode\fR returns an OR-ed combination of \fBTCL_READABLE\fR
170
and \fBTCL_WRITABLE\fR, indicating whether the channel is open for input
171
and output.
172
.PP
173
\fBTcl_SetDefaultTranslation\fR sets the default end of line translation
174
mode. This mode will be installed as the translation mode for the channel
175
if an attempt is made to output on the channel while it is still in
176
\fBTCL_TRANSLATE_AUTO\fR mode. For a description of end of line translation
177
modes, see the manual entry for \fBfconfigure\fR.
178
.PP
179
\fBTcl_GetChannelBufferSize\fR returns the size, in bytes, of buffers
180
allocated to store input or output in \fIchan\fR. If the value was not set
181
by a previous call to \fBTcl_SetChannelBufferSize\fR, described below, then
182
the default value of 4096 is returned.
183
.PP
184
\fBTcl_SetChannelBufferSize\fR sets the size, in bytes, of buffers that
185
will be allocated in subsequent operations on the channel to store input or
186
output. The \fIsize\fR argument should be between ten and one million,
187
allowing buffers of ten bytes to one million bytes. If \fIsize\fR is
188
outside this range, \fBTcl_SetChannelBufferSize\fR sets the buffer size to
189
4096.
190
.PP
191
.VS
192
\fBTcl_NotifyChannel\fR is called by a channel driver to indicate to
193
the generic layer that the events specified by \fImask\fR have
194
occurred on the channel.  Channel drivers are responsible for invoking
195
this function whenever the channel handlers need to be called for the
196
channel.  See \fBWATCHPROC\fR below for more details.
197
.VE
198
.PP
199
.VS
200
\fBTcl_BadChannelOption\fR is called from driver specific set or get option
201
procs to generate a complete error message.
202
.VE
203
 
204
.SH TCL_CHANNELTYPE
205
.PP
206
A channel driver provides a \fBTcl_ChannelType\fR structure that contains
207
pointers to functions that implement the various operations on a channel;
208
these operations are invoked as needed by the generic layer. The
209
\fBTcl_ChannelType\fR structure contains the following fields:
210
.PP
211
.VS
212
.CS
213
typedef struct Tcl_ChannelType {
214
        char *\fItypeName\fR;
215
        Tcl_DriverBlockModeProc *\fIblockModeProc\fR;
216
        Tcl_DriverCloseProc *\fIcloseProc\fR;
217
        Tcl_DriverInputProc *\fIinputProc\fR;
218
        Tcl_DriverOutputProc *\fIoutputProc\fR;
219
        Tcl_DriverSeekProc *\fIseekProc\fR;
220
        Tcl_DriverSetOptionProc *\fIsetOptionProc\fR;
221
        Tcl_DriverGetOptionProc *\fIgetOptionProc\fR;
222
        Tcl_DriverWatchProc *\fIwatchProc\fR;
223
        Tcl_DriverGetHandleProc *\fIgetHandleProc\fR;
224
} Tcl_ChannelType;
225
.CE
226
.VE
227
.PP
228
The driver must provide implementations for all functions except
229
\fIblockModeProc\fR, \fIseekProc\fR, \fIsetOptionProc\fR, and
230
\fIgetOptionProc\fR, which may be specified as NULL to indicate that the
231
channel does not support seeking.  Other functions that can not be
232
implemented for this type of device should return \fBEINVAL\fR when invoked
233
to indicate that they are not implemented.
234
 
235
.SH TYPENAME
236
.PP
237
The \fItypeName\fR field contains a null-terminated string that
238
identifies the type of the device implemented by this driver, e.g.
239
\fBfile\fR or \fBsocket\fR.
240
 
241
.SH BLOCKMODEPROC
242
.PP
243
The \fIblockModeProc\fR field contains the address of a function called by
244
the generic layer to set blocking and nonblocking mode on the device.
245
\fIBlockModeProc\fR should match the following prototype:
246
.PP
247
.CS
248
typedef int Tcl_DriverBlockModeProc(
249
        ClientData \fIinstanceData\fR,
250
        int \fImode\fR);
251
.CE
252
.PP
253
The \fIinstanceData\fR is the same as the value passed to
254
\fBTcl_CreateChannel\fR when this channel was created.  The \fImode\fR
255
argument is either \fBTCL_MODE_BLOCKING\fR or \fBTCL_MODE_NONBLOCKING\fR to
256
set the device into blocking or nonblocking mode. The function should
257
return zero if the operation was successful, or a nonzero POSIX error code
258
if the operation failed.
259
.PP
260
If the operation is successful, the function can modify the supplied
261
\fIinstanceData\fR to record that the channel entered blocking or
262
nonblocking mode and to implement the blocking or nonblocking behavior.
263
For some device types, the blocking and nonblocking behavior can be
264
implemented by the underlying operating system; for other device types, the
265
behavior must be emulated in the channel driver.
266
 
267
.SH CLOSEPROC
268
.PP
269
The \fIcloseProc\fR field contains the address of a function called by the
270
generic layer to clean up driver-related information when the channel is
271
closed. \fICloseProc\fR must match the following prototype:
272
.PP
273
.CS
274
typedef int Tcl_DriverCloseProc(
275
        ClientData \fIinstanceData\fR,
276
        Tcl_Interp *\fIinterp\fR);
277
.CE
278
.PP
279
The \fIinstanceData\fR argument is the same as the value provided to
280
\fBTcl_CreateChannel\fR when the channel was created. The function should
281
release any storage maintained by the channel driver for this channel, and
282
close the input and output devices encapsulated by this channel. All queued
283
output will have been flushed to the device before this function is called,
284
and no further driver operations will be invoked on this instance after
285
calling the \fIcloseProc\fR. If the close operation is successful, the
286
procedure should return zero; otherwise it should return a nonzero POSIX
287
error code. In addition, if an error occurs and \fIinterp\fR is not NULL,
288
the procedure should store an error message in \fIinterp->result\fR.
289
 
290
.SH INPUTPROC
291
.PP
292
The \fIinputProc\fR field contains the address of a function called by the
293
generic layer to read data from the file or device and store it in an
294
internal buffer. \fIInputProc\fR must match the following prototype:
295
.PP
296
.CS
297
typedef int Tcl_DriverInputProc(
298
        ClientData \fIinstanceData\fR,
299
        char *\fIbuf\fR,
300
        int \fIbufSize\fR,
301
        int *\fIerrorCodePtr\fR);
302
.CE
303
.PP
304
\fIInstanceData\fR is the same as the value passed to
305
\fBTcl_CreateChannel\fR when the channel was created.  The \fIbuf\fR
306
argument points to an array of bytes in which to store input from the
307
device, and the \fIbufSize\fR argument indicates how many bytes are
308
available at \fIbuf\fR.
309
.PP
310
The \fIerrorCodePtr\fR argument points to an integer variable provided by
311
the generic layer. If an error occurs, the function should set the variable
312
to a POSIX error code that identifies the error that occurred.
313
.PP
314
The function should read data from the input device encapsulated by the
315
channel and store it at \fIbuf\fR.  On success, the function should return
316
a nonnegative integer indicating how many bytes were read from the input
317
device and stored at \fIbuf\fR. On error, the function should return -1. If
318
an error occurs after some data has been read from the device, that data is
319
lost.
320
.PP
321
If \fIinputProc\fR can determine that the input device has some data
322
available but less than requested by the \fIbufSize\fR argument, the
323
function should only attempt to read as much data as is available and
324
return without blocking. If the input device has no data available
325
whatsoever and the channel is in nonblocking mode, the function should
326
return an \fBEAGAIN\fR error. If the input device has no data available
327
whatsoever and the channel is in blocking mode, the function should block
328
for the shortest possible time until at least one byte of data can be read
329
from the device; then, it should return as much data as it can read without
330
blocking.
331
 
332
.SH OUTPUTPROC
333
.PP
334
The \fIoutputProc\fR field contains the address of a function called by the
335
generic layer to transfer data from an internal buffer to the output device.
336
\fIOutputProc\fR must match the following prototype:
337
.PP
338
.CS
339
typedef int Tcl_DriverOutputProc(
340
        ClientData \fIinstanceData\fR,
341
        char *\fIbuf\fR,
342
        int \fItoWrite\fR,
343
        int *\fIerrorCodePtr\fR);
344
.CE
345
.PP
346
\fIInstanceData\fR is the same as the value passed to
347
\fBTcl_CreateChannel\fR when the channel was created. The \fIbuf\fR
348
argument contains an array of bytes to be written to the device, and the
349
\fItoWrite\fR argument indicates how many bytes are to be written from the
350
\fIbuf\fR argument.
351
.PP
352
The \fIerrorCodePtr\fR argument points to an integer variable provided by
353
the generic layer. If an error occurs, the function should set this
354
variable to a POSIX error code that identifies the error.
355
.PP
356
The function should write the data at \fIbuf\fR to the output device
357
encapsulated by the channel. On success, the function should return a
358
nonnegative integer indicating how many bytes were written to the output
359
device.  The return value is normally the same as \fItoWrite\fR, but may be
360
less in some cases such as if the output operation is interrupted by a
361
signal. If an error occurs the function should return -1.  In case of
362
error, some data may have been written to the device.
363
.PP
364
If the channel is nonblocking and the output device is unable to absorb any
365
data whatsoever, the function should return -1 with an \fBEAGAIN\fR error
366
without writing any data.
367
 
368
.SH SEEKPROC
369
.PP
370
The \fIseekProc\fR field contains the address of a function called by the
371
generic layer to move the access point at which subsequent input or output
372
operations will be applied. \fISeekProc\fR must match the following
373
prototype:
374
.PP
375
.CS
376
typedef int Tcl_DriverSeekProc(
377
        ClientData \fIinstanceData\fR,
378
        long \fIoffset\fR,
379
        int \fIseekMode\fR,
380
        int *\fIerrorCodePtr\fR);
381
.CE
382
.PP
383
The \fIinstanceData\fR argument is the same as the value given to
384
\fBTcl_CreateChannel\fR when this channel was created.  \fIOffset\fR and
385
\fIseekMode\fR have the same meaning as for the \fBTcl_SeekChannel\fR
386
procedure (described in the manual entry for \fBTcl_OpenFileChannel\fR).
387
.PP
388
The \fIerrorCodePtr\fR argument points to an integer variable provided by
389
the generic layer for returning \fBerrno\fR values from the function.  The
390
function should set this variable to a POSIX error code if an error occurs.
391
The function should store an \fBEINVAL\fR error code if the channel type
392
does not implement seeking.
393
.PP
394
The return value is the new access point or -1 in case of error. If an
395
error occurred, the function should not move the access point.
396
 
397
.SH SETOPTIONPROC
398
.PP
399
The \fIsetOptionProc\fR field contains the address of a function called by
400
the generic layer to set a channel type specific option on a channel.
401
\fIsetOptionProc\fR must match the following prototype:
402
.PP
403
.CS
404
typedef int Tcl_DriverSetOptionProc(
405
        ClientData \fIinstanceData\fR,
406
        Tcl_Interp *\fIinterp\fR,
407
        char *\fIoptionName\fR,
408
        char *\fIoptionValue\fR);
409
.CE
410
.PP
411
\fIoptionName\fR is the name of an option to set, and \fIoptionValue\fR is
412
the new value for that option, as a string. The \fIinstanceData\fR is the
413
same as the value given to \fBTcl_CreateChannel\fR when this channel was
414
created. The function should do whatever channel type specific action is
415
required to implement the new value of the option.
416
.PP
417
Some options are handled by the generic code and this function is never
418
called to set them, e.g. \fB-blockmode\fR. Other options are specific to
419
each channel type and the \fIsetOptionProc\fR procedure of the channel
420
driver will get called to implement them. The \fIsetOptionProc\fR field can
421
be NULL, which indicates that this channel type supports no type specific
422
options.
423
.PP
424
If the option value is successfully modified to the new value, the function
425
returns \fBTCL_OK\fR.
426
.VS
427
It should call \fBTcl_BadChannelOption\fR which itself returns
428
\fBTCL_ERROR\fR if the \fIoptionName\fR is
429
unrecognized.
430
.VE
431
If \fIoptionValue\fR specifies a value for the option that
432
is not supported or if a system call error occurs,
433
the function should leave an error message in the
434
\fIresult\fR field of \fIinterp\fR if \fIinterp\fR is not NULL. The
435
function should also call \fBTcl_SetErrno\fR to store an appropriate POSIX
436
error code.
437
 
438
.SH GETOPTIONPROC
439
.PP
440
The \fIgetOptionProc\fR field contains the address of a function called by
441
the generic layer to get the value of a channel type specific option on a
442
channel. \fIgetOptionProc\fR must match the following prototype:
443
.PP
444
.CS
445
typedef int Tcl_DriverGetOptionProc(
446
        ClientData \fIinstanceData\fR,
447
.VS
448
        Tcl_Interp *\fIinterp\fR,
449
.VE
450
        char *\fIoptionName\fR,
451
        Tcl_DString *\fIdsPtr\fR);
452
.CE
453
.PP
454
\fIOptionName\fR is the name of an option supported by this type of
455
channel. If the option name is not NULL, the function stores its current
456
value, as a string, in the Tcl dynamic string \fIdsPtr\fR.
457
If \fIoptionName\fR is NULL, the function stores in \fIdsPtr\fR an
458
alternating list of all supported options and their current values.
459
On success, the function returns \fBTCL_OK\fR.
460
.VS
461
It should call \fBTcl_BadChannelOption\fR which itself returns
462
\fBTCL_ERROR\fR if the \fIoptionName\fR is
463
unrecognized. If a system call error occurs,
464
the function should leave an error message in the
465
\fIresult\fR field of \fIinterp\fR if \fIinterp\fR is not NULL. The
466
function should also call \fBTcl_SetErrno\fR to store an appropriate POSIX
467
error code.
468
.VE
469
.PP
470
Some options are handled by the generic code and this function is never
471
called to retrieve their value, e.g. \fB-blockmode\fR. Other options are
472
specific to each channel type and the \fIgetOptionProc\fR procedure of the
473
channel driver will get called to implement them. The \fIgetOptionProc\fR
474
field can be NULL, which indicates that this channel type supports no type
475
specific options.
476
 
477
.SH WATCHPROC
478
.VS
479
.PP
480
The \fIwatchProc\fR field contains the address of a function called
481
by the generic layer to initialize the event notification mechanism to
482
notice events of interest on this channel.
483
\fIWatchProc\fR should match the following prototype:
484
.PP
485
.CS
486
typedef void Tcl_DriverWatchProc(
487
        ClientData \fIinstanceData\fR,
488
        int \fImask\fR);
489
.CE
490
.VE
491
.PP
492
The \fIinstanceData\fR is the same as the value passed to
493
\fBTcl_CreateChannel\fR when this channel was created. The \fImask\fR
494
argument is an OR-ed combination of \fBTCL_READABLE\fR, \fBTCL_WRITABLE\fR
495
and \fBTCL_EXCEPTION\fR; it indicates events the caller is interested in
496
noticing on this channel.
497
.PP
498
.VS
499
The function should initialize device type specific mechanisms to
500
notice when an event of interest is present on the channel.  When one
501
or more of the designated events occurs on the channel, the channel
502
driver is responsible for calling \fBTcl_NotifyChannel\fR to inform
503
the generic channel module.  The driver should take care not to starve
504
other channel drivers or sources of callbacks by invoking
505
Tcl_NotifyChannel too frequently.  Fairness can be insured by using
506
the Tcl event queue to allow the channel event to be scheduled in sequence
507
with other events.  See the description of \fBTcl_QueueEvent\fR for
508
details on how to queue an event.
509
 
510
.SH GETHANDLEPROC
511
.PP
512
The \fIgetHandleProc\fR field contains the address of a function called by
513
the generic layer to retrieve a device-specific handle from the channel.
514
\fIGetHandleProc\fR should match the following prototype:
515
.PP
516
.CS
517
typedef int Tcl_DriverGetHandleProc(
518
        ClientData \fIinstanceData\fR,
519
        int \fIdirection\fR,
520
        ClientData *\fIhandlePtr\fR);
521
.CE
522
.PP
523
\fIInstanceData is the same as the value passed to
524
\fBTcl_CreateChannel\fR when this channel was created. The \fIdirection\fR
525
argument is either \fBTCL_READABLE\fR to retrieve the handle used
526
for input, or \fBTCL_WRITABLE\fR to retrieve the handle used for
527
output.
528
.PP
529
If the channel implementation has device-specific handles, the
530
function should retrieve the appropriate handle associated with the
531
channel, according the \fIdirection\fR argument.  The handle should be
532
stored in the location referred to by \fIhandlePtr\fR, and
533
\fBTCL_OK\fR should be returned.  If the channel is not open for the
534
specified direction, or if the channel implementation does not use
535
device handles, the function should return \fBTCL_ERROR\fR.
536
.VE
537
 
538
.VS
539
.SH TCL_BADCHANNELOPTION
540
.PP
541
This procedure generates a "bad option" error message in an
542
(optional) interpreter.  It is used by channel drivers when
543
a invalid Set/Get option is requested. Its purpose is to concatenate
544
the generic options list to the specific ones and factorize
545
the generic options error message string.
546
.PP
547
It always return \fBTCL_ERROR\fR
548
.PP
549
An error message is generated in interp's result object to
550
indicate that a command was invoked with the a bad option
551
The message has the form
552
.CS
553
    bad option "blah": should be one of
554
    <...generic options...>+<...specific options...>
555
so you get for instance:
556
    bad option "-blah": should be one of -blocking,
557
    -buffering, -buffersize, -eofchar, -translation,
558
    -peername, or -sockname
559
when called with optionList="peername sockname"
560
.CE
561
"blah" is the optionName argument and ""
562
is a space separated list of specific option words.
563
The function takes good care of inserting minus signs before
564
each option, commas after, and an "or" before the last option.
565
.VE
566
 
567
.SH "SEE ALSO"
568
Tcl_Close(3), Tcl_OpenFileChannel(3), Tcl_SetErrno(3), Tcl_QueueEvent(3)
569
 
570
.SH KEYWORDS
571
blocking, channel driver, channel registration, channel type, nonblocking

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.