X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2b030203c5926bd6af8bc310469c911f2143f7e1..e733c4ce1e24cf7e4b0b0d8362fc59aaa7a7641c:/src/cocoa/NSButton.mm?ds=sidebyside diff --git a/src/cocoa/NSButton.mm b/src/cocoa/NSButton.mm index 63cf30df2f..3e0b3ed6fe 100644 --- a/src/cocoa/NSButton.mm +++ b/src/cocoa/NSButton.mm @@ -1,12 +1,11 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: cocoa/NSButton.cpp +// Name: src/cocoa/NSButton.mm // Purpose: wxCocoaNSButton // Author: David Elliott // Modified by: // Created: 2003/01/31 -// RCS-ID: $Id: -// Copyright: (c) 2003 David Elliott -// Licence: wxWindows license +// Copyright: (c) 2003-2004 David Elliott +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// // ============================================================================ @@ -22,8 +21,7 @@ #include "wx/log.h" #endif // WX_PRECOMP -#include "wx/cocoa/ObjcPose.h" - +#include "wx/cocoa/objc/objc_uniquifying.h" #include "wx/cocoa/NSButton.h" #import @@ -33,34 +31,38 @@ WX_IMPLEMENT_OBJC_INTERFACE_HASHMAP(NSButton) // ============================================================================ -// @class wxPoserNSButton +// @class wxNSButtonTarget // ============================================================================ -@interface wxPoserNSButton : NSButton +@interface wxNSButtonTarget : NSObject { } - (void)wxNSButtonAction: (id)sender; -@end // wxPoserNSButton - -WX_IMPLEMENT_POSER(wxPoserNSButton); +@end // wxNSButtonTarget +WX_DECLARE_GET_OBJC_CLASS(wxNSButtonTarget,NSObject) -@implementation wxPoserNSButton : NSButton +@implementation wxNSButtonTarget : NSObject - (void)wxNSButtonAction: (id)sender { - wxASSERT_MSG((id)self==sender,wxT("Received wxNSButtonAction from another object")); - wxCocoaNSButton *button = wxCocoaNSButton::GetFromCocoa(self); + wxCocoaNSButton *button = wxCocoaNSButton::GetFromCocoa(sender); wxCHECK_RET(button,wxT("wxNSButtonAction received without associated wx object")); button->Cocoa_wxNSButtonAction(); } -@end // implementation wxPoserNSButton +@end // implementation wxNSButtonTarget +WX_IMPLEMENT_GET_OBJC_CLASS(wxNSButtonTarget,NSObject) + +// ============================================================================ +// class wxCocoaNSButton +// ============================================================================ +const wxObjcAutoRefFromAlloc wxCocoaNSButton::sm_cocoaTarget = [[WX_GET_OBJC_CLASS(wxNSButtonTarget) alloc] init]; void wxCocoaNSButton::AssociateNSButton(WX_NSButton cocoaNSButton) { if(cocoaNSButton) { sm_cocoaHash.insert(wxCocoaNSButtonHash::value_type(cocoaNSButton,this)); - [cocoaNSButton setTarget: cocoaNSButton]; + [cocoaNSButton setTarget: sm_cocoaTarget]; [cocoaNSButton setAction: @selector(wxNSButtonAction:)]; } }