Initial commit of OpenSPARC T2 architecture model.
[OpenSPARC-T2-SAM] / sam-t2 / devtools / v8plus / man / man3 / Tcl_UtfFindFirst.3
CommitLineData
920dae64
AT
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.13.2.2 2003/07/18 22:15:45 dkf 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.4 2000/08/25 06:18:32 ericm 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 5.5c 11c
211.ft B
212..
213'\" # SE - end of list of standard options
214.de SE
215.fi
216.ft R
217.LP
218See 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
225Command-Line Name: \\fB\\$1\\fR
226Database Name: \\fB\\$2\\fR
227Database 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
248Tcl_UniChar, Tcl_UniCharCaseMatch, Tcl_UniCharNcasecmp, 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
253typedef ... Tcl_UniChar;
254.sp
255int
256\fBTcl_UniCharToUtf\fR(\fIch, buf\fR)
257.sp
258int
259\fBTcl_UtfToUniChar\fR(\fIsrc, chPtr\fR)
260.VS 8.4
261.sp
262char *
263\fBTcl_UniCharToUtfDString\fR(\fIuniStr, numChars, dstPtr\fR)
264.sp
265Tcl_UniChar *
266\fBTcl_UtfToUniCharDString\fR(\fIsrc, len, dstPtr\fR)
267.VE 8.4
268.sp
269int
270\fBTcl_UniCharLen\fR(\fIuniStr\fR)
271.sp
272int
273\fBTcl_UniCharNcmp\fR(\fIuniStr, uniStr, num\fR)
274.VS 8.4
275.sp
276int
277\fBTcl_UniCharNcasecmp\fR(\fIuniStr, uniStr, num\fR)
278.sp
279int
280\fBTcl_UniCharCaseMatch\fR(\fIuniStr, uniPattern, nocase\fR)
281.VE 8.4
282.sp
283int
284\fBTcl_UtfNcmp\fR(\fIsrc, src, num\fR)
285.sp
286int
287\fBTcl_UtfNcasecmp\fR(\fIsrc, src, num\fR)
288.sp
289int
290\fBTcl_UtfCharComplete\fR(\fIsrc, len\fR)
291.sp
292int
293\fBTcl_NumUtfChars\fR(\fIsrc, len\fR)
294.VS 8.4
295.sp
296CONST char *
297\fBTcl_UtfFindFirst\fR(\fIsrc, ch\fR)
298.sp
299CONST char *
300\fBTcl_UtfFindLast\fR(\fIsrc, ch\fR)
301.sp
302CONST char *
303\fBTcl_UtfNext\fR(\fIsrc\fR)
304.sp
305CONST char *
306\fBTcl_UtfPrev\fR(\fIsrc, start\fR)
307.VE 8.4
308.sp
309Tcl_UniChar
310\fBTcl_UniCharAtIndex\fR(\fIsrc, index\fR)
311.VS 8.4
312.sp
313CONST char *
314\fBTcl_UtfAtIndex\fR(\fIsrc, index\fR)
315.VE 8.4
316.sp
317int
318\fBTcl_UtfBackslash\fR(\fIsrc, readPtr, dst\fR)
319.SH ARGUMENTS
320.AS "CONST Tcl_UniChar" numChars in/out
321.AP char *buf out
322Buffer in which the UTF-8 representation of the Tcl_UniChar is stored. At most
323TCL_UTF_MAX bytes are stored in the buffer.
324.AP int ch in
325The Tcl_UniChar to be converted or examined.
326.AP Tcl_UniChar *chPtr out
327Filled with the Tcl_UniChar represented by the head of the UTF-8 string.
328.AP "CONST char" *src in
329Pointer to a UTF-8 string.
330.AP "CONST Tcl_UniChar" *uniStr in
331A null-terminated Unicode string.
332.AP "CONST Tcl_UniChar" *uniPattern in
333A null-terminated Unicode string.
334.AP int len in
335The length of the UTF-8 string in bytes (not UTF-8 characters). If
336negative, all bytes up to the first null byte are used.
337.AP int numChars in
338The length of the Unicode string in characters. Must be greater than or
339equal to 0.
340.AP "Tcl_DString" *dstPtr in/out
341A pointer to a previously-initialized \fBTcl_DString\fR.
342.AP "unsigned long" num in
343The number of characters to compare.
344.AP "CONST char" *start in
345Pointer to the beginning of a UTF-8 string.
346.AP int index in
347The index of a character (not byte) in the UTF-8 string.
348.AP int *readPtr out
349If non-NULL, filled with the number of bytes in the backslash sequence,
350including the backslash character.
351.AP char *dst out
352Buffer in which the bytes represented by the backslash sequence are stored.
353At most TCL_UTF_MAX bytes are stored in the buffer.
354.VS 8.4
355.AP int nocase in
356Specifies whether the match should be done case-sensitive (0) or
357case-insensitive (1).
358.VE 8.4
359.BE
360
361.SH DESCRIPTION
362.PP
363These routines convert between UTF-8 strings and Tcl_UniChars. A
364Tcl_UniChar is a Unicode character represented as an unsigned, fixed-size
365quantity. A UTF-8 character is a Unicode character represented as
366a varying-length sequence of up to TCL_UTF_MAX bytes. A multibyte UTF-8
367sequence consists of a lead byte followed by some number of trail bytes.
368.PP
369\fBTCL_UTF_MAX\fR is the maximum number of bytes that it takes to
370represent one Unicode character in the UTF-8 representation.
371.PP
372\fBTcl_UniCharToUtf\fR stores the Tcl_UniChar \fIch\fR as a UTF-8 string
373in starting at \fIbuf\fR. The return value is the number of bytes stored
374in \fIbuf\fR.
375.PP
376\fBTcl_UtfToUniChar\fR reads one UTF-8 character starting at \fIsrc\fR
377and stores it as a Tcl_UniChar in \fI*chPtr\fR. The return value is the
378number of bytes read from \fIsrc\fR.. The caller must ensure that the
379source buffer is long enough such that this routine does not run off the
380end and dereference non-existent or random memory; if the source buffer
381is known to be null-terminated, this will not happen. If the input is
382not in proper UTF-8 format, \fBTcl_UtfToUniChar\fR will store the first
383byte of \fIsrc\fR in \fI*chPtr\fR as a Tcl_UniChar between 0x0000 and
3840x00ff and return 1.
385.PP
386\fBTcl_UniCharToUtfDString\fR converts the given Unicode string
387to UTF-8, storing the result in a previously-initialized \fBTcl_DString\fR.
388You must specify the length of the given Unicode string.
389The return value is a pointer to the UTF-8 representation of the
390Unicode string. Storage for the return value is appended to the
391end of the \fBTcl_DString\fR.
392.PP
393\fBTcl_UtfToUniCharDString\fR converts the given UTF-8 string to Unicode,
394storing the result in the previously-initialized \fBTcl_DString\fR.
395you may either specify the length of the given UTF-8 string or "-1",
396in which case \fBTcl_UtfToUniCharDString\fR uses \fBstrlen\fR to
397calculate the length. The return value is a pointer to the Unicode
398representation of the UTF-8 string. Storage for the return value
399is appended to the end of the \fBTcl_DString\fR. The Unicode string
400is terminated with a Unicode null character.
401.PP
402\fBTcl_UniCharLen\fR corresponds to \fBstrlen\fR for Unicode
403characters. It accepts a null-terminated Unicode string and returns
404the number of Unicode characters (not bytes) in that string.
405.PP
406\fBTcl_UniCharNcmp\fR and \fBTcl_UniCharNcasecmp\fR correspond to
407\fBstrncmp\fR and \fBstrncasecmp\fR, respectively, for Unicode characters.
408They accepts two null-terminated Unicode strings and the number of characters
409to compare. Both strings are assumed to be at least \fIlen\fR characters
410long. \fBTcl_UniCharNcmp\fR compares the two strings character-by-character
411according to the Unicode character ordering. It returns an integer greater
412than, equal to, or less than 0 if the first string is greater than, equal
413to, or less than the second string respectively. \fBTcl_UniCharNcasecmp\fR
414is the Unicode case insensitive version.
415.PP
416.VS 8.4
417\fBTcl_UniCharCaseMatch\fR is the Unicode equivalent to
418\fBTcl_StringCaseMatch\fR. It accepts a null-terminated Unicode string,
419a Unicode pattern, and a boolean value specifying whether the match should
420be case sensitive and returns whether the string matches the pattern.
421.VE 8.4
422.PP
423\fBTcl_UtfNcmp\fR corresponds to \fBstrncmp\fR for UTF-8 strings. It
424accepts two null-terminated UTF-8 strings and the number of characters
425to compare. (Both strings are assumed to be at least \fIlen\fR
426characters long.) \fBTcl_UtfNcmp\fR compares the two strings
427character-by-character according to the Unicode character ordering.
428It returns an integer greater than, equal to, or less than 0 if the
429first string is greater than, equal to, or less than the second string
430respectively.
431.PP
432\fBTcl_UtfNcasecmp\fR corresponds to \fBstrncasecmp\fR for UTF-8
433strings. It is similar to \fBTcl_UtfNcmp\fR except comparisons ignore
434differences in case when comparing upper, lower or title case
435characters.
436.PP
437\fBTcl_UtfCharComplete\fR returns 1 if the source UTF-8 string \fIsrc\fR
438of length \fIlen\fR bytes is long enough to be decoded by
439\fBTcl_UtfToUniChar\fR, or 0 otherwise. This function does not guarantee
440that the UTF-8 string is properly formed. This routine is used by
441procedures that are operating on a byte at a time and need to know if a
442full Tcl_UniChar has been seen.
443.PP
444\fBTcl_NumUtfChars\fR corresponds to \fBstrlen\fR for UTF-8 strings. It
445returns the number of Tcl_UniChars that are represented by the UTF-8 string
446\fIsrc\fR. The length of the source string is \fIlen\fR bytes. If the
447length is negative, all bytes up to the first null byte are used.
448.PP
449\fBTcl_UtfFindFirst\fR corresponds to \fBstrchr\fR for UTF-8 strings. It
450returns a pointer to the first occurrence of the Tcl_UniChar \fIch\fR
451in the null-terminated UTF-8 string \fIsrc\fR. The null terminator is
452considered part of the UTF-8 string.
453.PP
454\fBTcl_UtfFindLast\fR corresponds to \fBstrrchr\fR for UTF-8 strings. It
455returns a pointer to the last occurrence of the Tcl_UniChar \fIch\fR
456in the null-terminated UTF-8 string \fIsrc\fR. The null terminator is
457considered part of the UTF-8 string.
458.PP
459Given \fIsrc\fR, a pointer to some location in a UTF-8 string,
460\fBTcl_UtfNext\fR returns a pointer to the next UTF-8 character in the
461string. The caller must not ask for the next character after the last
462character in the string if the string is not terminated by a null
463character.
464.PP
465Given \fIsrc\fR, a pointer to some location in a UTF-8 string (or to a
466null byte immediately following such a string), \fBTcl_UtfPrev\fR
467returns a pointer to the closest preceding byte that starts a UTF-8
468character.
469This function will not back up to a position before \fIstart\fR,
470the start of the UTF-8 string. If \fIsrc\fR was already at \fIstart\fR, the
471return value will be \fIstart\fR.
472.PP
473\fBTcl_UniCharAtIndex\fR corresponds to a C string array dereference or the
474Pascal Ord() function. It returns the Tcl_UniChar represented at the
475specified character (not byte) \fIindex\fR in the UTF-8 string
476\fIsrc\fR. The source string must contain at least \fIindex\fR
477characters. Behavior is undefined if a negative \fIindex\fR is given.
478.PP
479\fBTcl_UtfAtIndex\fR returns a pointer to the specified character (not
480byte) \fIindex\fR in the UTF-8 string \fIsrc\fR. The source string must
481contain at least \fIindex\fR characters. This is equivalent to calling
482\fBTcl_UtfNext\fR \fIindex\fR times. If a negative \fIindex\fR is given,
483the return pointer points to the first character in the source string.
484.PP
485\fBTcl_UtfBackslash\fR is a utility procedure used by several of the Tcl
486commands. It parses a backslash sequence and stores the properly formed
487UTF-8 character represented by the backslash sequence in the output
488buffer \fIdst\fR. At most TCL_UTF_MAX bytes are stored in the buffer.
489\fBTcl_UtfBackslash\fR modifies \fI*readPtr\fR to contain the number
490of bytes in the backslash sequence, including the backslash character.
491The return value is the number of bytes stored in the output buffer.
492.PP
493See the \fBTcl\fR manual entry for information on the valid backslash
494sequences. All of the sequences described in the Tcl manual entry are
495supported by \fBTcl_UtfBackslash\fR.
496
497.SH KEYWORDS
498utf, unicode, backslash