| Index: ios/chrome/browser/sessions/session_service.h
|
| diff --git a/ios/chrome/browser/sessions/session_service.h b/ios/chrome/browser/sessions/session_service.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..c80740fd4b29849bac434c2814e354240ba75763
|
| --- /dev/null
|
| +++ b/ios/chrome/browser/sessions/session_service.h
|
| @@ -0,0 +1,68 @@
|
| +// Copyright 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 IOS_CHROME_BROWSER_SESSIONS_SESSION_SERVICE_H_
|
| +#define IOS_CHROME_BROWSER_SESSIONS_SESSION_SERVICE_H_
|
| +
|
| +#import <Foundation/Foundation.h>
|
| +
|
| +#include "base/mac/scoped_nsobject.h"
|
| +
|
| +namespace ios {
|
| +class ChromeBrowserState;
|
| +}
|
| +
|
| +@class SessionWindowIOS;
|
| +
|
| +// Trivial NSKeyedUnarchiver subclass that can be configured with a
|
| +// ChromeBrowserState instance that decoding classes can use.
|
| +@interface SessionWindowUnarchiver : NSKeyedUnarchiver
|
| +
|
| +// The BrowserState set on the unarchiver at init; a weak pointer.
|
| +@property(nonatomic, readonly) ios::ChromeBrowserState* browserState;
|
| +
|
| +// Inits exactly as initForReadingWithData: does, additionally setting
|
| +// |browserState| on the reciever.
|
| +- (instancetype)initForReadingWithData:(NSData*)data
|
| + browserState:(ios::ChromeBrowserState*)browserState;
|
| +
|
| +@end
|
| +
|
| +// A singleton service for saving the current session. Can either save on a
|
| +// delay or immediately. Saving is always performed on a separate thread.
|
| +@interface SessionServiceIOS : NSObject
|
| +
|
| +// Lazily creates a singleton instance. Use this instead of calling alloc/init.
|
| ++ (SessionServiceIOS*)sharedService;
|
| +
|
| +// Saves the session represented by |window| to the given browserState directory
|
| +// on disk. If |immediately| is NO, the save is done after a delay. If another
|
| +// call is pending, this one is ignored. If YES, the save is done now,
|
| +// cancelling any pending calls. Either way, the save is done on a separate
|
| +// thread to avoid blocking the UI thread. As a result, |window| should contain
|
| +// copies of non-threadsafe objects.
|
| +- (void)saveWindow:(SessionWindowIOS*)window
|
| + forBrowserState:(ios::ChromeBrowserState*)browserState
|
| + immediately:(BOOL)immediately;
|
| +
|
| +// Loads the window from the given browserState directory on disk on the main
|
| +// thread. Returns nil if no session was previously saved.
|
| +- (SessionWindowIOS*)loadWindowForBrowserState:
|
| + (ios::ChromeBrowserState*)browserState;
|
| +
|
| +// Schedules deletion of the file containing the commands for the last session
|
| +// in the given browserState directory.
|
| +- (void)deleteLastSession:(NSString*)directory;
|
| +
|
| +// Loads the window from the given backup file on disk on the main thread.
|
| +// Returns nil if unable to read the sessions.
|
| +- (SessionWindowIOS*)loadWindowFromPath:(NSString*)path
|
| + forBrowserState:(ios::ChromeBrowserState*)browserState;
|
| +
|
| +// Returns the path of the session file.
|
| +- (NSString*)sessionFilePathForDirectory:(NSString*)directory;
|
| +
|
| +@end
|
| +
|
| +#endif // IOS_CHROME_BROWSER_SESSIONS_SESSION_SERVICE_H_
|
|
|