blob: 86e4ab7b62cf2a0ce6bbb014220877baa987dd2e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
/*
* Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#include "config.h"
#include "KURL.h"
#include "NotImplemented.h"
#include "TextEncoding.h"
#include "qurl.h"
#include <wtf/text/CString.h>
namespace WebCore {
KURL::KURL(const QUrl& url)
{
*this = KURL(KURL(), url.toEncoded().constData(), UTF8Encoding());
}
KURL::operator QUrl() const
{
#if !HAVE(QT5)
QString str = QString::fromRawData(reinterpret_cast<const QChar*>(m_string.characters()), m_string.length());
QByteArray ba = str.toUtf8();
QUrl url = QUrl::fromEncoded(ba);
return url;
#else
return QUrl(m_string);
#endif
}
String KURL::fileSystemPath() const
{
if (!isValid())
return String();
if (isLocalFile())
return static_cast<QUrl>(*this).toLocalFile();
// A valid qrc resource path begins with a colon.
if (protocolIs("qrc"))
return ":" + decodeURLEscapeSequences(path());
return String();
}
}
|