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

« back to all changes in this revision

Viewing changes to Source/WebCore/platform/chromium/LinkHashChromium.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, 2009, Google Inc. All rights reserved.
 
3
 *
 
4
 * Redistribution and use in source and binary forms, with or without
 
5
 * modification, are permitted provided that the following conditions are
 
6
 * met:
 
7
 *
 
8
 *     * Redistributions of source code must retain the above copyright
 
9
 * notice, this list of conditions and the following disclaimer.
 
10
 *     * Redistributions in binary form must reproduce the above
 
11
 * copyright notice, this list of conditions and the following disclaimer
 
12
 * in the documentation and/or other materials provided with the
 
13
 * distribution.
 
14
 *     * Neither the name of Google Inc. nor the names of its
 
15
 * contributors may be used to endorse or promote products derived from
 
16
 * this software without specific prior written permission.
 
17
 *
 
18
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 
19
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 
20
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 
21
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 
22
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 
23
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 
24
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 
25
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 
26
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 
27
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 
28
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
29
 */
 
30
 
 
31
#include "config.h"
 
32
#include "KURL.h"
 
33
#include "LinkHash.h"
 
34
 
 
35
#if USE(GOOGLEURL)
 
36
#include <googleurl/src/url_util.h>
 
37
#endif
 
38
 
 
39
#include <public/Platform.h>
 
40
 
 
41
namespace WebCore {
 
42
 
 
43
// Visited Links --------------------------------------------------------------
 
44
 
 
45
LinkHash visitedLinkHash(const UChar* url, unsigned length)
 
46
{
 
47
    url_canon::RawCanonOutput<2048> buffer;
 
48
    url_parse::Parsed parsed;
 
49
    if (!url_util::Canonicalize(url, length, 0, &buffer, &parsed))
 
50
        return 0; // Invalid URLs are unvisited.
 
51
    return WebKit::Platform::current()->visitedLinkHash(buffer.data(), buffer.length());
 
52
}
 
53
 
 
54
LinkHash visitedLinkHash(const String& url)
 
55
{
 
56
    return visitedLinkHash(url.characters(), url.length());
 
57
}
 
58
 
 
59
LinkHash visitedLinkHash(const KURL& base, const AtomicString& attributeURL)
 
60
{
 
61
    // Resolve the relative URL using googleurl and pass the absolute URL up to
 
62
    // the embedder. We could create a GURL object from the base and resolve
 
63
    // the relative URL that way, but calling the lower-level functions
 
64
    // directly saves us the string allocation in most cases.
 
65
    url_canon::RawCanonOutput<2048> buffer;
 
66
    url_parse::Parsed parsed;
 
67
 
 
68
#if USE(GOOGLEURL)
 
69
    const CString& cstr = base.utf8String();
 
70
    const char* data = cstr.data();
 
71
    int length = cstr.length();
 
72
    const url_parse::Parsed& srcParsed = base.parsed();
 
73
#else
 
74
    // When we're not using GoogleURL, first canonicalize it so we can resolve it
 
75
    // below.
 
76
    url_canon::RawCanonOutput<2048> srcCanon;
 
77
    url_parse::Parsed srcParsed;
 
78
    String str = base.string();
 
79
    if (!url_util::Canonicalize(str.characters(), str.length(), 0, &srcCanon, &srcParsed))
 
80
        return 0;
 
81
    const char* data = srcCanon.data();
 
82
    int length = srcCanon.length();
 
83
#endif
 
84
 
 
85
    if (!url_util::ResolveRelative(data, length, srcParsed, attributeURL.characters(),
 
86
                                   attributeURL.length(), 0, &buffer, &parsed))
 
87
        return 0; // Invalid resolved URL.
 
88
 
 
89
    return WebKit::Platform::current()->visitedLinkHash(buffer.data(), buffer.length());
 
90
}
 
91
 
 
92
} // namespace WebCore