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

Unified Diff: chrome/browser/printing/background_printing_manager.h

Issue 7862005: Merge 100235 - Print Preview: Hold on to tabs that do window.print(); window.close() until print ... (Closed) Base URL: svn://svn.chromium.org/chrome/branches/874/src/
Patch Set: Created 9 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 | « no previous file | chrome/browser/printing/background_printing_manager.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/printing/background_printing_manager.h
===================================================================
--- chrome/browser/printing/background_printing_manager.h (revision 100462)
+++ chrome/browser/printing/background_printing_manager.h (working copy)
@@ -6,6 +6,7 @@
#define CHROME_BROWSER_PRINTING_BACKGROUND_PRINTING_MANAGER_H_
#pragma once
+#include <map>
#include <set>
#include "base/compiler_specific.h"
@@ -13,6 +14,7 @@
#include "content/common/notification_observer.h"
#include "content/common/notification_registrar.h"
+class RenderProcessHost;
class TabContentsWrapper;
namespace printing {
@@ -33,6 +35,13 @@
// hides it from the user.
void OwnPrintPreviewTab(TabContentsWrapper* preview_tab);
+ // Takes ownership of |initiator_tab| and deletes it when its preview tab is
+ // destroyed by either being canceled, closed or finishing printing. This
+ // removes the TabContentsWrapper from its TabStrip and hides it from the
+ // user. Returns true if content has an associated print preview tab,
+ // otherwise, returns false and does not take ownership of |initiator_tab|.
+ bool OwnInitiatorTab(TabContentsWrapper* initiator_tab);
+
// Let others iterate over the list of background printing tabs.
TabContentsWrapperSet::const_iterator begin();
TabContentsWrapperSet::const_iterator end();
@@ -46,9 +55,27 @@
const NotificationDetails& details) OVERRIDE;
private:
+ typedef std::map<TabContentsWrapper*, TabContentsWrapper*>
+ TabContentsWrapperMap;
+
+ // Notifications handlers.
+ void OnRendererProcessClosed(RenderProcessHost* rph);
+ void OnPrintJobReleased(TabContentsWrapper* preview_tab);
+ void OnTabContentsDestroyed(TabContentsWrapper* preview_tab);
+
+ // Removes |tab| from its tab strip.
+ void RemoveFromTabStrip(TabContentsWrapper* tab);
+
// The set of print preview tabs managed by BackgroundPrintingManager.
TabContentsWrapperSet printing_tabs_;
+ // 1:1 mapping between an initiator tab managed by BackgroundPrintingManager
+ // and its associated print preview tab. The print preview tab need not be in
+ // |printing_tabs_|.
+ // Key: print preview tab.
+ // Value: initiator tab.
+ TabContentsWrapperMap map_;
+
NotificationRegistrar registrar_;
DISALLOW_COPY_AND_ASSIGN(BackgroundPrintingManager);
« no previous file with comments | « no previous file | chrome/browser/printing/background_printing_manager.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698