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

Unified Diff: chrome/browser/android/offline_pages/offline_page_bookmark_observer.h

Issue 2185973003: [Offline Pages] Delete associated page along with bookmark. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixing conflicts. Created 4 years, 3 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
« no previous file with comments | « chrome/browser/BUILD.gn ('k') | chrome/browser/android/offline_pages/offline_page_bookmark_observer.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/android/offline_pages/offline_page_bookmark_observer.h
diff --git a/chrome/browser/android/offline_pages/offline_page_bookmark_observer.h b/chrome/browser/android/offline_pages/offline_page_bookmark_observer.h
new file mode 100644
index 0000000000000000000000000000000000000000..e5f859568da4538a7b8b5d7fcb96c60559c44f7d
--- /dev/null
+++ b/chrome/browser/android/offline_pages/offline_page_bookmark_observer.h
@@ -0,0 +1,55 @@
+// 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 CHROME_BROWSER_ANDROID_OFFLINE_PAGES_OFFLINE_PAGE_BOOKMARK_OBSERVER_H_
+#define CHROME_BROWSER_ANDROID_OFFLINE_PAGES_OFFLINE_PAGE_BOOKMARK_OBSERVER_H_
+
+#include "base/memory/weak_ptr.h"
+#include "chrome/browser/android/offline_pages/offline_page_model_factory.h"
+#include "components/bookmarks/browser/base_bookmark_model_observer.h"
+#include "components/offline_pages/offline_page_types.h"
+
+class GURL;
+
+namespace bookmarks {
+class BookmarkModel;
+class BookmarkNode;
+}
+
+namespace content {
+class BrowserContext;
+}
+
+namespace offline_pages {
+
+class OfflinePageBookmarkObserver
+ : public bookmarks::BaseBookmarkModelObserver {
+ public:
+ explicit OfflinePageBookmarkObserver(content::BrowserContext* context);
+ ~OfflinePageBookmarkObserver() override;
+
+ // Implement bookmarks::OfflinePageBookmarkObserver
+ void BookmarkModelChanged() override;
+ void BookmarkNodeRemoved(bookmarks::BookmarkModel* model,
+ const bookmarks::BookmarkNode* parent,
+ int old_index,
+ const bookmarks::BookmarkNode* node,
+ const std::set<GURL>& removed_urls) override;
+
+ private:
+ // Does work for actual expiring.
+ void DoExpireRemovedBookmarkPages(const MultipleOfflineIdResult& offline_ids);
+
+ // Callback for expiring removed bookmark pages.
+ void OnExpireRemovedBookmarkPagesDone(bool result);
+
+ content::BrowserContext* context_;
+
+ OfflinePageModel* offline_page_model_;
+
+ base::WeakPtrFactory<OfflinePageBookmarkObserver> weak_ptr_factory_;
+};
+} // namespace offline_pages
+
+#endif // CHROME_BROWSER_ANDROID_OFFLINE_PAGES_OFFLINE_PAGE_BOOKMARK_OBSERVER_H_
« no previous file with comments | « chrome/browser/BUILD.gn ('k') | chrome/browser/android/offline_pages/offline_page_bookmark_observer.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698