]> git.ipfire.org Git - thirdparty/man-pages.git/blobdiff - man3/towupper.3
fanotify_init.2, fanotify.7: Document FAN_REPORT_TID
[thirdparty/man-pages.git] / man3 / towupper.3
index 2f571cf6936f78efb057e1e0f97248fb37ab5ef2..8624196ba93d72be1f2c1e07bd383c6cab7d3dd3 100644 (file)
-.\" Copyright (c) Bruno Haible <haible@clisp.cons.org>
+
+.\" and Copyright (C) 2014 Michael Kerrisk <mtk.manpages@gmail.com>
 .\"
+.\" %%%LICENSE_START(GPLv2+_DOC_ONEPARA)
 .\" This is free documentation; you can redistribute it and/or
 .\" modify it under the terms of the GNU General Public License as
 .\" published by the Free Software Foundation; either version 2 of
 .\" the License, or (at your option) any later version.
+.\" %%%LICENSE_END
 .\"
 .\" References consulted:
 .\"   GNU glibc-2 source code and manual
 .\"   Dinkumware C library reference http://www.dinkumware.com/
-.\"   OpenGroup's Single Unix specification http://www.UNIX-systems.org/online.html
+.\"   OpenGroup's Single UNIX specification http://www.UNIX-systems.org/online.html
 .\"   ISO/IEC 9899:1999
 .\"
-.TH TOWUPPER 3  1999-07-25 "GNU" "Linux Programmer's Manual"
+.TH TOWUPPER 3  2017-09-15 "GNU" "Linux Programmer's Manual"
 .SH NAME
-towupper \- convert a wide character to uppercase
+towupper, towupper_l \- convert a wide character to uppercase
 .SH SYNOPSIS
 .nf
 .B #include <wctype.h>
-.sp
+.PP
 .BI "wint_t towupper(wint_t " wc );
+.PP
+.BI "wint_t towupper_l(wint_t " wc ", locale_t " locale );
 .fi
+.PP
+.in -4n
+Feature Test Macro Requirements for glibc (see
+.BR feature_test_macros (7)):
+.in
+.PP
+.BR towupper_l ():
+.PD 0
+.RS 4
+.TP
+Since glibc 2.10:
+_XOPEN_SOURCE\ >=\ 700
+.TP
+Before glibc 2.10:
+_GNU_SOURCE
+.RE
+.PD
 .SH DESCRIPTION
-The \fBtowupper\fP() function is the wide-character equivalent of the
-\fBtoupper\fP(3) function.
-If \fIwc\fP is a wide character, it is converted to
-uppercase.
-Characters which do not have case are returned unchanged.
-If \fIwc\fP is WEOF, WEOF is returned.
-.SH "RETURN VALUE"
-The \fBtowupper\fP() function returns the uppercase equivalent of \fIwc\fP,
-or WEOF if \fIwc\fP is WEOF.
-.SH "CONFORMING TO"
-C99.
-.SH "SEE ALSO"
-.BR iswupper (3),
-.BR towctrans (3),
-.BR towlower (3)
+The
+.BR towupper ()
+function is the wide-character equivalent of the
+.BR toupper (3)
+function.
+If
+.I wc
+is a lowercase wide character,
+and there exists an uppercase equivalent in the current locale,
+it returns the uppercase equivalent of
+.IR wc .
+In all other cases,
+.I wc
+is returned unchanged.
+.PP
+The
+.BR towupper_l ()
+function performs the same task,
+but performs the conversion based on the character type information in
+the locale specified by
+.IR locale .
+The behavior of
+.BR towupper_l ()
+is undefined if
+.I locale
+is the special locale object
+.BR LC_GLOBAL_LOCALE
+(see
+.BR duplocale (3))
+or is not a valid locale object handle.
+.PP
+The argument
+.I wc
+must be representable as a
+.IR wchar_t
+and be a valid character in the locale or be the value
+.BR WEOF .
+.SH RETURN VALUE
+If
+.I wc
+was convertible to uppercase,
+.BR towupper ()
+returns its uppercase equivalent;
+otherwise it returns
+.IR wc .
+.SH VERSIONS
+The
+.BR towupper_l ()
+function first appeared in glibc 2.3.
+.SH ATTRIBUTES
+For an explanation of the terms used in this section, see
+.BR attributes (7).
+.TS
+allbox;
+lb lb lb
+l l l.
+Interface      Attribute       Value
+T{
+.BR towupper ()
+T}     Thread safety   MT-Safe locale
+T{
+.BR towupper_l ()
+T}     Thread safety   MT-Safe
+.TE
+.SH CONFORMING TO
+.BR towupper ():
+C99, POSIX.1-2001 (XSI);
+present as an XSI extension in POSIX.1-2008, but marked obsolete.
+.PP
+.BR towupper_l ():
+POSIX.1-2008.
 .SH NOTES
-The behaviour of \fBtowupper\fP() depends on the LC_CTYPE category of the
-current locale.
+The behavior of these functions depends on the
+.B LC_CTYPE
+category of the locale.
 .PP
-This function is not very appropriate for dealing with Unicode characters,
+These functions are not very appropriate for dealing with Unicode characters,
 because Unicode knows about three cases: upper, lower and title case.
+.SH SEE ALSO
+.BR iswupper (3),
+.BR towctrans (3),
+.BR towlower (3),
+.BR locale (7)