// Copyright (c) 2012 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_SYNC_GLUE_SYNCED_SESSION_H_ #define CHROME_BROWSER_SYNC_GLUE_SYNCED_SESSION_H_ #include <map> #include <string> #include "base/time/time.h" #include "chrome/browser/sessions/session_id.h" #include "chrome/browser/sessions/session_types.h" namespace content { class NavigationEntry; } namespace browser_sync { // Defines a synced session for use by session sync. A synced session is a // list of windows along with a unique session identifer (tag) and meta-data // about the device being synced. struct SyncedSession { typedef std::map<SessionID::id_type, SessionWindow*> SyncedWindowMap; // The type of device. // Please keep in sync with ForeignSessionHelper.java enum DeviceType { TYPE_UNSET = 0, TYPE_WIN = 1, TYPE_MACOSX = 2, TYPE_LINUX = 3, TYPE_CHROMEOS = 4, TYPE_OTHER = 5, TYPE_PHONE = 6, TYPE_TABLET = 7 }; SyncedSession(); ~SyncedSession(); // Unique tag for each session. std::string session_tag; // User-visible name std::string session_name; // Type of device this session is from. DeviceType device_type; // Last time this session was modified remotely. base::Time modified_time; // Map of windows that make up this session. Windowws are owned by the session // itself and free'd on destruction. SyncedWindowMap windows; // Converts the DeviceType enum value to a string. This is used // in the NTP handler for foreign sessions for matching session // types to an icon style. std::string DeviceTypeAsString() const { switch (device_type) { case SyncedSession::TYPE_WIN: return "win"; case SyncedSession::TYPE_MACOSX: return "macosx"; case SyncedSession::TYPE_LINUX: return "linux"; case SyncedSession::TYPE_CHROMEOS: return "chromeos"; case SyncedSession::TYPE_OTHER: return "other"; case SyncedSession::TYPE_PHONE: return "phone"; case SyncedSession::TYPE_TABLET: return "tablet"; default: return std::string(); } } private: DISALLOW_COPY_AND_ASSIGN(SyncedSession); }; // Control which foreign tabs we're interested in syncing/displaying. Checks // that the tab has navigations and contains at least one valid url. // Note: chrome:// and file:// are not considered valid urls (for syncing). bool ShouldSyncSessionTab(const SessionTab& tab); // Checks whether the window has tabs to sync. If no tabs to sync, it returns // true, false otherwise. bool SessionWindowHasNoTabsToSync(const SessionWindow& window); } // namespace browser_sync #endif // CHROME_BROWSER_SYNC_GLUE_SYNCED_SESSION_H_