OSDN Git Service

FIRST REPOSITORY
[eos/hostdependOTHERS.git] / ALPHALINUX5 / util / ALPHALINUX5 / man / man3 / Tcl_UniChar.3
1 '\"
2 '\" Copyright (c) 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: Utf.3,v 1.7 2000/04/25 17:55:29 hobbs Exp $
8 '\" 
9 '\" The definitions below are for supplemental macros used in Tcl/Tk
10 '\" 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
54 '\"     Start of list of standard options for a Tk widget.  The
55 '\"     options follow on successive lines, in four columns separated
56 '\"     by tabs.
57 '\"
58 '\" .SE
59 '\"     End of list of standard options for a Tk widget.
60 '\"
61 '\" .OP cmdName dbName dbClass
62 '\"     Start of description of a specific option.  cmdName gives the
63 '\"     option's name as specified in the class command, dbName gives
64 '\"     the option's name in the option database, and dbClass gives
65 '\"     the option's class in the option database.
66 '\"
67 '\" .UL arg1 arg2
68 '\"     Print arg1 underlined, then print arg2 normally.
69 '\"
70 '\" RCS: @(#) $Id: man.macros,v 1.3 1999/04/16 00:46:35 stanton Exp $
71 '\"
72 '\"     # Set up traps and other miscellaneous stuff for Tcl/Tk man pages.
73 .if t .wh -1.3i ^B
74 .nr ^l \n(.l
75 .ad b
76 '\"     # Start an argument description
77 .de AP
78 .ie !"\\$4"" .TP \\$4
79 .el \{\
80 .   ie !"\\$2"" .TP \\n()Cu
81 .   el          .TP 15
82 .\}
83 .ta \\n()Au \\n()Bu
84 .ie !"\\$3"" \{\
85 \&\\$1  \\fI\\$2\\fP    (\\$3)
86 .\".b
87 .\}
88 .el \{\
89 .br
90 .ie !"\\$2"" \{\
91 \&\\$1  \\fI\\$2\\fP
92 .\}
93 .el \{\
94 \&\\fI\\$1\\fP
95 .\}
96 .\}
97 ..
98 '\"     # define tabbing values for .AP
99 .de AS
100 .nr )A 10n
101 .if !"\\$1"" .nr )A \\w'\\$1'u+3n
102 .nr )B \\n()Au+15n
103 .\"
104 .if !"\\$2"" .nr )B \\w'\\$2'u+\\n()Au+3n
105 .nr )C \\n()Bu+\\w'(in/out)'u+2n
106 ..
107 .AS Tcl_Interp Tcl_CreateInterp in/out
108 '\"     # BS - start boxed text
109 '\"     # ^y = starting y location
110 '\"     # ^b = 1
111 .de BS
112 .br
113 .mk ^y
114 .nr ^b 1u
115 .if n .nf
116 .if n .ti 0
117 .if n \l'\\n(.lu\(ul'
118 .if n .fi
119 ..
120 '\"     # BE - end boxed text (draw box now)
121 .de BE
122 .nf
123 .ti 0
124 .mk ^t
125 .ie n \l'\\n(^lu\(ul'
126 .el \{\
127 .\"     Draw four-sided box normally, but don't draw top of
128 .\"     box if the box started on an earlier page.
129 .ie !\\n(^b-1 \{\
130 \h'-1.5n'\L'|\\n(^yu-1v'\l'\\n(^lu+3n\(ul'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
131 .\}
132 .el \}\
133 \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\l'|0u-1.5n\(ul'
134 .\}
135 .\}
136 .fi
137 .br
138 .nr ^b 0
139 ..
140 '\"     # VS - start vertical sidebar
141 '\"     # ^Y = starting y location
142 '\"     # ^v = 1 (for troff;  for nroff this doesn't matter)
143 .de VS
144 .if !"\\$2"" .br
145 .mk ^Y
146 .ie n 'mc \s12\(br\s0
147 .el .nr ^v 1u
148 ..
149 '\"     # VE - end of vertical sidebar
150 .de VE
151 .ie n 'mc
152 .el \{\
153 .ev 2
154 .nf
155 .ti 0
156 .mk ^t
157 \h'|\\n(^lu+3n'\L'|\\n(^Yu-1v\(bv'\v'\\n(^tu+1v-\\n(^Yu'\h'-|\\n(^lu+3n'
158 .sp -1
159 .fi
160 .ev
161 .\}
162 .nr ^v 0
163 ..
164 '\"     # Special macro to handle page bottom:  finish off current
165 '\"     # box/sidebar if in box/sidebar mode, then invoked standard
166 '\"     # page bottom macro.
167 .de ^B
168 .ev 2
169 'ti 0
170 'nf
171 .mk ^t
172 .if \\n(^b \{\
173 .\"     Draw three-sided box if this is the box's first page,
174 .\"     draw two sides but no top otherwise.
175 .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
176 .el \h'-1.5n'\L'|\\n(^yu-1v'\h'\\n(^lu+3n'\L'\\n(^tu+1v-\\n(^yu'\h'|0u'\c
177 .\}
178 .if \\n(^v \{\
179 .nr ^x \\n(^tu+1v-\\n(^Yu
180 \kx\h'-\\nxu'\h'|\\n(^lu+3n'\ky\L'-\\n(^xu'\v'\\n(^xu'\h'|0u'\c
181 .\}
182 .bp
183 'fi
184 .ev
185 .if \\n(^b \{\
186 .mk ^y
187 .nr ^b 2
188 .\}
189 .if \\n(^v \{\
190 .mk ^Y
191 .\}
192 ..
193 '\"     # DS - begin display
194 .de DS
195 .RS
196 .nf
197 .sp
198 ..
199 '\"     # DE - end display
200 .de DE
201 .fi
202 .RE
203 .sp
204 ..
205 '\"     # SO - start of list of standard options
206 .de SO
207 .SH "STANDARD OPTIONS"
208 .LP
209 .nf
210 .ta 4c 8c 12c
211 .ft B
212 ..
213 '\"     # SE - end of list of standard options
214 .de SE
215 .fi
216 .ft R
217 .LP
218 See the \\fBoptions\\fR manual entry for details on the standard options.
219 ..
220 '\"     # OP - start of full description for a single option
221 .de OP
222 .LP
223 .nf
224 .ta 4c
225 Command-Line Name:      \\fB\\$1\\fR
226 Database Name:  \\fB\\$2\\fR
227 Database Class: \\fB\\$3\\fR
228 .fi
229 .IP
230 ..
231 '\"     # CS - begin code excerpt
232 .de CS
233 .RS
234 .nf
235 .ta .25i .5i .75i 1i
236 ..
237 '\"     # CE - end code excerpt
238 .de CE
239 .fi
240 .RE
241 ..
242 .de UL
243 \\$1\l'|0\(ul'\\$2
244 ..
245 .TH Utf 3 "8.1" Tcl "Tcl Library Procedures"
246 .BS
247 .SH NAME
248 Tcl_UniChar, Tcl_UniCharToUtf, Tcl_UtfToUniChar, Tcl_UniCharToUtfDString, Tcl_UtfToUniCharDString, Tcl_UniCharLen, Tcl_UniCharNcmp, Tcl_UtfCharComplete, Tcl_NumUtfChars, Tcl_UtfFindFirst, Tcl_UtfFindLast, Tcl_UtfNext, Tcl_UtfPrev, Tcl_UniCharAtIndex, Tcl_UtfAtIndex, Tcl_UtfBackslash \- routines for manipulating UTF-8 strings.
249 .SH SYNOPSIS
250 .nf
251 \fB#include <tcl.h>\fR
252 .sp
253 typedef ... Tcl_UniChar;
254 .sp
255 int
256 \fBTcl_UniCharToUtf\fR(\fIch, buf\fR)
257 .sp
258 int
259 \fBTcl_UtfToUniChar\fR(\fIsrc, chPtr\fR)
260 .sp
261 char *
262 \fBTcl_UniCharToUtfDString\fR(\fIuniStr, numChars, dstPtr\fR)
263 .sp
264 Tcl_UniChar *
265 \fBTcl_UtfToUniCharDString\fR(\fIsrc, len, dstPtr\fR)
266 .sp
267 int
268 \fBTcl_UniCharLen\fR(\fIuniStr\fR)
269 .sp
270 int
271 \fBTcl_UniCharNcmp\fR(\fIuniStr, uniStr, num\fR)
272 .sp
273 int
274 \fBTcl_UtfNcmp\fR(\fIsrc, src, num\fR)
275 .sp
276 int
277 \fBTcl_UtfNcasecmp\fR(\fIsrc, src, num\fR)
278 .sp
279 int
280 \fBTcl_UtfCharComplete\fR(\fIsrc, len\fR)
281 .sp
282 int 
283 \fBTcl_NumUtfChars\fR(\fIsrc, len\fR)
284 .sp
285 char *
286 \fBTcl_UtfFindFirst\fR(\fIsrc, ch\fR)
287 .sp
288 char *
289 \fBTcl_UtfFindLast\fR(\fIsrc, ch\fR)
290 .sp
291 char *
292 \fBTcl_UtfNext\fR(\fIsrc\fR)
293 .sp
294 char *
295 \fBTcl_UtfPrev\fR(\fIsrc, start\fR)
296 .sp
297 Tcl_UniChar
298 \fBTcl_UniCharAtIndex\fR(\fIsrc, index\fR)
299 .sp
300 char *
301 \fBTcl_UtfAtIndex\fR(\fIsrc, index\fR)
302 .sp
303 int
304 \fBTcl_UtfBackslash\fR(\fIsrc, readPtr, dst\fR)
305 .SH ARGUMENTS
306 .AS "CONST Tcl_UniChar" numChars in/out
307 .AP char *buf out
308 Buffer in which the UTF-8 representation of the Tcl_UniChar is stored.  At most
309 TCL_UTF_MAX bytes are stored in the buffer.
310 .AP int ch in
311 The Tcl_UniChar to be converted or examined.
312 .AP Tcl_UniChar *chPtr out
313 Filled with the Tcl_UniChar represented by the head of the UTF-8 string.
314 .AP "CONST char" *src in
315 Pointer to a UTF-8 string.
316 .AP "CONST Tcl_UniChar" *uniStr in
317 A NULL-terminated Unicode string.
318 .AP int len in
319 The length of the UTF-8 string in bytes (not UTF-8 characters).  If
320 negative, all bytes up to the first null byte are used.
321 .AP int numChars in
322 The length of the Unicode string in characters.  Must be greater than or
323 equal to 0.
324 .AP "Tcl_DString" *dstPtr in/out
325 A pointer to a previously-initialized \fBTcl_DString\fR.
326 .AP "unsigned long" num in
327 The number of characters to compare.
328 .AP "CONST char" *start in
329 Pointer to the beginning of a UTF-8 string.
330 .AP int index in
331 The index of a character (not byte) in the UTF-8 string.
332 .AP int *readPtr out
333 If non-NULL, filled with the number of bytes in the backslash sequence, 
334 including the backslash character.
335 .AP char *dst out
336 Buffer in which the bytes represented by the backslash sequence are stored.
337 At most TCL_UTF_MAX bytes are stored in the buffer.
338 .BE
339
340 .SH DESCRIPTION
341 .PP
342 These routines convert between UTF-8 strings and Tcl_UniChars.  A
343 Tcl_UniChar is a Unicode character represented as an unsigned, fixed-size
344 quantity.  A UTF-8 character is a Unicode character represented as
345 a varying-length sequence of up to TCL_UTF_MAX bytes.  A multibyte UTF-8
346 sequence consists of a lead byte followed by some number of trail bytes.
347 .PP
348 \fBTCL_UTF_MAX\fR is the maximum number of bytes that it takes to
349 represent one Unicode character in the UTF-8 representation.
350 .PP
351 \fBTcl_UniCharToUtf\fR stores the Tcl_UniChar \fIch\fR as a UTF-8 string
352 in starting at \fIbuf\fR.  The return value is the number of bytes stored
353 in \fIbuf\fR.
354 .PP
355 \fBTcl_UtfToUniChar\fR reads one UTF-8 character starting at \fIsrc\fR
356 and stores it as a Tcl_UniChar in \fI*chPtr\fR.  The return value is the
357 number of bytes read from \fIsrc\fR..  The caller must ensure that the
358 source buffer is long enough such that this routine does not run off the
359 end and dereference non-existent or random memory; if the source buffer
360 is known to be null terminated, this will not happen.  If the input is
361 not in proper UTF-8 format, \fBTcl_UtfToUniChar\fR will store the first
362 byte of \fIsrc\fR in \fI*chPtr\fR as a Tcl_UniChar between 0x0000 and
363 0x00ff and return 1.  
364 .PP
365 \fBTcl_UniCharToUtfDString\fR converts the given Unicode string
366 to UTF-8, storing the result in a previously-initialized \fBTcl_DString\fR.
367 You must specify the length of the given Unicode string.
368 The return value is a pointer to the UTF-8 representation of the
369 Unicode string.  Storage for the return value is appended to the
370 end of the \fBTcl_DString\fR.
371 .PP
372 \fBTcl_UtfToUniCharDString\fR coverts the given UTF-8 string to Unicode,
373 storing the result in the previously-initialized \fBTcl_Dstring\fR.
374 you may either specify the length of the given UTF-8 string or "-1",
375 in which case \fBTcl_UtfToUniCharDString\fR uses \fBstrlen\fR to
376 calculate the length.  The return value is a pointer to the Unicode
377 representation of the UTF-8 string.  Storage for the return value
378 is appended to the end of the \fBTcl_DString\fR.  The Unicode string
379 is terminated with a Unicode NULL character.
380 .PP
381 \fBTcl_UniCharLen\fR corresponds to \fBstrlen\fR for Unicode
382 characters.  It accepts a NULL-terminated Unicode string and returns
383 the number of Unicode characters (not bytes) in that string.
384 .PP
385 \fBTcl_UniCharNcmp\fR corresponds to \fBstrncmp\fR for Unicode
386 characters.  It accepts two NULL-terminated Unicode strings
387 and the number of characters to compare.  (Both strings are
388 assumed to be at least \fIlen\fR characters long.)
389 \fBTcl_UniCharNcmp\fR compares the two strings character-by-character
390 according to the Unicode character ordering.  It returns an integer
391 greater than, equal to,
392 or less than 0 if the first string is greater than, equal to, or
393 less than the second string respectively.
394 .PP
395 \fBTcl_UtfNcmp\fR corresponds to \fBstrncmp\fR for UTF-8 strings. It
396 accepts two NULL-terminated UTF-8 strings and the number of characters
397 to compare.  (Both strings are assumed to be at least \fIlen\fR
398 characters long.)  \fBTcl_UtfNcmp\fR compares the two strings
399 character-by-character according to the Unicode character ordering.
400 It returns an integer greater than, equal to, or less than 0 if the
401 first string is greater than, equal to, or less than the second string
402 respectively.
403 .PP
404 \fBTcl_UtfNcasecmp\fR corresponds to \fBstrncasecmp\fR for UTF-8
405 strings.  It is similar to \fBTcl_UtfNcmp\fR except comparisons ignore
406 differences in case when comparing upper, lower or title case
407 characters.
408 .PP
409 \fBTcl_UtfCharComplete\fR returns 1 if the source UTF-8 string \fIsrc\fR
410 of length \fIlen\fR bytes is long enough to be decoded by
411 \fBTcl_UtfToUniChar\fR, or 0 otherwise.  This function does not guarantee
412 that the UTF-8 string is properly formed.  This routine is used by
413 procedures that are operating on a byte at a time and need to know if a
414 full Tcl_UniChar has been seen.
415 .PP
416 \fBTcl_NumUtfChars\fR corresponds to \fBstrlen\fR for UTF-8 strings.  It
417 returns the number of Tcl_UniChars that are represented by the UTF-8 string
418 \fIsrc\fR.  The length of the source string is \fIlen\fR bytes.  If the
419 length is negative, all bytes up to the first NULL byte are used.
420 .PP
421 \fBTcl_UtfFindFirst\fR corresponds to \fBstrchr\fR for UTF-8 strings.  It
422 returns a pointer to the first occurance of the Tcl_UniChar \fIch\fR
423 in the NULL-terminated UTF-8 string \fIsrc\fR.  The NULL terminator is
424 considered part of the UTF-8 string.  
425 .PP
426 \fBTcl_UtfFindLast\fR corresponds to \fBstrrchr\fR for UTF-8 strings.  It
427 returns a pointer to the last occurance of the Tcl_UniChar \fIch\fR
428 in the NULL terminated UTF-8 string \fIsrc\fR.  The NULL terminator is
429 considered part of the UTF-8 string.  
430 .PP
431 Given \fIsrc\fR, a pointer to some location in a UTF-8 string,
432 \fBTcl_UtfNext\fR returns a pointer to the next UTF-8 character in the
433 string.  The caller must not ask for the next character after the last
434 character in the string.
435 .PP
436 Given \fIsrc\fR, a pointer to some location in a UTF-8 string,
437 \fBTcl_UtfPrev\fR returns a pointer to the previous UTF-8 character in the
438 string.  This function will not back up to a position before \fIstart\fR,
439 the start of the UTF-8 string.  If \fIsrc\fR was already at \fIstart\fR, the
440 return value will be \fIstart\fR.
441 .PP
442 \fBTcl_UniCharAtIndex\fR corresponds to a C string array dereference or the
443 Pascal Ord() function.  It returns the Tcl_UniChar represented at the
444 specified character (not byte) \fIindex\fR in the UTF-8 string
445 \fIsrc\fR.  The source string must contain at least \fIindex\fR
446 characters.  Behavior is undefined if a negative \fIindex\fR is given.
447 .PP
448 \fBTcl_UtfAtIndex\fR returns a pointer to the specified character (not
449 byte) \fIindex\fR in the UTF-8 string \fIsrc\fR.  The source string must
450 contain at least \fIindex\fR characters.  This is equivalent to calling 
451 \fBTcl_UtfNext\fR \fIindex\fR times.  If a negative \fIindex\fR is given,
452 the return pointer points to the first character in the source string.
453 .PP
454 \fBTcl_UtfBackslash\fR is a utility procedure used by several of the Tcl
455 commands.  It parses a backslash sequence and stores the properly formed
456 UTF-8 character represented by the backslash sequence in the output
457 buffer \fIdst\fR.  At most TCL_UTF_MAX bytes are stored in the buffer.
458 \fBTcl_UtfBackslash\fR modifies \fI*readPtr\fR to contain the number
459 of bytes in the backslash sequence, including the backslash character.
460 The return value is the number of bytes stored in the output buffer.
461 .PP
462 See the \fBTcl\fR manual entry for information on the valid backslash
463 sequences.  All of the sequences described in the Tcl manual entry are
464 supported by \fBTcl_UtfBackslash\fR.
465
466 .SH KEYWORDS
467 utf, unicode, backslash