Merge branch 'master' into fix-nsarray-kvc-generics

This commit is contained in:
Fred Kiefer 2019-07-15 08:43:37 +02:00 committed by GitHub
commit 2e9207c4e9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
10 changed files with 440 additions and 3 deletions

View file

@ -18,7 +18,7 @@ matrix:
sudo: required
before_install:
- sudo apt-get -qq update
- sudo apt-get install -y cmake pkg-config libgnutls28-dev libgmp-dev libffi-dev libicu-dev libxml2-dev libxslt1-dev libssl-dev libavahi-client-dev zlib1g-dev
- sudo apt-get install -y cmake pkg-config libgnutls28-dev libgmp-dev libffi-dev libicu-dev libxml2-dev libxslt1-dev libssl-dev libavahi-client-dev zlib1g-dev libblocksruntime-dev
- >
if [ $LIBRARY_COMBO = 'gnu-gnu-gnu' ];
then

View file

@ -5,16 +5,37 @@
Fix generics definition of NSMutableArray and NSMutableOrderedSet.
Fix NSArray and NSOrderedSet KVC method types to not use generic type.
2019-07-14 Fred Kiefer <fredkiefer@gmx.de>
* Source/NSUbiquitousKeyValueStore.m: Change to use GNUstep
formatting. Move simple methods into base class. Correct the usage
of long long NSNumber.
2019-07-10 Gregory Casamento <greg.casamento@gmail.com>
* Headers/Foundation/NSUbiquitousKeyValueStore.h
* Source/NSUbiquitousKeyValueStore.m: Implementation of
skeletal version of this class for compilation. Also put in
place a way to make concrete subclasses for various services.
2019-07-02 Wolfgang Lux <wolfgang.lux@gmail.com>
* Tests/base/GSTLS/basic.m: Use fixed time zone.
2019-07-02 Gregory John Casamento <greg.casamento@gmail.com>
* Headers/Foundation/NSOrderedSet.h: Added header for class cluster
implementation of NSOrderedSet.
* Source/NSOrderedSet.m: Implementation of NSOrderedSet and NSMutableOrderedSet
* Source/GSOrderedSet.m: Implementation of concrete class.
2019-07-01 Fred Kiefer <fredkiefer@gmx.de>
* Source/GSXML.m (fatalErrorFunction): Use correct function to get
line number.
* Source/NSOperation.m (_execute): Surround with NS_DURING to free
lock on error.
2019-06-11 Richard Frith-Macdonald <rfm@gnu.org>
* Headers/GNUstepBase/GSIArray.h:

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

@ -35,7 +35,6 @@ Missing headers:
<NSScriptObjectSpecifiers.h>
<NSScriptStandardSuiteCommands.h>
<NSScriptSuiteRegistry.h>>
<NSUbiquitousKeyValueStore.h>
<NSUserNotification.h>
<NSUserScriptTask.h>
<NSXPCConnection.h>
@ -48,7 +47,6 @@ Foundation:
<NSFileVersion.h>
<NSFileWrapper.h>
<NSLinguisticTagger.h>
<NSUbiquitousKeyValueStore.h>
<NSAppleEventDescriptor.h>
<NSAppleEventManager.h>
<NSAppleScript.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,253 @@
/** 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
{
return (NSArray *)[self objectForKey: key];
}
// Returns the Boolean value associated with the specified key.
- (BOOL) boolForKey: (NSString *)key
{
return (BOOL)([[self objectForKey: key] boolValue] == 1);
}
// Returns the data object associated with the specified key.
- (NSData*) dataForKey: (NSString *)key
{
return (NSData *)[self objectForKey: key];
}
// Returns the dictionary object associated with the specified key.
- (NSDictionary *) dictionaryForKey: (NSString *)key
{
return (NSDictionary *)[self objectForKey: key];
}
// Returns the double value associated with the specified key.
- (double) doubleForKey: (NSString *)key
{
return [[self objectForKey: key] doubleValue];
}
// Returns the long long value associated with the specified key.
- (long long) longLongForKey: (NSString *)key
{
return [[self objectForKey: key] longLongValue];
}
// 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
{
return (NSString *)[self objectForKey: key];
}
// Setting Values
// Sets an array object for the specified key in the key-value store.
- (void) setArray: (NSArray *)array forKey: (NSString *)key
{
[self 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];
[self setObject: num forKey: key];
}
// Sets a data object for the specified key in the key-value store.
- (void) setData: (NSData *)data forKey: (NSString *)key
{
[self setObject: data forKey: key];
}
// Sets a dictionary object for the specified key in the key-value store.
- (void) setDictionary: (NSDictionary *)dict forKey: (NSString *)key
{
[self 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];
[self 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 numberWithLongLong: val];
[self setObject: num forKey: key];
}
// 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 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
{
[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;
}
@end
@interface GSSimpleUbiquitousKeyValueStore : NSUbiquitousKeyValueStore
{
NSMutableDictionary *_dict;
}
@end
@implementation GSSimpleUbiquitousKeyValueStore
- (id) init
{
self = [super init];
if(self != nil)
{
_dict = [[NSMutableDictionary alloc] initWithCapacity: 10];
}
return self;
}
// Returns the object associated with the specified key.
- (id) objectForKey: (NSString *)key
{
return [_dict objectForKey: 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];
}
// 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;
}