Merge branch 'NSUbiquitousKeyValueStore_branch'

This commit is contained in:
Gregory John Casamento 2019-07-10 18:10:34 -04:00
commit e0df104ba2
7 changed files with 514 additions and 0 deletions

View file

@ -122,6 +122,7 @@
#import <Foundation/NSThread.h>
#import <Foundation/NSTimer.h>
#import <Foundation/NSTimeZone.h>
#import <Foundation/NSUbiquitousKeyValueStore.h>
#import <Foundation/NSUndoManager.h>
#import <Foundation/NSURLAuthenticationChallenge.h>
#import <Foundation/NSURLCache.h>

View file

@ -0,0 +1,122 @@
/** Interface for NSUbiquitousKeyValueStore
Copyright (C) 2019 Free Software Foundation, Inc.
Written by: Gregory John Casamento <greg.casamento@gmail.com>
Created: July 3 2019
This file is part of the GNUstep Base Library.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02111 USA.
*/
#ifndef _NSUbiquitousKeyValueStore_h_GNUSTEP_BASE_INCLUDE
#define _NSUbiquitousKeyValueStore_h_GNUSTEP_BASE_INCLUDE
#if OS_API_VERSION(MAC_OS_X_VERSION_10_7,GS_API_LATEST)
#import <GNUstepBase/GSVersionMacros.h>
#import <Foundation/NSObject.h>
@class GS_GENERIC_CLASS(NSArray, ElementT);
@class GS_GENERIC_CLASS(NSDictionary, KeyT:id<NSCopying>, ValT);
@class NSData;
@class NSString;
#if defined(__cplusplus)
extern "C" {
#endif
@interface NSUbiquitousKeyValueStore : NSObject
// Getting the Shared Instance
+ (NSUbiquitousKeyValueStore *) defaultStore;
// Getting Values
// Returns the array associated with the specified key.
- (NSArray *) arrayForKey: (NSString *)key;
// Returns the Boolean value associated with the specified key.
- (BOOL) boolForKey: (NSString *)key;
// Returns the data object associated with the specified key.
- (NSData*) dataForKey: (NSString *)key;
// Returns the dictionary object associated with the specified key.
- (NSDictionary *) dictionaryForKey: (NSString *)key;
// Returns the double value associated with the specified key.
- (double) doubleForKey: (NSString *)key;
// Returns the long long value associated with the specified key.
- (long long) longLongForKey: (NSString *)key;
// Returns the object associated with the specified key.
- (id) objectForKey: (NSString *)key;
// Returns the string associated with the specified key.
- (NSString *) stringForKey: (NSString *)key;
// Setting Values
// Sets an array object for the specified key in the key-value store.
- (void) setArray: (NSArray *)array forKey: (NSString *)key;
// Sets a Boolean value for the specified key in the key-value store.
- (void) setBool: (BOOL)flag forKey: (NSString *)key;
// Sets a data object for the specified key in the key-value store.
- (void) setData: (NSData *)data forKey: (NSString *)key;
// Sets a dictionary object for the specified key in the key-value store.
- (void) setDictionary: (NSDictionary *)dict forKey: (NSString *)key;
// Sets a double value for the specified key in the key-value store.
- (void) setDouble: (double)val forKey: (NSString *)key;
// Sets a long long value for the specified key in the key-value store.
- (void) setLongLong: (long long)val forKey: (NSString *)key;
// Sets an object for the specified key in the key-value store.
- (void) setObject: (id) obj forKey: (NSString *)key;
// Sets a string object for the specified key in the key-value store.
- (void) setString: (NSString *)string forKey: (NSString *)key;
// Explicitly Synchronizing In-Memory Key-Value Data to Disk
// Explicitly synchronizes in-memory keys and values with those stored on disk.
- (void) synchronize;
// Removing Keys
// Removes the value associated with the specified key from the key-value store.
- (void) removeObjectForKey: (NSString *)key;
// Retrieving the Current Keys and Values
// A dictionary containing all of the key-value pairs in the key-value store.
- (NSDictionary *) dictionaryRepresentation;
// Notifications & constants
GS_EXPORT NSString* const NSUbiquitousKeyValueStoreDidChangeExternallyNotification;
GS_EXPORT NSString* const NSUbiquitousKeyValueStoreChangeReasonKey;
@end
#if defined(__cplusplus)
}
#endif
#endif /* OS_API_VERSION check */
#endif /* _NSUbiquitousKeyValueStore_h_GNUSTEP_BASE_INCLUDE */

View file

@ -288,6 +288,7 @@ NSTask.m \
NSThread.m \
NSTimer.m \
NSTimeZone.m \
NSUbiquitousKeyValueStore.m \
NSUnarchiver.m \
NSUndoManager.m \
NSURL.m \
@ -457,6 +458,7 @@ NSTextCheckingResult.h\
NSThread.h \
NSTimer.h \
NSTimeZone.h \
NSUbiquitousKeyValueStore.h \
NSUndoManager.h \
NSURLAuthenticationChallenge.h \
NSURLCache.h \

View file

@ -0,0 +1,349 @@
/** Interface for NSUbiquitousKeyValueStore
Copyright (C) 2019 Free Software Foundation, Inc.
Written by: Gregory John Casamento <greg.casamento@gmail.com>
Created: July 3 2019
This file is part of the GNUstep Base Library.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free
Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02111 USA.
*/
#import "common.h"
#import "Foundation/NSAutoreleasePool.h"
#import "Foundation/NSCoder.h"
#import "Foundation/NSEnumerator.h"
#import "Foundation/NSException.h"
#import "Foundation/NSKeyedArchiver.h"
#import <Foundation/NSUbiquitousKeyValueStore.h>
#import <Foundation/NSArray.h>
#import <Foundation/NSDictionary.h>
#import <Foundation/NSData.h>
#import <Foundation/NSString.h>
#import <Foundation/NSValue.h>
#import <Foundation/NSUserDefaults.h>
static NSUbiquitousKeyValueStore *_sharedUbiquitousKeyValueStore = nil;
@implementation NSUbiquitousKeyValueStore : NSObject
// Getting the Shared Instance
- (id) init
{
if((self = [super init]) != nil)
{
}
return self;
}
+ (NSUbiquitousKeyValueStore *) defaultStore
{
if(_sharedUbiquitousKeyValueStore == nil)
{
NSString *storeClassName = [[NSUserDefaults standardUserDefaults]
stringForKey: @"GSUbiquitousKeyValueStoreClass"];
Class klass = (storeClassName != nil) ? NSClassFromString(storeClassName) :
NSClassFromString(@"GSSimpleUbiquitousKeyValueStore");
_sharedUbiquitousKeyValueStore = [[klass alloc] init];
if(_sharedUbiquitousKeyValueStore == nil)
{
NSLog(@"Cannot instantiate class shared key store");
}
}
return _sharedUbiquitousKeyValueStore;
}
// Getting Values
// Returns the array associated with the specified key.
- (NSArray *) arrayForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return nil;
}
// Returns the Boolean value associated with the specified key.
- (BOOL) boolForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return NO;
}
// Returns the data object associated with the specified key.
- (NSData*) dataForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return nil;
}
// Returns the dictionary object associated with the specified key.
- (NSDictionary *) dictionaryForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return nil;
}
// Returns the double value associated with the specified key.
- (double) doubleForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return 0.0;
}
// Returns the long long value associated with the specified key.
- (long long) longLongForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return 0.0;
}
// Returns the object associated with the specified key.
- (id) objectForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return nil;
}
// Returns the string associated with the specified key.
- (NSString *) stringForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
return nil;
}
// Setting Values
// Sets an array object for the specified key in the key-value store.
- (void) setArray: (NSArray *)array forKey: (NSString *)key
{
}
// Sets a Boolean value for the specified key in the key-value store.
- (void) setBool: (BOOL)flag forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets a data object for the specified key in the key-value store.
- (void) setData: (NSData *)data forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets a dictionary object for the specified key in the key-value store.
- (void) setDictionary: (NSDictionary *)dict forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets a double value for the specified key in the key-value store.
- (void) setDouble: (double)val forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets a long long value for the specified key in the key-value store.
- (void) setLongLong: (long long)val forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets an object for the specified key in the key-value store.
- (void) setObject: (id) obj forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Sets a string object for the specified key in the key-value store.
- (void) setString: (NSString *)string forKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Explicitly Synchronizing In-Memory Key-Value Data to Disk
// Explicitly synchronizes in-memory keys and values with those stored on disk.
- (void) synchronize
{
[self subclassResponsibility: _cmd];
}
// Removing Keys
// Removes the value associated with the specified key from the key-value store.
- (void) removeObjectForKey: (NSString *)key
{
[self subclassResponsibility: _cmd];
}
// Retrieving the Current Keys and Values
// A dictionary containing all of the key-value pairs in the key-value store.
- (NSDictionary *) dictionaryRepresentation
{
[self subclassResponsibility: _cmd];
return nil;
}
// Notifications & constants
GS_EXPORT NSString* const NSUbiquitousKeyValueStoreDidChangeExternallyNotification;
GS_EXPORT NSString* const NSUbiquitousKeyValueStoreChangeReasonKey;
@end
@interface GSSimpleUbiquitousKeyValueStore : NSUbiquitousKeyValueStore
{
NSMutableDictionary *_dict;
}
@end
@implementation GSSimpleUbiquitousKeyValueStore
- (id) init
{
self = [super init];
if(self != nil)
{
_dict = [[NSMutableDictionary alloc] initWithCapacity: 10];
}
return self;
}
// Getting Values
// Returns the array associated with the specified key.
- (NSArray *) arrayForKey: (NSString *)key
{
return (NSArray *)[_dict objectForKey: key];
}
// Returns the Boolean value associated with the specified key.
- (BOOL) boolForKey: (NSString *)key
{
return (BOOL)([[_dict objectForKey: key] boolValue] == 1);
}
// Returns the data object associated with the specified key.
- (NSData*) dataForKey: (NSString *)key
{
return (NSData *)[_dict objectForKey: key];
}
// Returns the dictionary object associated with the specified key.
- (NSDictionary *) dictionaryForKey: (NSString *)key
{
return (NSDictionary *)[_dict objectForKey: key];
}
// Returns the double value associated with the specified key.
- (double) doubleForKey: (NSString *)key
{
return (double)[[_dict objectForKey: key] doubleValue];
}
// Returns the long long value associated with the specified key.
- (long long) longLongForKey: (NSString *)key
{
return (long long)[[_dict objectForKey: key] longValue];
}
// Returns the object associated with the specified key.
- (id) objectForKey: (NSString *)key
{
return [_dict objectForKey: key];
}
// Returns the string associated with the specified key.
- (NSString *) stringForKey: (NSString *)key
{
return (NSString *)[_dict objectForKey: key];
}
// Setting Values
// Sets an array object for the specified key in the key-value store.
- (void) setArray: (NSArray *)array forKey: (NSString *)key
{
[_dict setObject: array forKey: key];
}
// Sets a Boolean value for the specified key in the key-value store.
- (void) setBool: (BOOL)flag forKey: (NSString *)key
{
NSNumber *num = [NSNumber numberWithBool: flag];
[_dict setObject: num forKey: key];
}
// Sets a data object for the specified key in the key-value store.
- (void) setData: (NSData *)data forKey: (NSString *)key
{
[_dict setObject: data forKey: key];
}
// Sets a dictionary object for the specified key in the key-value store.
- (void) setDictionary: (NSDictionary *)dict forKey: (NSString *)key
{
[_dict setObject: dict forKey: key];
}
// Sets a double value for the specified key in the key-value store.
- (void) setDouble: (double)val forKey: (NSString *)key
{
NSNumber *num = [NSNumber numberWithDouble: val];
[_dict setObject: num forKey: key];
}
// Sets a long long value for the specified key in the key-value store.
- (void) setLongLong: (long long)val forKey: (NSString *)key
{
NSNumber *num = [NSNumber numberWithLong: val];
[_dict setObject: num forKey: key];
}
// Sets an object for the specified key in the key-value store.
- (void) setObject: (id) obj forKey: (NSString *)key
{
[_dict setObject: obj forKey: key];
}
// Sets a string object for the specified key in the key-value store.
- (void) setString: (NSString *)string forKey: (NSString *)key
{
[_dict setObject: string forKey: key];
}
// Explicitly Synchronizing In-Memory Key-Value Data to Disk
// Explicitly synchronizes in-memory keys and values with those stored on disk.
- (void) synchronize
{
}
// Removing Keys
// Removes the value associated with the specified key from the key-value store.
- (void) removeObjectForKey: (NSString *)key
{
[_dict removeObjectForKey: key];
}
// Retrieving the Current Keys and Values
// A dictionary containing all of the key-value pairs in the key-value store.
- (NSDictionary *) dictionaryRepresentation
{
return _dict;
}
@end
@interface GSAWSUbiquitousKeyValueStore : NSUbiquitousKeyValueStore
{
}
@end
@implementation GSAWSUbiquitousKeyValueStore
@end

View file

@ -86,6 +86,11 @@ NSString *NSUndoManagerWillRedoChangeNotification = @"NSUndoManagerWillRedoChang
NSString *NSUndoManagerWillUndoChangeNotification = @"NSUndoManagerWillUndoChangeNotification";
/*
* NSUbiquitousKeyValueStore notifications
*/
NSString *NSUbiquitousKeyValueStoreDidChangeExternallyNotification = @"NSUbiquitousKeyValueStoreDidChangeExternallyNotification";
NSString *NSUbiquitousKeyValueStoreChangeReasonKey = @"NSUbiquitousKeyValueStoreChangeReasonKey";
/* NSURL constants */
NSString *NSURLFileScheme = @"file";

View file

@ -0,0 +1,35 @@
#import "ObjectTesting.h"
#import <Foundation/Foundation.h>
int main()
{
START_SET("NSUbiquitousKeyValueStore base");
NSUbiquitousKeyValueStore *kvStore = [NSUbiquitousKeyValueStore defaultStore];
[kvStore setObject:@"Hello" forKey:@"World"];
id obj = [kvStore objectForKey:@"World"];
PASS([obj isEqualToString:@"Hello"], "Returned proper value");
[kvStore setString:@"Hello" forKey:@"World2"];
obj = [kvStore objectForKey:@"World2"];
PASS([obj isEqualToString:@"Hello"], "Returned proper value");
[kvStore setArray: [NSArray arrayWithObject:@"Hello"] forKey:@"World3"];
obj = [kvStore arrayForKey:@"World3"];
PASS([obj isEqual:[NSArray arrayWithObject:@"Hello"] ], "Returned proper value");
[kvStore setDictionary:[NSDictionary dictionaryWithObject:@"Hello" forKey:@"World4"] forKey:@"World5"];
obj = [kvStore dictionaryForKey:@"World5"];
PASS([obj isEqual:[NSDictionary dictionaryWithObject:@"Hello" forKey:@"World4"]], "Returned proper value");
[kvStore setData:[NSData dataWithBytes:"hello" length:5] forKey:@"World6"];
obj = [kvStore dataForKey:@"World6"];
PASS([obj isEqual:[NSData dataWithBytes:"hello" length:5]], "Returned proper value");
[kvStore setDictionary:[NSDictionary dictionaryWithObject:@"Hello" forKey:@"World4"] forKey:@"World5"];
obj = [kvStore objectForKey:@"World5"];
PASS([obj isEqual:[NSDictionary dictionaryWithObject:@"Hello" forKey:@"World4"]], "Returned proper value");
END_SET("NSUbiquitousKeyValueStore base");
return 0;
}