// Name: src/cocoa/timer.mm
// Purpose: wxTimer for wxCocoa
// Author: Ryan Norton
-// Modified by:
+// Modified by: David Elliott
// Created: 2005-02-04
// RCS-ID: $Id$
// Copyright: (c) Ryan Norton
#include "wx/timer.h"
#endif
+#include "wx/cocoa/autorelease.h"
+
#import <Foundation/NSTimer.h>
// ============================================================================
IMPLEMENT_CLASS(wxTimer, wxTimerBase)
-// ========================================================================
-// wxNSTimerDelegate
-// ========================================================================
-@interface wxNSTimerDelegate : NSObject
-{
-}
-
-- (void)onNotify:(NSTimer *)theTimer;
-@end // interface wxNSTimerDelegate : NSObject
-
// ========================================================================
// wxNSTimerData
// ========================================================================
wxTimer* m_timer;
}
-- (id)setTimer:(wxTimer*)theTimer;
+- (id)init;
+- (id)initWithWxTimer:(wxTimer*)theTimer;
- (wxTimer*)timer;
+- (void)onNotify:(NSTimer *)theTimer;
@end // interface wxNSTimerData : NSObject
@implementation wxNSTimerData : NSObject
-- (id)setTimer:(wxTimer*)theTimer;
+- (id)init
{
+ if(!(self = [super init]))
+ return nil;
+ m_timer = NULL;
+ return self;
+}
+
+- (id)initWithWxTimer:(wxTimer*)theTimer;
+{
+ if(!(self = [super init]))
+ return nil;
m_timer = theTimer;
return self;
}
+
- (wxTimer*)timer
{
return m_timer;
}
-@end
-@implementation wxNSTimerDelegate : NSObject
- (void)onNotify:(NSTimer *)theTimer
{
- wxNSTimerData* theData = [theTimer userInfo];
- [theData timer]->Notify(); //wxTimerBase method
+ m_timer->Notify(); //wxTimerBase method
}
@end
// wxTimer
// ----------------------------------------------------------------------------
-const wxObjcAutoRefFromAlloc<struct objc_object*> wxTimer::sm_cocoaDelegate = [[wxNSTimerDelegate alloc] init];
-
wxTimer::~wxTimer()
{
Stop();
bool wxTimer::Start(int millisecs, bool oneShot)
{
+ Stop();
+
+ wxAutoNSAutoreleasePool thePool;
+
+ wxNSTimerData *timerData = [[wxNSTimerData alloc] initWithWxTimer:this];
m_cocoaNSTimer = [[NSTimer
scheduledTimerWithTimeInterval: millisecs / 1000.0 //seconds
- target: wxTimer::sm_cocoaDelegate
+ target: timerData
selector: @selector(onNotify:)
- userInfo: [[wxNSTimerData alloc] setTimer:this]
+ userInfo: nil
repeats: oneShot == false] retain];
+ [timerData release];
return IsRunning();
}
{
if (m_cocoaNSTimer)
{
+ // FIXME: Is this safe to do if !isValid ?
[m_cocoaNSTimer invalidate];
- [[m_cocoaNSTimer userInfo] release];
[m_cocoaNSTimer release];
+ m_cocoaNSTimer = NULL;
}
}