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:
Kai Koehne 2014-09-30 09:52:51 +02:00 committed by Oswald Buddenhagen
parent b7d36614e9
commit 54d4fb4f50
2 changed files with 11 additions and 22 deletions

View File

@ -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;

View File

@ -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