 Chromium Code Reviews
 Chromium Code Reviews Issue 2529283002:
  Save favicon during reading list distillation  (Closed)
    
  
    Issue 2529283002:
  Save favicon during reading list distillation  (Closed) 
  | Index: ios/chrome/browser/dom_distiller/favicon_web_state_dispatcher_impl.h | 
| diff --git a/ios/chrome/browser/dom_distiller/favicon_web_state_dispatcher_impl.h b/ios/chrome/browser/dom_distiller/favicon_web_state_dispatcher_impl.h | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..ad8c4a1c1b3f1b464fb203d60d6af063e91ab827 | 
| --- /dev/null | 
| +++ b/ios/chrome/browser/dom_distiller/favicon_web_state_dispatcher_impl.h | 
| @@ -0,0 +1,45 @@ | 
| +// Copyright 2016 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 IOS_CHROME_BROWSER_DOM_DISTILLER_FAVICON_WEB_STATE_DISPATCHER_IMPL_H_ | 
| +#define IOS_CHROME_BROWSER_DOM_DISTILLER_FAVICON_WEB_STATE_DISPATCHER_IMPL_H_ | 
| + | 
| +#include <map> | 
| +#include <memory> | 
| + | 
| +#include "base/memory/weak_ptr.h" | 
| +#include "components/dom_distiller/ios/favicon_web_state_dispatcher.h" | 
| + | 
| +namespace web { | 
| +class BrowserState; | 
| +} | 
| + | 
| +namespace dom_distiller { | 
| + | 
| +// Implementation of the FaviconWebStateDispatcher. | 
| +class FaviconWebStateDispatcherImpl : public FaviconWebStateDispatcher { | 
| + public: | 
| + // Constructor with default delay for keeping the WebStates alive. | 
| + FaviconWebStateDispatcherImpl(web::BrowserState* browser_state); | 
| 
Eugene But (OOO till 7-30)
2016/12/19 17:30:06
explicit
 
gambard
2016/12/20 08:54:22
Done.
 | 
| + // Constructor for keeping the WebStates alive for |keep_alive_time|. | 
| + FaviconWebStateDispatcherImpl(web::BrowserState* browser_state, | 
| + int keep_alive_time); | 
| + ~FaviconWebStateDispatcherImpl() override; | 
| + | 
| + // FaviconWebStateDispatcher implementation. | 
| + web::WebState* RequestWebState() override; | 
| + void ReturnWebState(web::WebState* web_state) override; | 
| + | 
| + private: | 
| + web::BrowserState* browser_state_; | 
| + // Map of the WebStates currently alive. | 
| + std::map<web::WebState*, std::unique_ptr<web::WebState>> web_states_; | 
| + // Time during which the WebState will be kept alive after being returned. | 
| + int keep_alive_time_; | 
| + base::WeakPtrFactory<FaviconWebStateDispatcherImpl> weak_ptr_factory_; | 
| +}; | 
| + | 
| +} // namespace dom_distiller | 
| + | 
| +#endif // IOS_CHROME_BROWSER_DOM_DISTILLER_FAVICON_WEB_STATE_DISPATCHER_IMPL_H_ |