Fix QUrl::toString(StripTrailingSlash) to not turn file:/// into file:
It should only strip one slash (as the name indicates), and not if the path is just "/". Change-Id: I133a81977241de77a49d1d1559143d30e0bd52f8 Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
This commit is contained in:
parent
5190beae81
commit
7c717e56f5
@ -2159,7 +2159,7 @@ QString QUrl::toString(FormattingOptions options) const
|
|||||||
|
|
||||||
d->appendPath(url, options, QUrlPrivate::FullUrl);
|
d->appendPath(url, options, QUrlPrivate::FullUrl);
|
||||||
// check if we need to remove trailing slashes
|
// check if we need to remove trailing slashes
|
||||||
while ((options & StripTrailingSlash) && url.endsWith(QLatin1Char('/')))
|
if ((options & StripTrailingSlash) && d->path != QLatin1String("/") && url.endsWith(QLatin1Char('/')))
|
||||||
url.chop(1);
|
url.chop(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,6 +140,7 @@ private slots:
|
|||||||
void setEncodedFragment_data();
|
void setEncodedFragment_data();
|
||||||
void setEncodedFragment();
|
void setEncodedFragment();
|
||||||
void fromEncoded();
|
void fromEncoded();
|
||||||
|
void stripTrailingSlash_data();
|
||||||
void stripTrailingSlash();
|
void stripTrailingSlash();
|
||||||
void hosts_data();
|
void hosts_data();
|
||||||
void hosts();
|
void hosts();
|
||||||
@ -2246,18 +2247,25 @@ void tst_QUrl::fromEncoded()
|
|||||||
QCOMPARE(qurl_newline_1.toEncoded().constData(), "http://www.foo.bar/foo/bar%0Agnork");
|
QCOMPARE(qurl_newline_1.toEncoded().constData(), "http://www.foo.bar/foo/bar%0Agnork");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void tst_QUrl::stripTrailingSlash_data()
|
||||||
|
{
|
||||||
|
QTest::addColumn<QString>("url");
|
||||||
|
QTest::addColumn<QString>("expected");
|
||||||
|
|
||||||
|
QTest::newRow("ftp no slash") << "ftp://ftp.de.kde.org/dir" << "ftp://ftp.de.kde.org/dir";
|
||||||
|
QTest::newRow("ftp slash") << "ftp://ftp.de.kde.org/dir/" << "ftp://ftp.de.kde.org/dir";
|
||||||
|
QTest::newRow("file slash") << "file:///dir/" << "file:///dir";
|
||||||
|
QTest::newRow("file no slash") << "file:///dir/" << "file:///dir";
|
||||||
|
QTest::newRow("file root") << "file:///" << "file:///";
|
||||||
|
}
|
||||||
|
|
||||||
void tst_QUrl::stripTrailingSlash()
|
void tst_QUrl::stripTrailingSlash()
|
||||||
{
|
{
|
||||||
QUrl u1( "ftp://ftp.de.kde.org/dir" );
|
QFETCH(QString, url);
|
||||||
QUrl u2( "ftp://ftp.de.kde.org/dir/" );
|
QFETCH(QString, expected);
|
||||||
QUrl::FormattingOptions options = QUrl::None;
|
|
||||||
options |= QUrl::StripTrailingSlash;
|
QUrl u(url);
|
||||||
QString str1 = u1.toString(options);
|
QCOMPARE(u.toString(QUrl::StripTrailingSlash), expected);
|
||||||
QString str2 = u2.toString(options);
|
|
||||||
QCOMPARE( str1, u1.toString() );
|
|
||||||
QCOMPARE( str2, u1.toString() );
|
|
||||||
bool same = str1 == str2;
|
|
||||||
QVERIFY( same );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void tst_QUrl::hosts_data()
|
void tst_QUrl::hosts_data()
|
||||||
|
Loading…
Reference in New Issue
Block a user