Some NSProxy fixes.

git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/base/trunk@14295 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
CaS 2002-08-19 10:26:07 +00:00
parent d9c38047b0
commit e96009290b
4 changed files with 203 additions and 38 deletions

View file

@ -1,3 +1,8 @@
2002-08-19 Richard Frith-Macdonald <rfm@gnu.org>
* Source/NSProxy.m: Documented all methods and corrected implementation
of some introspection methods.
2002-08-16 Richard Frith-Macdonald <rfm@gnu.org> 2002-08-16 Richard Frith-Macdonald <rfm@gnu.org>
* Source/Base.gsdoc: Moved to Documentation. * Source/Base.gsdoc: Moved to Documentation.

View file

@ -36,19 +36,38 @@
+ (id) alloc; + (id) alloc;
+ (id) allocWithZone: (NSZone*)z; + (id) allocWithZone: (NSZone*)z;
+ (id) autorelease;
+ (Class) class; + (Class) class;
+ (NSString*) description;
+ (BOOL) isKindOfClass: (Class)aClass;
+ (BOOL) isMemberOfClass: (Class)aClass;
+ (void) load; + (void) load;
+ (void) release;
+ (BOOL) respondsToSelector: (SEL)aSelector; + (BOOL) respondsToSelector: (SEL)aSelector;
+ (id) retain;
+ (unsigned int) retainCount;
- (id) autorelease;
- (Class) class;
- (BOOL) conformsToProtocol: (Protocol*)aProtocol;
- (void) dealloc; - (void) dealloc;
- (NSString*) description; - (NSString*) description;
- (void) forwardInvocation: (NSInvocation*)anInvocation; - (void) forwardInvocation: (NSInvocation*)anInvocation;
- (NSMethodSignature*) methodSignatureForSelector: (SEL)aSelector; - (unsigned int) hash;
- (id) init;
@end - (BOOL) isEqual: (id)anObject;
- (BOOL) isKindOfClass: (Class)aClass;
@interface Object (IsProxy) - (BOOL) isMemberOfClass: (Class)aClass;
- (BOOL) isProxy; - (BOOL) isProxy;
- (NSMethodSignature*) methodSignatureForSelector: (SEL)aSelector;
- (void) release;
- (BOOL) respondsToSelector: (SEL)aSelector;
- (id) retain;
- (unsigned int) retainCount;
- (id) self;
- (Class) superclass;
- (NSZone*) zone;
@end @end
#endif /* __NSProxy_h_GNUSTEP_BASE_INCLUDE */ #endif /* __NSProxy_h_GNUSTEP_BASE_INCLUDE */

View file

@ -1935,6 +1935,10 @@ _fastMallocBuffer(unsigned size)
return [NSString stringWithFormat: @"<%s: %lx>", return [NSString stringWithFormat: @"<%s: %lx>",
object_get_class_name(self), (unsigned long)self]; object_get_class_name(self), (unsigned long)self];
} }
- (BOOL) isProxy
{
return NO;
}
- (void) release - (void) release
{ {
return; return;

View file

@ -38,39 +38,84 @@
extern BOOL __objc_responds_to(id, SEL); extern BOOL __objc_responds_to(id, SEL);
#endif #endif
/**
* The NSProxy class provides a basic implementation of a class whose
* instances are used to <em>stand in</em> for other objects.<br />
* The class provides the most basic methods of NSObject, and expects
* messages for other methods to be forwarded to the <em>real</em>
* object represented by the proxy. You must subclass NSProxy to
* implement -forwardInvocation: to these <em>real</em> objects.
*/
@implementation NSProxy @implementation NSProxy
/**
* Allocates and returns an NSProxy instance in the default zone.
*/
+ (id) alloc + (id) alloc
{ {
return [self allocWithZone: NSDefaultMallocZone()]; return [self allocWithZone: NSDefaultMallocZone()];
} }
/**
* Allocates and returns an NSProxy instance in the specified zone z.
*/
+ (id) allocWithZone: (NSZone*)z + (id) allocWithZone: (NSZone*)z
{ {
NSProxy* ob = (NSProxy*) NSAllocateObject(self, 0, z); NSProxy* ob = (NSProxy*) NSAllocateObject(self, 0, z);
return ob; return ob;
} }
/**
* Returns the receiver
*/
+ (id) autorelease + (id) autorelease
{ {
return self; return self;
} }
/**
* Returns the receiver
*/
+ (Class) class + (Class) class
{ {
return self; return self;
} }
/**
* Returns a string describing the receiver.
*/
+ (NSString*) description + (NSString*) description
{ {
return [NSString stringWithFormat: @"<%s>", object_get_class_name(self)]; return [NSString stringWithFormat: @"<%s>", object_get_class_name(self)];
} }
/**
* Returns NO ... the NSProxy class cannot be an instance of any class.
*/
+ (BOOL) isKindOfClass: (Class)aClass
{
return NO;
}
/**
* Returns YES if aClass is identical to the receiver, NO otherwise.
*/
+ (BOOL) isMemberOfClass: (Class)aClass
{
return(self == aClass);
}
/**
* A dummy method ...
*/
+ (void) load + (void) load
{ {
/* Do nothing */ /* Do nothing */
} }
/**
* Returns the method signature for the specified selector.
*/
+ (NSMethodSignature*) methodSignatureForSelector: (SEL)aSelector + (NSMethodSignature*) methodSignatureForSelector: (SEL)aSelector
{ {
struct objc_method *mth; struct objc_method *mth;
@ -92,11 +137,17 @@ extern BOOL __objc_responds_to(id, SEL);
return nil; return nil;
} }
/**
* A dummy method to ensure that the class can safely be held in containers.
*/
+ (void) release + (void) release
{ {
/* Do nothing */ /* Do nothing */
} }
/**
* Returns YES if the receiver responds to aSelector, NO otherwise.
*/
+ (BOOL) respondsToSelector: (SEL)aSelector + (BOOL) respondsToSelector: (SEL)aSelector
{ {
if (__objc_responds_to(self, aSelector)) if (__objc_responds_to(self, aSelector))
@ -105,16 +156,33 @@ extern BOOL __objc_responds_to(id, SEL);
return NO; return NO;
} }
/**
* Returns the receiver.
*/
+ (id) retain + (id) retain
{ {
return self; return self;
} }
/**
* Returns the maximum unsigned integer value.
*/
+ (unsigned int) retainCount
{
return UINT_MAX;
}
/**
* Returns the superclass of the receiver
*/
+ (Class) superclass + (Class) superclass
{ {
return class_get_super_class (self); return class_get_super_class (self);
} }
/**
* Adds the receiver to the current autorelease pool and returns self.
*/
- (id) autorelease - (id) autorelease
{ {
#if GS_WITH_GC == 0 #if GS_WITH_GC == 0
@ -123,30 +191,54 @@ extern BOOL __objc_responds_to(id, SEL);
return self; return self;
} }
/**
* Returns the class of the receiver.
*/
- (Class) class - (Class) class
{ {
return object_get_class(self); return object_get_class(self);
} }
/**
* Calls the -forwardInvocation: method to determine if the 'real' object
* referred to by the proxy conforms to aProtocol. Returns the result.<br />
* NB. The default operation of -forwardInvocation: is to raise an exception.
*/
- (BOOL) conformsToProtocol: (Protocol*)aProtocol - (BOOL) conformsToProtocol: (Protocol*)aProtocol
{ {
[NSException raise: NSGenericException NSMethodSignature *sig;
format: @"subclass %s should override %s", object_get_class_name(self), NSInvocation *inv;
sel_get_name(_cmd)]; BOOL ret;
return NO;
sig = [self methodSignatureForSelector: _cmd];
inv = [NSInvocation invocationWithMethodSignature: sig];
[inv setSelector: _cmd];
[inv setArgument: &aProtocol atIndex: 2];
[self forwardInvocation: inv];
[inv getReturnValue: &ret];
return ret;
} }
/**
* Frees the memory used by the receiver.
*/
- (void) dealloc - (void) dealloc
{ {
NSDeallocateObject((NSObject*)self); NSDeallocateObject((NSObject*)self);
} }
/**
* Returns a text descrioption of the receiver.
*/
- (NSString*) description - (NSString*) description
{ {
return [NSString stringWithFormat: @"<%s %lx>", return [NSString stringWithFormat: @"<%s %lx>",
object_get_class_name(self), (unsigned long)self]; object_get_class_name(self), (unsigned long)self];
} }
/**
* Calls the -forwardInvocation: method and returns the result.
*/
- (retval_t) forward:(SEL)aSel :(arglist_t)argFrame - (retval_t) forward:(SEL)aSel :(arglist_t)argFrame
{ {
NSInvocation *inv; NSInvocation *inv;
@ -157,6 +249,9 @@ extern BOOL __objc_responds_to(id, SEL);
return [inv returnFrame: argFrame]; return [inv returnFrame: argFrame];
} }
/** <override-subclass />
* Raises an NSInvalidArgumentException
*/
- (void) forwardInvocation: (NSInvocation*)anInvocation - (void) forwardInvocation: (NSInvocation*)anInvocation
{ {
[NSException raise: NSInvalidArgumentException [NSException raise: NSInvalidArgumentException
@ -164,11 +259,17 @@ extern BOOL __objc_responds_to(id, SEL);
sel_get_name(_cmd)]; sel_get_name(_cmd)];
} }
/**
* Returns the address of the receiver ... so it can be stored in a dictionary.
*/
- (unsigned int) hash - (unsigned int) hash
{ {
return (unsigned int)self; return (unsigned int)self;
} }
/** <init /> <override-subclass />
* Initialises the receiver and returns the resulting instance.
*/
- (id) init - (id) init
{ {
[NSException raise: NSGenericException [NSException raise: NSGenericException
@ -177,41 +278,59 @@ extern BOOL __objc_responds_to(id, SEL);
return self; return self;
} }
/**
* Tests for pointer equality with anObject
*/
- (BOOL) isEqual: (id)anObject - (BOOL) isEqual: (id)anObject
{ {
return (self == anObject); return (self == anObject);
} }
+ (BOOL) isKindOfClass: (Class)aClass /**
{ * Calls the -forwardInvocation: method to determine if the 'real' object
return NO; * referred to by the proxy is an instance of the specified class.
} * Returns the result.<br />
* NB. The default operation of -forwardInvocation: is to raise an exception.
*/
- (BOOL) isKindOfClass: (Class)aClass - (BOOL) isKindOfClass: (Class)aClass
{ {
Class class = self->isa; NSMethodSignature *sig;
NSInvocation *inv;
BOOL ret;
while (class != nil) sig = [self methodSignatureForSelector: _cmd];
{ inv = [NSInvocation invocationWithMethodSignature: sig];
if (class == aClass) [inv setSelector: _cmd];
{ [inv setArgument: &aClass atIndex: 2];
return YES; [self forwardInvocation: inv];
} [inv getReturnValue: &ret];
class = class_get_super_class(class); return ret;
}
return NO;
}
+ (BOOL) isMemberOfClass: (Class)aClass
{
return(self == aClass);
} }
/**
* Calls the -forwardInvocation: method to determine if the 'real' object
* referred to by the proxy is an instance of the specified class.
* Returns the result.<br />
* NB. The default operation of -forwardInvocation: is to raise an exception.
*/
- (BOOL) isMemberOfClass: (Class)aClass - (BOOL) isMemberOfClass: (Class)aClass
{ {
return(self->isa == aClass); NSMethodSignature *sig;
NSInvocation *inv;
BOOL ret;
sig = [self methodSignatureForSelector: _cmd];
inv = [NSInvocation invocationWithMethodSignature: sig];
[inv setSelector: _cmd];
[inv setArgument: &aClass atIndex: 2];
[self forwardInvocation: inv];
[inv getReturnValue: &ret];
return ret;
} }
/**
* Returns YES
*/
- (BOOL) isProxy - (BOOL) isProxy
{ {
return YES; return YES;
@ -224,7 +343,7 @@ extern BOOL __objc_responds_to(id, SEL);
return self; return self;
} }
/* /**
* If we respond to the method directly, create and return a method * If we respond to the method directly, create and return a method
* signature. Otherwise raise an exception. * signature. Otherwise raise an exception.
*/ */
@ -296,17 +415,25 @@ extern BOOL __objc_responds_to(id, SEL);
return (*msg)(self, aSelector, anObject, anotherObject); return (*msg)(self, aSelector, anObject, anotherObject);
} }
/**
* Decrement the retain count for the receiver ... deallocate if it would
* become negative.
*/
- (void) release - (void) release
{ {
#if GS_WITH_GC == 0 #if GS_WITH_GC == 0
if (_retain_count-- == 0) if (_retain_count == 0)
{ {
[self dealloc]; [self dealloc];
} }
else
{
_retain_count--;
}
#endif #endif
} }
/* /**
* If we respond to the method directly, return YES, otherwise * If we respond to the method directly, return YES, otherwise
* forward this request to the object we are acting as a proxy for. * forward this request to the object we are acting as a proxy for.
*/ */
@ -336,6 +463,9 @@ extern BOOL __objc_responds_to(id, SEL);
} }
} }
/**
* Increment the retain count for the receiver.
*/
- (id) retain - (id) retain
{ {
#if GS_WITH_GC == 0 #if GS_WITH_GC == 0
@ -344,26 +474,33 @@ extern BOOL __objc_responds_to(id, SEL);
return self; return self;
} }
/**
* Return the retain count for the receiver.
*/
- (unsigned int) retainCount - (unsigned int) retainCount
{ {
return _retain_count + 1; return _retain_count + 1;
} }
+ (unsigned) retainCount /**
{ * Returns the receiver.
return UINT_MAX; */
}
- (id) self - (id) self
{ {
return self; return self;
} }
/**
* Returns the superclass of the receivers class.
*/
- (Class) superclass - (Class) superclass
{ {
return object_get_super_class(self); return object_get_super_class(self);
} }
/**
* Returns the zone in which the receiver was allocated.
*/
- (NSZone*) zone - (NSZone*) zone
{ {
return NSZoneFromPointer(self); return NSZoneFromPointer(self);