diff options
author | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-13 17:18:50 +0000 |
---|---|---|
committer | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-12-13 17:18:50 +0000 |
commit | 8a6e174c293dfcce6b1c409f5f508537eaaa7f9c (patch) | |
tree | f4014f19df5697338cf5977fd5a70ec8c2b00c0c /chrome | |
parent | dca408e49016c2bdf1fef64be587f6f2d3b81cf8 (diff) | |
download | chromium_src-8a6e174c293dfcce6b1c409f5f508537eaaa7f9c.zip chromium_src-8a6e174c293dfcce6b1c409f5f508537eaaa7f9c.tar.gz chromium_src-8a6e174c293dfcce6b1c409f5f508537eaaa7f9c.tar.bz2 |
Implement visited link coloring.
Review URL: http://codereview.chromium.org/12928
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@6970 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r-- | chrome/common/visitedlink_common.cc | 2 | ||||
-rw-r--r-- | chrome/common/visitedlink_common.h | 19 | ||||
-rw-r--r-- | chrome/renderer/renderer_glue.cc | 9 |
3 files changed, 22 insertions, 8 deletions
diff --git a/chrome/common/visitedlink_common.cc b/chrome/common/visitedlink_common.cc index 39273e0..6bda05d 100644 --- a/chrome/common/visitedlink_common.cc +++ b/chrome/common/visitedlink_common.cc @@ -29,7 +29,7 @@ bool VisitedLinkCommon::IsVisited(const char* canonical_url, NOTREACHED(); return false; } - return IsVisited(ComputeURLFingerprint(canonical_url, url_len, salt_)); + return IsVisited(ComputeURLFingerprint(canonical_url, url_len)); } bool VisitedLinkCommon::IsVisited(Fingerprint fingerprint) const { diff --git a/chrome/common/visitedlink_common.h b/chrome/common/visitedlink_common.h index 65f540b..06a4f5c 100644 --- a/chrome/common/visitedlink_common.h +++ b/chrome/common/visitedlink_common.h @@ -55,13 +55,20 @@ class VisitedLinkCommon { VisitedLinkCommon(); virtual ~VisitedLinkCommon(); - // Computes the fingerprint of the key and looks it up in the table. We - // return true if found. Does not modify the hastable. The input should be - // the canonical 16-bit URL. + // Returns the fingerprint for the given URL. + Fingerprint ComputeURLFingerprint(const char* canonical_url, + size_t url_len) const { + return ComputeURLFingerprint(canonical_url, url_len, salt_); + } + + // Looks up the given key in the table. The fingerprint for the URL is + // computed if you call one with the string argument. Returns true if found. + // Does not modify the hastable. bool IsVisited(const char* canonical_url, size_t url_len) const; bool IsVisited(const GURL& url) const { return IsVisited(url.spec().data(), url.spec().size()); } + bool IsVisited(Fingerprint fingerprint) const; #ifdef UNIT_TEST // Returns statistics about DB usage @@ -93,12 +100,10 @@ class VisitedLinkCommon { return hash_table_[table_offset]; } - // Returns true if the given fingerprint is in the table. - bool IsVisited(Fingerprint fingerprint) const; - // Computes the fingerprint of the given canonical URL. It is static so the // same algorithm can be re-used by the table rebuilder, so you will have to - // pass the salt as a parameter. + // pass the salt as a parameter. See the non-static version above if you + // want to use the current class' salt. static Fingerprint ComputeURLFingerprint(const char* canonical_url, size_t url_len, const uint8 salt[LINK_SALT_LENGTH]); diff --git a/chrome/renderer/renderer_glue.cc b/chrome/renderer/renderer_glue.cc index 35f2a73..bf325fb 100644 --- a/chrome/renderer/renderer_glue.cc +++ b/chrome/renderer/renderer_glue.cc @@ -252,6 +252,15 @@ webkit_glue::ScreenInfo webkit_glue::GetScreenInfo(gfx::NativeView window) { return results; } +uint64 webkit_glue::VisitedLinkHash(const char* canonical_url, size_t length) { + return RenderThread::current()->visited_link_slave()->ComputeURLFingerprint( + canonical_url, length); +} + +bool webkit_glue::IsLinkVisited(uint64 link_hash) { + return RenderThread::current()->visited_link_slave()->IsVisited(link_hash); +} + #ifndef USING_SIMPLE_RESOURCE_LOADER_BRIDGE // Each RenderView has a ResourceDispatcher. In unit tests, this function may |