OSDN Git Service

Please enter the commit message for your changes. Lines starting
[eos/hostdependX86LINUX64.git] / util / X86LINUX64 / man / man3 / Tcl_Interp.3
1 '\"
2 '\" Copyright (c) 1989-1993 The Regents of the University of California.
3 '\" Copyright (c) 1994-1996 Sun Microsystems, Inc.
4 '\"
5 '\" See the file "license.terms" for information on usage and redistribution
6 '\" of this file, and for a DISCLAIMER OF ALL WARRANTIES.
7 '\" 
8 .TH Tcl_Interp 3 7.5 Tcl "Tcl Library Procedures"
9 .\" The -*- nroff -*- definitions below are for supplemental macros used
10 .\" in Tcl/Tk manual entries.
11 .\"
12 .\" .AP type name in/out ?indent?
13 .\"     Start paragraph describing an argument to a library procedure.
14 .\"     type is type of argument (int, etc.), in/out is either "in", "out",
15 .\"     or "in/out" to describe whether procedure reads or modifies arg,
16 .\"     and indent is equivalent to second arg of .IP (shouldn't ever be
17 .\"     needed;  use .AS below instead)
18 .\"
19 .\" .AS ?type? ?name?
20 .\"     Give maximum sizes of arguments for setting tab stops.  Type and
21 .\"     name are examples of largest possible arguments that will be passed
22 .\"     to .AP later.  If args are omitted, default tab stops are used.
23 .\"
24 .\" .BS
25 .\"     Start box enclosure.  From here until next .BE, everything will be
26 .\"     enclosed in one large box.
27 .\"
28 .\" .BE
29 .\"     End of box enclosure.
30 .\"
31 .\" .CS
32 .\"     Begin code excerpt.
33 .\"
34 .\" .CE
35 .\"     End code excerpt.
36 .\"
37 .\" .VS ?version? ?br?
38 .\"     Begin vertical sidebar, for use in marking newly-changed parts
39 .\"     of man pages.  The first argument is ignored and used for recording
40 .\"     the version when the .VS was added, so that the sidebars can be
41 .\"     found and removed when they reach a certain age.  If another argument
42 .\"     is present, then a line break is forced before starting the sidebar.
43 .\"
44 .\" .VE
45 .\"     End of vertical sidebar.
46 .\"
47 .\" .DS
48 .\"     Begin an indented unfilled display.
49 .\"
50 .\" .DE
51 .\"     End of indented unfilled display.
52 .\"
53 .\" .SO ?manpage?
54 .\"     Start of list of standard options for a Tk widget. The manpage
55 .\"     argument defines where to look up the standard options; if
56 .\"     omitted, defaults to "options". The options follow on successive
57 .\"     lines, in three columns separated by tabs.
58 .\"
59 .\" .SE
60 .\"     End of list of standard options for a Tk widget.
61 .\"
62 .\" .OP cmdName dbName dbClass
63 .\"     Start of description of a specific option.  cmdName gives the
64 .\"     option's name as specified in the class command, dbName gives
65 .\"     the option's name in the option database, and dbClass gives
66 .\"     the option's class in the option database.
67 .\"
68 .\" .UL arg1 arg2
69 .\"     Print arg1 underlined, then print arg2 normally.
70 .\"
71 .\" .QW arg1 ?arg2?
72 .\"     Print arg1 in quotes, then arg2 normally (for trailing punctuation).
73 .\"
74 .\" .PQ arg1 ?arg2?
75 .\"     Print an open parenthesis, arg1 in quotes, then arg2 normally
76 .\"     (for trailing punctuation) and then a closing parenthesis.
77 .\"
78 .\"     # Set up traps and other miscellaneous stuff for Tcl/Tk man pages.
79 .if t .wh -1.3i ^B
80 .nr ^l \n(.l
81 .ad b
82 .\"     # Start an argument description
83 .de AP
84 .ie !"\\$4"" .TP \\$4
85 .el \{\
86 .   ie !"\\$2"" .TP \\n()Cu
87 .   el          .TP 15
88 .\}
89 .ta \\n()Au \\n()Bu
90 .ie !"\\$3"" \{\
91 \&\\$1 \\fI\\$2\\fP (\\$3)
92 .\".b
93 .\}
94 .el \{\
95 .br
96 .ie !"\\$2"" \{\
97 \&\\$1  \\fI\\$2\\fP
98 .\}
99 .el \{\
100 \&\\fI\\$1\\fP
101 .\}
102 .\}
103 ..
104 .\"     # define tabbing values for .AP
105 .de AS
106 .nr )A 10n
107 .if !"\\$1"" .nr )A \\w'\\$1'u+3n
108 .nr )B \\n()Au+15n
109 .\"
110 .if !"\\$2"" .nr )B \\w'\\$2'u+\\n()Au+3n
111 .nr )C \\n()Bu+\\w'(in/out)'u+2n
112 ..
113 .AS Tcl_Interp Tcl_CreateInterp in/out
114 .\"     # BS - start boxed text
115 .\"     # ^y = starting y location
116 .\"     # ^b = 1
117 .de BS
118 .br
119 .mk ^y
120 .nr ^b 1u
121 .if n .nf
122 .if n .ti 0
123 .if n \l'\\n(.lu\(ul'
124 .if n .fi
125 ..
126 .\"     # BE - end boxed text (draw box now)
127 .de BE
128 .nf
129 .ti 0
130 .mk ^t
131 .ie n \l'\\n(^lu\(ul'
132 .el \{\
133 .\"     Draw four-sided box normally, but don't draw top of
134 .\"     box if the box started on an earlier page.
135 .ie !\\n(^b-1 \{\
136 \h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
137 .\}
138 .el \}\
139 \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
140 .\}
141 .\}
142 .fi
143 .br
144 .nr ^b 0
145 ..
146 .\"     # VS - start vertical sidebar
147 .\"     # ^Y = starting y location
148 .\"     # ^v = 1 (for troff;  for nroff this doesn't matter)
149 .de VS
150 .if !"\\$2"" .br
151 .mk ^Y
152 .ie n 'mc \s12\(br\s0
153 .el .nr ^v 1u
154 ..
155 .\"     # VE - end of vertical sidebar
156 .de VE
157 .ie n 'mc
158 .el \{\
159 .ev 2
160 .nf
161 .ti 0
162 .mk ^t
163 \h'|\\n(^lu+3n'\L'|\\n(^Yu-1v\(bv'\v'\\n(^tu+1v-\\n(^Yu'\h'-|\\n(^lu+3n'
164 .sp -1
165 .fi
166 .ev
167 .\}
168 .nr ^v 0
169 ..
170 .\"     # Special macro to handle page bottom:  finish off current
171 .\"     # box/sidebar if in box/sidebar mode, then invoked standard
172 .\"     # page bottom macro.
173 .de ^B
174 .ev 2
175 'ti 0
176 'nf
177 .mk ^t
178 .if \\n(^b \{\
179 .\"     Draw three-sided box if this is the box's first page,
180 .\"     draw two sides but no top otherwise.
181 .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
182 .el \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c
183 .\}
184 .if \\n(^v \{\
185 .nr ^x \\n(^tu+1v-\\n(^Yu
186 \kx\h'-\\nxu'\h'|\\n(^lu+3n'\ky\L'-\\n(^xu'\v'\\n(^xu'\h'|0u'\c
187 .\}
188 .bp
189 'fi
190 .ev
191 .if \\n(^b \{\
192 .mk ^y
193 .nr ^b 2
194 .\}
195 .if \\n(^v \{\
196 .mk ^Y
197 .\}
198 ..
199 .\"     # DS - begin display
200 .de DS
201 .RS
202 .nf
203 .sp
204 ..
205 .\"     # DE - end display
206 .de DE
207 .fi
208 .RE
209 .sp
210 ..
211 .\"     # SO - start of list of standard options
212 .de SO
213 'ie '\\$1'' .ds So \\fBoptions\\fR
214 'el .ds So \\fB\\$1\\fR
215 .SH "STANDARD OPTIONS"
216 .LP
217 .nf
218 .ta 5.5c 11c
219 .ft B
220 ..
221 .\"     # SE - end of list of standard options
222 .de SE
223 .fi
224 .ft R
225 .LP
226 See the \\*(So manual entry for details on the standard options.
227 ..
228 .\"     # OP - start of full description for a single option
229 .de OP
230 .LP
231 .nf
232 .ta 4c
233 Command-Line Name:      \\fB\\$1\\fR
234 Database Name:  \\fB\\$2\\fR
235 Database Class: \\fB\\$3\\fR
236 .fi
237 .IP
238 ..
239 .\"     # CS - begin code excerpt
240 .de CS
241 .RS
242 .nf
243 .ta .25i .5i .75i 1i
244 ..
245 .\"     # CE - end code excerpt
246 .de CE
247 .fi
248 .RE
249 ..
250 .\"     # UL - underline word
251 .de UL
252 \\$1\l'|0\(ul'\\$2
253 ..
254 .\"     # QW - apply quotation marks to word
255 .de QW
256 .ie '\\*(lq'"' ``\\$1''\\$2
257 .\"" fix emacs highlighting
258 .el \\*(lq\\$1\\*(rq\\$2
259 ..
260 .\"     # PQ - apply parens and quotation marks to word
261 .de PQ
262 .ie '\\*(lq'"' (``\\$1''\\$2)\\$3
263 .\"" fix emacs highlighting
264 .el (\\*(lq\\$1\\*(rq\\$2)\\$3
265 ..
266 .\"     # QR - quoted range
267 .de QR
268 .ie '\\*(lq'"' ``\\$1''\\-``\\$2''\\$3
269 .\"" fix emacs highlighting
270 .el \\*(lq\\$1\\*(rq\\-\\*(lq\\$2\\*(rq\\$3
271 ..
272 .\"     # MT - "empty" string
273 .de MT
274 .QW ""
275 ..
276 .BS
277 .SH NAME
278 Tcl_Interp \- client-visible fields of interpreter structures
279 .SH SYNOPSIS
280 .nf
281 \fB#include <tcl.h>\fR
282 .sp
283 typedef struct {
284     char *\fIresult\fR;
285     Tcl_FreeProc *\fIfreeProc\fR;
286     int \fIerrorLine\fR;
287 } \fBTcl_Interp\fR;
288
289 typedef void \fBTcl_FreeProc\fR(
290         char *\fIblockPtr\fR);
291 .BE
292 .SH DESCRIPTION
293 .PP
294 The \fBTcl_CreateInterp\fR procedure returns a pointer to a Tcl_Interp
295 structure.  Callers of \fBTcl_CreateInterp\fR should use this pointer
296 as an opaque token, suitable for nothing other than passing back to
297 other routines in the Tcl interface.  Accessing fields directly through
298 the pointer as described below is no longer supported.  The supported
299 public routines \fBTcl_SetResult\fR, \fBTcl_GetResult\fR,
300 \fBTcl_SetErrorLine\fR, \fBTcl_GetErrorLine\fR must be used instead.
301 .PP
302 For legacy programs and extensions no longer being maintained, compiles
303 against the Tcl 8.6 header files are only possible with the compiler
304 directives
305 .CS
306 #define USE_INTERP_RESULT
307 .CE
308 and/or
309 .CS
310 #define USE_INTERP_ERRORLINE
311 .CE
312 depending on which fields of the \fBTcl_Interp\fR struct are accessed.
313 These directives may be embedded in code or supplied via compiler options.
314 .PP
315 The \fIresult\fR and \fIfreeProc\fR fields are used to return
316 results or error messages from commands.
317 This information is returned by command procedures back to \fBTcl_Eval\fR,
318 and by \fBTcl_Eval\fR back to its callers.
319 The \fIresult\fR field points to the string that represents the
320 result or error message, and the \fIfreeProc\fR field tells how
321 to dispose of the storage for the string when it is not needed anymore.
322 The easiest way for command procedures to manipulate these
323 fields is to call procedures like \fBTcl_SetResult\fR
324 or \fBTcl_AppendResult\fR;  they
325 will hide all the details of managing the fields.
326 The description below is for those procedures that manipulate the
327 fields directly.
328 .PP
329 Whenever a command procedure returns, it must ensure
330 that the \fIresult\fR field of its interpreter points to the string
331 being returned by the command.
332 The \fIresult\fR field must always point to a valid string.
333 If a command wishes to return no result then \fIinterp->result\fR
334 should point to an empty string.
335 Normally, results are assumed to be statically allocated,
336 which means that the contents will not change before the next time
337 \fBTcl_Eval\fR is called or some other command procedure is invoked.
338 In this case, the \fIfreeProc\fR field must be zero.
339 Alternatively, a command procedure may dynamically
340 allocate its return value (e.g. using \fBTcl_Alloc\fR)
341 and store a pointer to it in \fIinterp->result\fR.
342 In this case, the command procedure must also set \fIinterp->freeProc\fR
343 to the address of a procedure that can free the value, or \fBTCL_DYNAMIC\fR
344 if the storage was allocated directly by Tcl or by a call to
345 \fBTcl_Alloc\fR. 
346 If \fIinterp->freeProc\fR is non-zero, then Tcl will call \fIfreeProc\fR
347 to free the space pointed to by \fIinterp->result\fR before it
348 invokes the next command.
349 If a client procedure overwrites \fIinterp->result\fR when
350 \fIinterp->freeProc\fR is non-zero, then it is responsible for calling
351 \fIfreeProc\fR to free the old \fIinterp->result\fR (the \fBTcl_FreeResult\fR
352 macro should be used for this purpose).
353 .PP
354 \fIFreeProc\fR should have arguments and result that match the
355 \fBTcl_FreeProc\fR declaration above:  it receives a single
356 argument which is a pointer to the result value to free.
357 In most applications \fBTCL_DYNAMIC\fR is the only non-zero value ever
358 used for \fIfreeProc\fR.
359 However, an application may store a different procedure address
360 in \fIfreeProc\fR in order to use an alternate memory allocator
361 or in order to do other cleanup when the result memory is freed.
362 .PP
363 As part of processing each command, \fBTcl_Eval\fR initializes
364 \fIinterp->result\fR
365 and \fIinterp->freeProc\fR just before calling the command procedure for
366 the command.  The \fIfreeProc\fR field will be initialized to zero,
367 and \fIinterp->result\fR will point to an empty string.  Commands that
368 do not return any value can simply leave the fields alone.
369 Furthermore, the empty string pointed to by \fIresult\fR is actually
370 part of an array of \fBTCL_RESULT_SIZE\fR characters (approximately 200).
371 If a command wishes to return a short string, it can simply copy
372 it to the area pointed to by \fIinterp->result\fR.  Or, it can use
373 the sprintf procedure to generate a short result string at the location
374 pointed to by \fIinterp->result\fR.
375 .PP
376 It is a general convention in Tcl-based applications that the result
377 of an interpreter is normally in the initialized state described
378 in the previous paragraph.
379 Procedures that manipulate an interpreter's result (e.g. by
380 returning an error) will generally assume that the result
381 has been initialized when the procedure is called.
382 If such a procedure is to be called after the result has been
383 changed, then \fBTcl_ResetResult\fR should be called first to
384 reset the result to its initialized state.  The direct use of
385 \fIinterp->result\fR is strongly deprecated (see \fBTcl_SetResult\fR).
386 .PP
387 The \fIerrorLine\fR
388 field is valid only after \fBTcl_Eval\fR returns
389 a \fBTCL_ERROR\fR return code.  In this situation the \fIerrorLine\fR
390 field identifies the line number of the command being executed when
391 the error occurred.  The line numbers are relative to the command
392 being executed:  1 means the first line of the command passed to
393 \fBTcl_Eval\fR, 2 means the second line, and so on.
394 The \fIerrorLine\fR field is typically used in conjunction with
395 \fBTcl_AddErrorInfo\fR to report information about where an error
396 occurred.
397 \fIErrorLine\fR should not normally be modified except by \fBTcl_Eval\fR.
398
399 .SH KEYWORDS
400 free, initialized, interpreter, malloc, result