QtNetwork: don't use Boyer-Moore for single-character needles

Using Boyer-Moore for single-character search strings makes
no sense since there can be no skipping beyond the normal
sequential search anyway.

So, port to QByteArray::indexOf(char).

Change-Id: I848e2ceea5ceafd0ebae402798b410f682348a75
Reviewed-by: Richard J. Moore <rich@kde.org>
This commit is contained in:
Marc Mutz 2016-02-24 18:38:17 +01:00
parent 3376e67abe
commit 8b5651eb41
2 changed files with 4 additions and 11 deletions

View File

@ -40,8 +40,6 @@
#include "qhttpnetworkreply_p.h" #include "qhttpnetworkreply_p.h"
#include "qhttpnetworkconnection_p.h" #include "qhttpnetworkconnection_p.h"
#include <qbytearraymatcher.h>
#ifndef QT_NO_HTTP #ifndef QT_NO_HTTP
#ifndef QT_NO_SSL #ifndef QT_NO_SSL
@ -611,11 +609,9 @@ void QHttpNetworkReplyPrivate::parseHeader(const QByteArray &header)
{ {
// see rfc2616, sec 4 for information about HTTP/1.1 headers. // see rfc2616, sec 4 for information about HTTP/1.1 headers.
// allows relaxed parsing here, accepts both CRLF & LF line endings // allows relaxed parsing here, accepts both CRLF & LF line endings
const QByteArrayMatcher lf("\n");
const QByteArrayMatcher colon(":");
int i = 0; int i = 0;
while (i < header.count()) { while (i < header.count()) {
int j = colon.indexIn(header, i); // field-name int j = header.indexOf(':', i); // field-name
if (j == -1) if (j == -1)
break; break;
const QByteArray field = header.mid(i, j - i).trimmed(); const QByteArray field = header.mid(i, j - i).trimmed();
@ -623,7 +619,7 @@ void QHttpNetworkReplyPrivate::parseHeader(const QByteArray &header)
// any number of LWS is allowed before and after the value // any number of LWS is allowed before and after the value
QByteArray value; QByteArray value;
do { do {
i = lf.indexIn(header, j); i = header.indexOf('\n', j);
if (i == -1) if (i == -1)
break; break;
if (!value.isEmpty()) if (!value.isEmpty())

View File

@ -61,7 +61,6 @@
#include <QtCore/qatomic.h> #include <QtCore/qatomic.h>
#include <QtCore/qbytearray.h> #include <QtCore/qbytearray.h>
#include <QtCore/qbytearraymatcher.h>
#include <QtCore/qiodevice.h> #include <QtCore/qiodevice.h>
#ifndef QT_NO_DEBUG_STREAM #ifndef QT_NO_DEBUG_STREAM
#include <QtCore/qdebug.h> #include <QtCore/qdebug.h>
@ -191,11 +190,9 @@ QByteArray QSslKeyPrivate::derFromPem(const QByteArray &pem, QMap<QByteArray, QB
if (der.contains("Proc-Type:")) { if (der.contains("Proc-Type:")) {
// taken from QHttpNetworkReplyPrivate::parseHeader // taken from QHttpNetworkReplyPrivate::parseHeader
const QByteArrayMatcher lf("\n");
const QByteArrayMatcher colon(":");
int i = 0; int i = 0;
while (i < der.count()) { while (i < der.count()) {
int j = colon.indexIn(der, i); // field-name int j = der.indexOf(':', i); // field-name
if (j == -1) if (j == -1)
break; break;
const QByteArray field = der.mid(i, j - i).trimmed(); const QByteArray field = der.mid(i, j - i).trimmed();
@ -203,7 +200,7 @@ QByteArray QSslKeyPrivate::derFromPem(const QByteArray &pem, QMap<QByteArray, QB
// any number of LWS is allowed before and after the value // any number of LWS is allowed before and after the value
QByteArray value; QByteArray value;
do { do {
i = lf.indexIn(der, j); i = der.indexOf('\n', j);
if (i == -1) if (i == -1)
break; break;
if (!value.isEmpty()) if (!value.isEmpty())