Add ENABLE_MEDIA_ROUTER define to builds other than Android and iOS.
[chromium-blink-merge.git] / chrome / browser / sync / glue / synced_session.h
blobb243dcf04b95347e1959ea0e4492f2df5119193d
1 // Copyright 2012 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_SYNC_GLUE_SYNCED_SESSION_H_
6 #define CHROME_BROWSER_SYNC_GLUE_SYNCED_SESSION_H_
8 #include <map>
9 #include <string>
11 #include "base/time/time.h"
12 #include "components/sessions/session_id.h"
13 #include "components/sessions/session_types.h"
14 #include "sync/protocol/session_specifics.pb.h"
16 namespace content {
17 class NavigationEntry;
20 namespace browser_sync {
22 // Defines a synced session for use by session sync. A synced session is a
23 // list of windows along with a unique session identifer (tag) and meta-data
24 // about the device being synced.
25 struct SyncedSession {
26 typedef std::map<SessionID::id_type, sessions::SessionWindow*>
27 SyncedWindowMap;
29 // The type of device.
30 // Please keep in sync with ForeignSessionHelper.java
31 enum DeviceType {
32 TYPE_UNSET = 0,
33 TYPE_WIN = 1,
34 TYPE_MACOSX = 2,
35 TYPE_LINUX = 3,
36 TYPE_CHROMEOS = 4,
37 TYPE_OTHER = 5,
38 TYPE_PHONE = 6,
39 TYPE_TABLET = 7
42 SyncedSession();
43 ~SyncedSession();
45 // Unique tag for each session.
46 std::string session_tag;
47 // User-visible name
48 std::string session_name;
50 // Type of device this session is from.
51 DeviceType device_type;
53 // Last time this session was modified remotely.
54 base::Time modified_time;
56 // Map of windows that make up this session. Windowws are owned by the session
57 // itself and free'd on destruction.
58 SyncedWindowMap windows;
60 // Converts the DeviceType enum value to a string. This is used
61 // in the NTP handler for foreign sessions for matching session
62 // types to an icon style.
63 std::string DeviceTypeAsString() const {
64 switch (device_type) {
65 case SyncedSession::TYPE_WIN:
66 return "win";
67 case SyncedSession::TYPE_MACOSX:
68 return "macosx";
69 case SyncedSession::TYPE_LINUX:
70 return "linux";
71 case SyncedSession::TYPE_CHROMEOS:
72 return "chromeos";
73 case SyncedSession::TYPE_OTHER:
74 return "other";
75 case SyncedSession::TYPE_PHONE:
76 return "phone";
77 case SyncedSession::TYPE_TABLET:
78 return "tablet";
79 default:
80 return std::string();
84 // Convert this object to its protocol buffer equivalent. Shallow conversion,
85 // does not create SessionTab protobufs.
86 sync_pb::SessionHeader ToSessionHeader() const;
88 private:
89 DISALLOW_COPY_AND_ASSIGN(SyncedSession);
92 // Control which foreign tabs we're interested in syncing/displaying. Checks
93 // that the tab has navigations and contains at least one valid url.
94 // Note: chrome:// and file:// are not considered valid urls (for syncing).
95 bool ShouldSyncSessionTab(const sessions::SessionTab& tab);
97 // Checks whether the window has tabs to sync. If no tabs to sync, it returns
98 // true, false otherwise.
99 bool SessionWindowHasNoTabsToSync(const sessions::SessionWindow& window);
101 } // namespace browser_sync
103 #endif // CHROME_BROWSER_SYNC_GLUE_SYNCED_SESSION_H_