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

Unified Diff: chrome/browser/extensions/api/sessions/session_id.h

Issue 21022018: Sessions API - previously Session Restore API. Supports restoring currently open foreign windows an… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 4 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
Index: chrome/browser/extensions/api/sessions/session_id.h
diff --git a/chrome/common/extensions/permissions/media_galleries_permission_data.h b/chrome/browser/extensions/api/sessions/session_id.h
similarity index 19%
copy from chrome/common/extensions/permissions/media_galleries_permission_data.h
copy to chrome/browser/extensions/api/sessions/session_id.h
index 896242d6d9f0344b786e089d040770420c53a623..7394351912cd8d18d8ea6bc1886fae5018d3fb95 100644
--- a/chrome/common/extensions/permissions/media_galleries_permission_data.h
+++ b/chrome/browser/extensions/api/sessions/session_id.h
@@ -2,50 +2,50 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-#ifndef CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_
-#define CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_
+#ifndef CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__
+#define CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__
#include <string>
#include "base/basictypes.h"
#include "base/memory/scoped_ptr.h"
-#include "chrome/common/extensions/permissions/api_permission.h"
-
-namespace base {
-class Value;
-}
namespace extensions {
-// A MediaGalleriesPermissionData instance represents a single part of the
-// MediaGalleriesPermission. e.g. "read" or "allAutoDetected".
-class MediaGalleriesPermissionData {
+class SessionId {
public:
- MediaGalleriesPermissionData();
+ // Constructs a SessionId object for the given session information.
not at google - send to devlin 2013/08/15 20:16:24 wow. git. weird. damn. can worry about fixing thi
+ // |session_tag| is the string used to uniquely identify a synced foreign
+ // session from the SessionModelAssociator. In the case that SessionId
+ // represents a local session, |session_tag_| will be the empty string. |id|
+ // uniquely identifies either a window or tab object in the local or the
+ // |session_tag| session.
+ SessionId(const std::string& session_tag, int id);
- // Check if |param| (which must be a MediaGalleriesPermission::CheckParam)
- // matches the encapsulated attribute.
- bool Check(const APIPermission::CheckParam* param) const;
+ // Returns a SessionId, representing either a local or a foreign session.
+ // In the case that the session is local, |session_tag_| will be empty string.
+ static scoped_ptr<SessionId> Parse(const std::string& session_string);
not at google - send to devlin 2013/08/15 20:16:24 put static methods first. You should also mention
Kristen Dwan 2013/08/16 22:03:06 Done.
- // Convert |this| into a base::Value.
- scoped_ptr<base::Value> ToValue() const;
+ // Returns true if the SessionId represents a foreign session.
+ bool IsForeign() const;
- // Populate |this| from a base::Value.
- bool FromValue(const base::Value* value);
+ // Returns the compressed std::string representation of a SessionId.
+ std::string ToString() const;
- bool operator<(const MediaGalleriesPermissionData& rhs) const;
- bool operator==(const MediaGalleriesPermissionData& rhs) const;
+ const std::string& session_tag() const { return session_tag_; }
+ int id() const { return id_; }
- std::string permission() const { return permission_; }
+ private:
+ // The unique identifier for a foreign session, given by the
+ // SessionModelAssociator.
+ std::string session_tag_;
- // This accessor is provided for IPC_STRUCT_TRAITS_MEMBER. Please think
- // twice before using it for anything else.
- std::string& permission() { return permission_; }
+ // ID corresponding to a window or tab object.
+ int id_;
- private:
- std::string permission_;
+ DISALLOW_COPY_AND_ASSIGN(SessionId);
};
} // namespace extensions
-#endif // CHROME_COMMON_EXTENSIONS_PERMISSIONS_MEDIA_GALLERIES_PERMISSION_DATA_H_
+#endif // CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSION_ID_H__

Powered by Google App Engine
This is Rietveld 408576698