Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(473)

Unified Diff: components/bookmarks_enhanced/image_store.h

Issue 259863007: Local salient image storage for enhanced bookmark experiment. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: removed unneeded header include Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/bookmarks_enhanced/image_store.h
diff --git a/components/bookmarks_enhanced/image_store.h b/components/bookmarks_enhanced/image_store.h
new file mode 100644
index 0000000000000000000000000000000000000000..ed12f97b06f09d72624284185f4aaee66f6edcdb
--- /dev/null
+++ b/components/bookmarks_enhanced/image_store.h
@@ -0,0 +1,65 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef COMPONENTS_BOOKMARKS_ENHANCED_IMAGE_STORE_H_
+#define COMPONENTS_BOOKMARKS_ENHANCED_IMAGE_STORE_H_
+
+#include <map>
+#include <set>
+
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+#include "base/threading/thread_checker.h"
+#include "ui/gfx/image/image.h"
+
+class GURL;
+
+// The ImageStore keeps an image for each URL. This class is not thread safe,
+// and will check the thread using base::ThreadChecker, except the constructor.
+class ImageStore : public base::RefCounted<ImageStore> {
+ public:
+ ImageStore();
+
+ // Returns true if there is an image for this url.
+ virtual bool HasKey(const GURL& page_url) = 0;
+
+ // Inserts an image and its url in the store for the the given page url. The
+ // image can be null indicating that the download of the image at this URL or
+ // encoding for insertion failed previously. On non-ios platforms, |image|
+ // must have exactly one representation with a scale factor of 1.
+ virtual void Insert(const GURL& page_url,
+ const GURL& image_url,
+ const gfx::Image& image) = 0;
+
+ // Removes an image from the store.
+ virtual void Erase(const GURL& page_url) = 0;
+
+ // Returns the image associated with this url. Returns nil if there are no
sky 2014/05/08 15:33:08 nil->empty image? empty url?
Kibeom Kim (inactive) 2014/05/08 17:56:33 Done.
+ // image for this url. It also returns the image_url where the image was
+ // downloaded from or failed to be downloaded from.
+ virtual std::pair<gfx::Image, GURL> Get(const GURL& page_url) = 0;
+
+ // Returns the size of the image stored for this URL or empty size if no
+ // images are present.
+ virtual gfx::Size GetSize(const GURL& page_url) = 0;
+
+ // Populates |urls| with all the urls that have an image in the store.
+ virtual void GetAllPageUrls(std::set<GURL>* urls) = 0;
+
+ // Moves an image from one url to another.
+ void ChangeImageURL(const GURL& from, const GURL& to);
+
+ // Removes all images.
+ void ClearAll();
sky 2014/05/08 15:33:08 I think this should remain pure virtual. In partic
Kibeom Kim (inactive) 2014/05/08 17:56:33 Done. (Also added ClearAll unittest)
+
+ protected:
+ virtual ~ImageStore();
+
+ base::ThreadChecker thread_checker_;
+
+ private:
+ friend class base::RefCounted<ImageStore>;
+};
+
+#endif // COMPONENTS_BOOKMARKS_ENHANCED_IMAGE_STORE_H_

Powered by Google App Engine
This is Rietveld 408576698