Added more of the implementation for toolbar/toolbaritem. Added check in GSClassSwapper to prevent an error case.

git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gui/trunk@17532 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
Gregory John Casamento 2003-08-24 17:22:11 +00:00
parent 577c9532e6
commit a32c4a14df
8 changed files with 173 additions and 40 deletions

View file

@ -335,7 +335,8 @@ IMLoading.h \
GSLayoutManager.h \
GSLayoutManager_internal.h \
GSTypesetter.h \
GSHorizontalTypesetter.h
GSHorizontalTypesetter.h \
GSToolbarView.h
libgnustep-gui_HEADER_FILES = ${GUI_HEADERS}

View file

@ -380,9 +380,10 @@ static const int currentVersion = 1; // GSNibItem version number...
{
if((self = [self init]) != nil)
{
NSLog(@"Created template %@ -> %@",NSStringFromClass([self class]), className);
NSDebugLog(@"Created template %@ -> %@",NSStringFromClass([self class]), className);
ASSIGN(_object, object);
ASSIGN(_className, className);
NSAssert(![className isEqualToString: superClassName], NSInvalidArgumentException);
_superClass = NSClassFromString(superClassName);
if(_superClass == nil)
{

View file

@ -38,19 +38,12 @@
#include "AppKit/NSView.h"
#include "AppKit/NSButton.h"
#include "AppKit/NSNibLoading.h"
#include "GNUstepGUI/GSToolbarView.h"
// internal
static NSNotificationCenter *nc = nil;
static const int current_version = 1;
@interface GSToolbarView : NSView
{
NSToolbar *_toolbar;
}
- (void) setToolbar: (NSToolbar *)toolbar;
- (NSToolbar *) toolbar;
@end
@implementation GSToolbarView
- (void) dealloc
{
@ -61,6 +54,7 @@ static const int current_version = 1;
- (void) setToolbar: (NSToolbar *)toolbar
{
ASSIGN(_toolbar, toolbar);
}
- (NSToolbar *) toolbar
{
@ -69,7 +63,23 @@ static const int current_version = 1;
- (void) drawRect: (NSRect)aRect
{
NSArray *items = [_toolbar items];
NSEnumerator *en = [items objectEnumerator];
id item = nil;
float x = 0;
[super drawRect: aRect];
while((item = [en nextObject]) != nil)
{
NSView *itemView = [item view];
NSRect itemFrame = [itemView frame];
// now we need to draw the items...
itemFrame.origin.x = x; // start at x
itemFrame.origin.y = 0; // reset to top of view.
[itemView drawRect: itemFrame];
x += NSWidth(itemFrame) + 2; // move over by the frame width plus 2 pixels.
}
}
@end
@ -101,13 +111,12 @@ static const int current_version = 1;
@end
@implementation NSToolbar (GNUstepPrivate)
- (GSToolbarView *) _toolbarView
- (id) _toolbarView
{
return _toolbarView;
}
@end
@implementation NSToolbar
// Initialize the class when it is loaded
+ (void) initialize
@ -309,5 +318,3 @@ static const int current_version = 1;
return _visibleItems;
}
@end /* interface of NSToolbar */

View file

@ -42,7 +42,11 @@
- (NSImage *)image
{
return _image;
if(_flags.viewRespondsToImage)
{
return [_view image];
}
return nil;
}
- (id)initWithItemIdentifier: (NSString *)itemIdentifier
@ -53,7 +57,11 @@
- (BOOL)isEnabled
{
return _enabled;
if(_flags.viewRespondsToIsEnabled)
{
return [_view isEnabled];
}
return NO;
}
- (NSString *)itemIdentifier
@ -88,17 +96,26 @@
- (void)setAction: (SEL)action
{
_action = action;
if(_flags.viewRespondsToSetAction)
{
[_view setAction: action];
}
}
- (void)setEnabled: (BOOL)enabled
{
enabled = _enabled;
if(_flags.viewRespondsToSetEnabled)
{
[_view setEnabled: enabled];
}
}
- (void)setImage: (NSImage *)image
{
ASSIGN(_image, image);
if(_flags.viewRespondsToSetImage)
{
[_view setImage: image];
}
}
- (void)setLabel: (NSString *)label
@ -128,12 +145,18 @@
- (void)setTag: (int)tag
{
_tag = tag;
if(_flags.viewRespondsToTag)
{
[_view setTag: tag];
}
}
- (void)setTarget: (id)target
{
ASSIGN(_target, target);
{
if(_flags.viewRespondsToTarget)
{
[_view setTarget: target];
}
}
- (void)setToolTip: (NSString *)toolTip
@ -144,11 +167,27 @@
- (void)setView: (NSView *)view
{
ASSIGN(_view, view);
// gets
_flags.viewRespondsToIsEnabled = [_view respondsToSelector: @selector(isEnabled)];
_flags.viewRespondsToTag = [_view respondsToSelector: @selector(tag)];
_flags.viewRespondsToAction = [_view respondsToSelector: @selector(action)];
_flags.viewRespondsToTarget = [_view respondsToSelector: @selector(target)];
_flags.viewRespondsToImage = [_view respondsToSelector: @selector(image)];
// sets
_flags.viewRespondsToSetEnabled = [_view respondsToSelector: @selector(setEnabled:)];
_flags.viewRespondsToSetTag = [_view respondsToSelector: @selector(setTag:)];
_flags.viewRespondsToSetAction = [_view respondsToSelector: @selector(setAction:)];
_flags.viewRespondsToSetTarget = [_view respondsToSelector: @selector(setTarget:)];
_flags.viewRespondsToSetImage = [_view respondsToSelector: @selector(setImage:)];
}
- (int)tag
{
return _tag;
if(_flags.viewRespondsToTag)
{
return [_view tag];
}
return 0;
}
- (NSString *)toolTip
@ -165,7 +204,6 @@
{
// validate by default, we know that all of the
// "standard" items are correct.
_enabled = YES;
}
- (NSView *)view
@ -176,12 +214,20 @@
// NSValidatedUserInterfaceItem protocol
- (SEL)action
{
return _action;
if(_flags.viewRespondsToAction)
{
return [_view action];
}
return 0;
}
- (id)target
{
return _target;
if(_flags.viewRespondsToTarget)
{
return [_view target];
}
return nil;
}
// NSCopying protocol