blob: c80740fd4b29849bac434c2814e354240ba75763 [file] [log] [blame]
// 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_