| Index: chrome/browser/extensions/api/sessions/sessions_api.h
|
| diff --git a/chrome/browser/extensions/api/session_restore/session_restore_api.h b/chrome/browser/extensions/api/sessions/sessions_api.h
|
| similarity index 24%
|
| rename from chrome/browser/extensions/api/session_restore/session_restore_api.h
|
| rename to chrome/browser/extensions/api/sessions/sessions_api.h
|
| index 37ab15eb1f5be393fdf7c584069d204684ce6b6a..207b6e22b038c990458221e5c8fb085cad0d8282 100644
|
| --- a/chrome/browser/extensions/api/session_restore/session_restore_api.h
|
| +++ b/chrome/browser/extensions/api/sessions/sessions_api.h
|
| @@ -1,61 +1,101 @@
|
| -// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
| +// Copyright (c) 2013 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_EXTENSIONS_API_SESSION_RESTORE_SESSION_RESTORE_API_H__
|
| -#define CHROME_BROWSER_EXTENSIONS_API_SESSION_RESTORE_SESSION_RESTORE_API_H__
|
| +#ifndef CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSIONS_API_H__
|
| +#define CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSIONS_API_H__
|
| +
|
| +#include <string>
|
|
|
| #include "chrome/browser/extensions/api/profile_keyed_api_factory.h"
|
| #include "chrome/browser/extensions/extension_function.h"
|
| #include "chrome/browser/sessions/tab_restore_service.h"
|
| -#include "chrome/common/extensions/api/session_restore.h"
|
| +#include "chrome/browser/sessions/tab_restore_service_observer.h"
|
| +#include "chrome/common/extensions/api/sessions.h"
|
| #include "chrome/common/extensions/api/tabs.h"
|
| #include "chrome/common/extensions/api/windows.h"
|
|
|
| class Profile;
|
|
|
| +namespace browser_sync {
|
| +struct SyncedSession;
|
| +}
|
| +
|
| namespace extensions {
|
|
|
| -class SessionRestoreGetRecentlyClosedFunction : public SyncExtensionFunction {
|
| +class ForeignSessionId;
|
| +
|
| +class SessionsGetRecentlyClosedFunction : public SyncExtensionFunction {
|
| protected:
|
| - virtual ~SessionRestoreGetRecentlyClosedFunction() {}
|
| + virtual ~SessionsGetRecentlyClosedFunction() {}
|
| virtual bool RunImpl() OVERRIDE;
|
| - DECLARE_EXTENSION_FUNCTION("sessionRestore.getRecentlyClosed",
|
| - SESSIONRESTORE_GETRECENTLYCLOSED)
|
| + DECLARE_EXTENSION_FUNCTION("sessions.getRecentlyClosed",
|
| + SESSIONS_GETRECENTLYCLOSED)
|
|
|
| private:
|
| - scoped_ptr<api::tabs::Tab> CreateTabModel(
|
| - const TabRestoreService::Tab& tab, int selected_index);
|
| + scoped_ptr<api::tabs::Tab> CreateTabModel(const TabRestoreService::Tab& tab,
|
| + int session_id,
|
| + int selected_index);
|
| scoped_ptr<api::windows::Window> CreateWindowModel(
|
| - const TabRestoreService::Window& window);
|
| - scoped_ptr<api::session_restore::ClosedEntry> CreateEntryModel(
|
| + const TabRestoreService::Window& window,
|
| + int session_id);
|
| + scoped_ptr<api::sessions::Session> CreateSessionModel(
|
| const TabRestoreService::Entry* entry);
|
| };
|
|
|
| -class SessionRestoreRestoreFunction : public SyncExtensionFunction {
|
| +class SessionsGetDevicesFunction : public SyncExtensionFunction {
|
| + protected:
|
| + virtual ~SessionsGetDevicesFunction() {}
|
| + virtual bool RunImpl() OVERRIDE;
|
| + DECLARE_EXTENSION_FUNCTION("sessions.getDevices", SESSIONS_GETDEVICES)
|
| +
|
| + private:
|
| + scoped_ptr<api::tabs::Tab> CreateTabModel(const std::string& session_tag,
|
| + const SessionTab& tab,
|
| + int tab_index,
|
| + int selected_index);
|
| + scoped_ptr<api::windows::Window> CreateWindowModel(
|
| + const SessionWindow& window,
|
| + const std::string& session_tag);
|
| + scoped_ptr<api::sessions::Session> CreateSessionModel(
|
| + const SessionWindow& window,
|
| + const std::string& session_tag);
|
| + scoped_ptr<api::sessions::Device> CreateDeviceModel(
|
| + const browser_sync::SyncedSession* session);
|
| +};
|
| +
|
| +class SessionsRestoreFunction : public SyncExtensionFunction {
|
| protected:
|
| - virtual ~SessionRestoreRestoreFunction() {}
|
| + virtual ~SessionsRestoreFunction() {}
|
| virtual bool RunImpl() OVERRIDE;
|
| - DECLARE_EXTENSION_FUNCTION("sessionRestore.restore", SESSIONRESTORE_RESTORE)
|
| + DECLARE_EXTENSION_FUNCTION("sessions.restore", SESSIONS_RESTORE)
|
| +
|
| + private:
|
| + void SetResultRestoredTab(const content::WebContents* contents);
|
| + bool SetResultRestoredWindow(int window_id);
|
| + bool RestoreMostRecentlyClosed(Browser* browser);
|
| + bool RestoreLocalSession(int id, Browser* browser);
|
| + bool RestoreForeignSession(const ForeignSessionId* fs_id,
|
| + Browser* browser);
|
| };
|
|
|
| -class SessionRestoreAPI : public ProfileKeyedAPI {
|
| +class SessionsAPI : public ProfileKeyedAPI {
|
| public:
|
| - explicit SessionRestoreAPI(Profile* profile);
|
| - virtual ~SessionRestoreAPI();
|
| + explicit SessionsAPI(Profile* profile);
|
| + virtual ~SessionsAPI();
|
|
|
| // ProfileKeyedAPI implementation.
|
| - static ProfileKeyedAPIFactory<SessionRestoreAPI>* GetFactoryInstance();
|
| + static ProfileKeyedAPIFactory<SessionsAPI>* GetFactoryInstance();
|
| private:
|
| - friend class ProfileKeyedAPIFactory<SessionRestoreAPI>;
|
| + friend class ProfileKeyedAPIFactory<SessionsAPI>;
|
|
|
| // ProfileKeyedAPI implementation.
|
| static const char* service_name() {
|
| - return "SessionRestoreAPI";
|
| + return "SessionsAPI";
|
| }
|
| static const bool kServiceIsNULLWhileTesting = true;
|
| };
|
|
|
| } // namespace extensions
|
|
|
| -#endif // CHROME_BROWSER_EXTENSIONS_API_SESSION_RESTORE_SESSION_RESTORE_API_H__
|
| +#endif // CHROME_BROWSER_EXTENSIONS_API_SESSIONS_SESSIONS_API_H__
|
|
|