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:
parent
3376e67abe
commit
8b5651eb41
@ -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())
|
||||||
|
@ -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())
|
||||||
|
Loading…
Reference in New Issue
Block a user