| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "chrome/browser/dom_distiller/lazy_dom_distiller_service.h" | 5 #include "chrome/browser/dom_distiller/lazy_dom_distiller_service.h" |
| 6 | 6 |
| 7 #include "chrome/browser/chrome_notification_types.h" | 7 #include "chrome/browser/chrome_notification_types.h" |
| 8 #include "chrome/browser/dom_distiller/dom_distiller_service_factory.h" | 8 #include "chrome/browser/dom_distiller/dom_distiller_service_factory.h" |
| 9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
| 10 #include "components/dom_distiller/core/dom_distiller_service.h" | 10 #include "components/dom_distiller/core/dom_distiller_service.h" |
| 11 #include "content/public/browser/notification_source.h" | 11 #include "content/public/browser/notification_source.h" |
| 12 | 12 |
| 13 namespace dom_distiller { | 13 namespace dom_distiller { |
| 14 | 14 |
| 15 LazyDomDistillerService::LazyDomDistillerService( | 15 LazyDomDistillerService::LazyDomDistillerService( |
| 16 Profile* profile, | 16 Profile* profile, |
| 17 const DomDistillerServiceFactory* service_factory) | 17 const DomDistillerServiceFactory* service_factory) |
| 18 : profile_(profile), service_factory_(service_factory) { | 18 : profile_(profile), service_factory_(service_factory) { |
| 19 registrar_.Add(this, | 19 registrar_.Add(this, |
| 20 chrome::NOTIFICATION_PROFILE_DESTROYED, | 20 chrome::NOTIFICATION_PROFILE_DESTROYED, |
| 21 content::Source<Profile>(profile)); | 21 content::Source<Profile>(profile)); |
| 22 } | 22 } |
| 23 | 23 |
| 24 LazyDomDistillerService::~LazyDomDistillerService() {} | 24 LazyDomDistillerService::~LazyDomDistillerService() { |
| 25 } |
| 25 | 26 |
| 26 // This will create an object and schedule work the first time it's called | 27 // This will create an object and schedule work the first time it's called |
| 27 // and just return an existing object after that. | 28 // and just return an existing object after that. |
| 28 DomDistillerServiceInterface* LazyDomDistillerService::instance() const { | 29 DomDistillerServiceInterface* LazyDomDistillerService::instance() const { |
| 29 return service_factory_->GetForBrowserContext(profile_); | 30 return service_factory_->GetForBrowserContext(profile_); |
| 30 } | 31 } |
| 31 | 32 |
| 32 void LazyDomDistillerService::Observe( | 33 void LazyDomDistillerService::Observe( |
| 33 int type, | 34 int type, |
| 34 const content::NotificationSource& source, | 35 const content::NotificationSource& source, |
| 35 const content::NotificationDetails& details) { | 36 const content::NotificationDetails& details) { |
| 36 DCHECK_EQ(chrome::NOTIFICATION_PROFILE_DESTROYED, type); | 37 DCHECK_EQ(chrome::NOTIFICATION_PROFILE_DESTROYED, type); |
| 37 DCHECK_EQ(profile_, content::Source<Profile>(source).ptr()); | 38 DCHECK_EQ(profile_, content::Source<Profile>(source).ptr()); |
| 38 delete this; | 39 delete this; |
| 39 } | 40 } |
| 40 | 41 |
| 41 syncer::SyncableService* LazyDomDistillerService::GetSyncableService() const { | 42 syncer::SyncableService* LazyDomDistillerService::GetSyncableService() const { |
| 42 return instance()->GetSyncableService(); | 43 return instance()->GetSyncableService(); |
| 43 } | 44 } |
| 44 | 45 |
| 45 const std::string LazyDomDistillerService::AddToList( | 46 const std::string LazyDomDistillerService::AddToList( |
| 46 const GURL& url, | 47 const GURL& url, |
| 48 scoped_ptr<DistillerPage> distiller_page, |
| 47 const ArticleAvailableCallback& article_cb) { | 49 const ArticleAvailableCallback& article_cb) { |
| 48 return instance()->AddToList(url, article_cb); | 50 return instance()->AddToList(url, distiller_page.Pass(), article_cb); |
| 49 } | 51 } |
| 50 | 52 |
| 51 std::vector<ArticleEntry> LazyDomDistillerService::GetEntries() const { | 53 std::vector<ArticleEntry> LazyDomDistillerService::GetEntries() const { |
| 52 return instance()->GetEntries(); | 54 return instance()->GetEntries(); |
| 53 } | 55 } |
| 54 | 56 |
| 55 scoped_ptr<ArticleEntry> LazyDomDistillerService::RemoveEntry( | 57 scoped_ptr<ArticleEntry> LazyDomDistillerService::RemoveEntry( |
| 56 const std::string& entry_id) { | 58 const std::string& entry_id) { |
| 57 return instance()->RemoveEntry(entry_id); | 59 return instance()->RemoveEntry(entry_id); |
| 58 } | 60 } |
| 59 | 61 |
| 60 scoped_ptr<ViewerHandle> LazyDomDistillerService::ViewEntry( | 62 scoped_ptr<ViewerHandle> LazyDomDistillerService::ViewEntry( |
| 61 ViewRequestDelegate* delegate, | 63 ViewRequestDelegate* delegate, |
| 64 scoped_ptr<DistillerPage> distiller_page, |
| 62 const std::string& entry_id) { | 65 const std::string& entry_id) { |
| 63 return instance()->ViewEntry(delegate, entry_id); | 66 return instance()->ViewEntry(delegate, distiller_page.Pass(), entry_id); |
| 64 } | 67 } |
| 65 | 68 |
| 66 scoped_ptr<ViewerHandle> LazyDomDistillerService::ViewUrl( | 69 scoped_ptr<ViewerHandle> LazyDomDistillerService::ViewUrl( |
| 67 ViewRequestDelegate* delegate, | 70 ViewRequestDelegate* delegate, |
| 71 scoped_ptr<DistillerPage> distiller_page, |
| 68 const GURL& url) { | 72 const GURL& url) { |
| 69 return instance()->ViewUrl(delegate, url); | 73 return instance()->ViewUrl(delegate, distiller_page.Pass(), url); |
| 74 } |
| 75 |
| 76 scoped_ptr<DistillerPage> |
| 77 LazyDomDistillerService::CreateDefaultDistillerPage() { |
| 78 return instance()->CreateDefaultDistillerPage(); |
| 70 } | 79 } |
| 71 | 80 |
| 72 void LazyDomDistillerService::AddObserver(DomDistillerObserver* observer) { | 81 void LazyDomDistillerService::AddObserver(DomDistillerObserver* observer) { |
| 73 instance()->AddObserver(observer); | 82 instance()->AddObserver(observer); |
| 74 } | 83 } |
| 75 | 84 |
| 76 void LazyDomDistillerService::RemoveObserver(DomDistillerObserver* observer) { | 85 void LazyDomDistillerService::RemoveObserver(DomDistillerObserver* observer) { |
| 77 instance()->RemoveObserver(observer); | 86 instance()->RemoveObserver(observer); |
| 78 } | 87 } |
| 79 | 88 |
| 80 } // namespace dom_distiller | 89 } // namespace dom_distiller |
| OLD | NEW |