Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef COMPONENTS_NTP_TILES_ICON_CACHER_H_ | 5 #ifndef COMPONENTS_NTP_TILES_ICON_CACHER_H_ |
| 6 #define COMPONENTS_NTP_TILES_ICON_CACHER_H_ | 6 #define COMPONENTS_NTP_TILES_ICON_CACHER_H_ |
| 7 | 7 |
| 8 #include "base/callback.h" | 8 #include "base/callback.h" |
| 9 #include "components/ntp_tiles/popular_sites.h" | 9 #include "components/ntp_tiles/popular_sites.h" |
| 10 | 10 |
| 11 namespace ntp_tiles { | 11 namespace ntp_tiles { |
| 12 | 12 |
| 13 // Ensures that a Popular Sites icon is cached, downloading and saving it if | 13 // Ensures that a Popular Sites icon is cached, downloading and saving it if |
| 14 // not. | 14 // not. |
| 15 // | 15 // |
| 16 // Does not provide any way to get a fetched favicon; use the FaviconService for | 16 // Does not provide any way to get a fetched favicon; use the FaviconService for |
| 17 // that. All this interface guarantees is that FaviconService will be able to | 17 // that. All this interface guarantees is that FaviconService will be able to |
| 18 // get you an icon (if it exists). | 18 // get you an icon (if it exists). |
| 19 class IconCacher { | 19 class IconCacher { |
| 20 public: | 20 public: |
| 21 virtual ~IconCacher() = default; | 21 virtual ~IconCacher() = default; |
| 22 | 22 |
| 23 // Fetches the icon if necessary, then invokes |done| with true if it was | 23 // Fetches the icon if necessary. It invokes |icon_available| if an icon was |
| 24 // newly fetched (false if it was already cached or could not be fetched). | 24 // newly fetched or loaded from a default source. |
|
mastiz
2017/03/01 08:48:12
How about the failure case? I see you removed the
fhorschig
2017/03/01 20:57:35
There is exactly one caller (as the previous revie
mastiz
2017/03/02 11:05:39
I don't feel strongly but it feels wrong that an A
fhorschig
2017/03/02 11:56:24
Relatable. I will consider reintroducing it.
| |
| 25 // The callback will be invoked again if a newer icon has been fetched. | |
| 25 virtual void StartFetch(PopularSites::Site site, | 26 virtual void StartFetch(PopularSites::Site site, |
| 26 const base::Callback<void(bool)>& done) = 0; | 27 const base::Callback<void()>& icon_available) = 0; |
|
mastiz
2017/03/01 08:48:12
Having the callback called twice is not something
fhorschig
2017/03/01 20:57:35
We now have two OnceCallbacks
mastiz
2017/03/02 11:05:39
Ack, let's wait for UX feedback, since this could
fhorschig
2017/03/02 11:56:24
Acknowledged.
| |
| 27 }; | 28 }; |
| 28 | 29 |
| 29 } // namespace ntp_tiles | 30 } // namespace ntp_tiles |
| 30 | 31 |
| 31 #endif // COMPONENTS_NTP_TILES_ICON_CACHER_H_ | 32 #endif // COMPONENTS_NTP_TILES_ICON_CACHER_H_ |
| OLD | NEW |