Add GCMChannelStatusSyncer to schedule requests and enable/disable GCM
[chromium-blink-merge.git] / chrome / browser / sessions / session_tab_helper.h
blobd47ec80c956852247d29a35f07f0bc7f0f45bb16
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_SESSIONS_SESSION_TAB_HELPER_H_
6 #define CHROME_BROWSER_SESSIONS_SESSION_TAB_HELPER_H_
8 #include "base/basictypes.h"
9 #include "components/sessions/session_id.h"
10 #include "content/public/browser/web_contents_observer.h"
11 #include "content/public/browser/web_contents_user_data.h"
13 // This class keeps the extension API's windowID up-to-date with the current
14 // window of the tab.
15 class SessionTabHelper : public content::WebContentsObserver,
16 public content::WebContentsUserData<SessionTabHelper> {
17 public:
18 virtual ~SessionTabHelper();
20 // Returns the identifier used by session restore for this tab.
21 const SessionID& session_id() const { return session_id_; }
23 // Identifier of the window the tab is in.
24 void SetWindowID(const SessionID& id);
25 const SessionID& window_id() const { return window_id_; }
27 // If the specified WebContents has a SessionTabHelper (probably because it
28 // was used as the contents of a tab), returns a tab id. This value is
29 // immutable for a given tab. It will be unique across Chrome within the
30 // current session, but may be re-used across sessions. Returns -1
31 // for a NULL WebContents or if the WebContents has no SessionTabHelper.
32 static SessionID::id_type IdForTab(const content::WebContents* tab);
34 // If the specified WebContents has a SessionTabHelper (probably because it
35 // was used as the contents of a tab), and has ever been attached to a Browser
36 // window, returns Browser::session_id().id() for that Browser. If the tab is
37 // being dragged between Browser windows, returns the old window's id value.
38 // If the WebContents has a SessionTabHelper but has never been attached to a
39 // Browser window, returns an id value that is different from that of any
40 // Browser. Returns -1 for a NULL WebContents or if the WebContents has no
41 // SessionTabHelper.
42 static SessionID::id_type IdForWindowContainingTab(
43 const content::WebContents* tab);
45 // content::WebContentsObserver:
46 virtual void RenderViewCreated(
47 content::RenderViewHost* render_view_host) OVERRIDE;
48 virtual void UserAgentOverrideSet(const std::string& user_agent) OVERRIDE;
50 private:
51 explicit SessionTabHelper(content::WebContents* contents);
52 friend class content::WebContentsUserData<SessionTabHelper>;
54 // Unique identifier of the tab for session restore. This id is only unique
55 // within the current session, and is not guaranteed to be unique across
56 // sessions.
57 const SessionID session_id_;
59 // Unique identifier of the window the tab is in.
60 SessionID window_id_;
62 DISALLOW_COPY_AND_ASSIGN(SessionTabHelper);
65 #endif // CHROME_BROWSER_SESSIONS_SESSION_TAB_HELPER_H_