~ubuntu-branches/ubuntu/raring/qtwebkit-source/raring-proposed

« back to all changes in this revision

Viewing changes to Source/WebCore/platform/qt/KURLQt.cpp

  • Committer: Package Import Robot
  • Author(s): Jonathan Riddell
  • Date: 2013-02-18 14:24:18 UTC
  • Revision ID: package-import@ubuntu.com-20130218142418-eon0jmjg3nj438uy
Tags: upstream-2.3
ImportĀ upstreamĀ versionĀ 2.3

Show diffs side-by-side

added added

removed removed

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