summaryrefslogtreecommitdiffstats
path: root/src/corelib
diff options
context:
space:
mode:
authorOswald Buddenhagen <oswald.buddenhagen@nokia.com>2010-12-16 16:44:01 (GMT)
committerOswald Buddenhagen <oswald.buddenhagen@nokia.com>2010-12-17 17:11:03 (GMT)
commit468328468904d116a5ff70fd4c71c34e453e8593 (patch)
tree5932d1a2f30504c0565e7df73abe9ecd6b874492 /src/corelib
parent86246bfe354aaf03065cd78d7d5410e5097ada48 (diff)
downloadQt-468328468904d116a5ff70fd4c71c34e453e8593.zip
Qt-468328468904d116a5ff70fd4c71c34e453e8593.tar.gz
Qt-468328468904d116a5ff70fd4c71c34e453e8593.tar.bz2
optimize writing string constants and byte arrays
don't throw away the already known length just to call strlen() on it over and over again. Reviewed-by: denis
Diffstat (limited to 'src/corelib')
-rw-r--r--src/corelib/xml/qxmlstream.cpp22
1 files changed, 12 insertions, 10 deletions
diff --git a/src/corelib/xml/qxmlstream.cpp b/src/corelib/xml/qxmlstream.cpp
index b29bd92..3d8af9b 100644
--- a/src/corelib/xml/qxmlstream.cpp
+++ b/src/corelib/xml/qxmlstream.cpp
@@ -2965,7 +2965,8 @@ public:
void write(const QStringRef &);
void write(const QString &);
void writeEscaped(const QString &, bool escapeWhitespace = false);
- void write(const char *s);
+ void write(const char *s, int len);
+ template <int N> void write(const char (&s)[N]) { write(s, N - 1); }
bool finishStartElement(bool contents = true);
void writeStartElement(const QString &namespaceUri, const QString &name);
QIODevice *device;
@@ -3074,12 +3075,12 @@ void QXmlStreamWriterPrivate::writeEscaped(const QString &s, bool escapeWhitespa
}
// ASCII only!
-void QXmlStreamWriterPrivate::write(const char *s)
+void QXmlStreamWriterPrivate::write(const char *s, int len)
{
if (device) {
- device->write(s, strlen(s));
+ device->write(s, len);
} else if (stringDevice) {
- stringDevice->append(QLatin1String(s));
+ stringDevice->append(QString::fromLatin1(s, len));
} else
qWarning("QXmlStreamWriter: No device");
}
@@ -3157,7 +3158,7 @@ void QXmlStreamWriterPrivate::indent(int level)
{
write("\n");
for (int i = level; i > 0; --i)
- write(autoFormattingIndent.constData());
+ write(autoFormattingIndent.constData(), autoFormattingIndent.length());
}
@@ -3744,7 +3745,7 @@ void QXmlStreamWriter::writeStartDocument(const QString &version)
#ifdef QT_NO_TEXTCODEC
d->write("iso-8859-1");
#else
- d->write(d->codec->name().constData());
+ d->write(d->codec->name().constData(), d->codec->name().length());
#endif
}
d->write("\"?>");
@@ -3767,12 +3768,13 @@ void QXmlStreamWriter::writeStartDocument(const QString &version, bool standalon
#ifdef QT_NO_TEXTCODEC
d->write("iso-8859-1");
#else
- d->write(d->codec->name().constData());
+ d->write(d->codec->name().constData(), d->codec->name().length());
#endif
}
- d->write("\" standalone=\"");
- d->write(standalone ? "yes" : "no");
- d->write("\"?>");
+ if (standalone)
+ d->write("\" standalone=\"yes\"?>");
+ else
+ d->write("\" standalone=\"no\"?>");
}