Fix QString::sprintf documentation
QString::sprintf does actually support all length modifiers, including %lld. The format string is also parsed as UTF-8. What's worthwile to mention, though, is that %lc and %ls is at odds with the standard, since wchar_t isn't necessarily 16 bits wide. Change-Id: I30cd22ec5b42035824dd98e3cdcc79d7adcc953a Reviewed-by: Olivier Goffart <ogoffart@woboq.com> Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
b7d36614e9
commit
54d4fb4f50
@ -760,14 +760,6 @@ void Widget::splitCaseSensitiveFunction()
|
|||||||
|
|
||||||
void Widget::sprintfFunction()
|
void Widget::sprintfFunction()
|
||||||
{
|
{
|
||||||
//! [63]
|
|
||||||
size_t BufSize;
|
|
||||||
char buf[BufSize];
|
|
||||||
|
|
||||||
::snprintf(buf, BufSize, "%lld", 123456789LL);
|
|
||||||
QString str = QString::fromUtf8(buf);
|
|
||||||
//! [63]
|
|
||||||
|
|
||||||
//! [64]
|
//! [64]
|
||||||
QString result;
|
QString result;
|
||||||
QTextStream(&result) << "pi = " << 3.14;
|
QTextStream(&result) << "pi = " << 3.14;
|
||||||
|
@ -5692,21 +5692,18 @@ QString QString::toUpper() const
|
|||||||
Safely builds a formatted string from the format string \a cformat
|
Safely builds a formatted string from the format string \a cformat
|
||||||
and an arbitrary list of arguments.
|
and an arbitrary list of arguments.
|
||||||
|
|
||||||
The %lc escape sequence expects a unicode character of type ushort
|
The format string supports the conversion specifiers, length modifiers,
|
||||||
(as returned by QChar::unicode()). The %ls escape sequence expects
|
and flags provided by printf() in the standard C++ library. The \a cformat
|
||||||
a pointer to a zero-terminated array of unicode characters of type
|
string and \c{%s} arguments must be UTF-8 encoded.
|
||||||
ushort (as returned by QString::utf16()).
|
|
||||||
|
|
||||||
\note This function expects a UTF-8 string for %s and Latin-1 for
|
\note The \c{%lc} escape sequence expects a unicode character of type
|
||||||
the format string.
|
\c char16_t, or \c ushort (as returned by QChar::unicode()).
|
||||||
|
The \c{%ls} escape sequence expects a pointer to a zero-terminated array
|
||||||
The format string supports most of the conversion specifiers
|
of unicode characters of type \c char16_t, or ushort (as returned by
|
||||||
provided by printf() in the standard C++ library. It doesn't
|
QString::utf16()). This is at odds with the printf() in the standard C++
|
||||||
honor the length modifiers (e.g. \c h for \c short, \c ll for
|
library, which defines \c {%lc} to print a wchar_t and \c{%ls} to print
|
||||||
\c{long long}). If you need those, use the standard snprintf()
|
a \c{wchar_t*}, and might also produce compiler warnings on platforms
|
||||||
function instead:
|
where the size of \c {wchar_t} is not 16 bits.
|
||||||
|
|
||||||
\snippet qstring/main.cpp 63
|
|
||||||
|
|
||||||
\warning We do not recommend using QString::sprintf() in new Qt
|
\warning We do not recommend using QString::sprintf() in new Qt
|
||||||
code. Instead, consider using QTextStream or arg(), both of
|
code. Instead, consider using QTextStream or arg(), both of
|
||||||
|
Loading…
Reference in New Issue
Block a user