{
private global::System.Runtime.InteropServices.HandleRef swigCPtr;
+ private bool played = false;
+ private string stackTrace;
+
internal Timer(global::System.IntPtr cPtr, bool cMemoryOwn) : base(NDalicPINVOKE.Timer_SWIGUpcast(cPtr), cMemoryOwn)
{
swigCPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
Tizen.Log.Fatal("NUI", $"Timer() disposed with dali timer! swigCPtr={swigCPtr.Handle}, current thread id={Thread.CurrentThread.ManagedThreadId}, main thread id={Registry.Instance.SavedApplicationThread.ManagedThreadId}");
}
+ played = false;
base.Dispose(type);
}
{
if (_timerTickEventHandler == null)
{
- _timerTickCallbackDelegate = (OnTick);
+ _timerTickCallbackDelegate = new TickCallbackDelegate(OnTick);
TickSignal().Connect(_timerTickCallbackDelegate);
}
_timerTickEventHandler += value;
{
TickEventArgs e = new TickEventArgs();
- if (_timerTickEventHandler != null)
+ if (played == false)
+ {
+ Tizen.Log.Fatal("NUI", $"should not be here! OnTick()!swigCPtr={swigCPtr.Handle}");
+ Tizen.Log.Fatal("NUI", "should not be here! #################### TID = " + global::System.Threading.Thread.CurrentThread.ManagedThreadId);
+ Tizen.Log.Fatal("NUI", stackTrace);
+ }
+
+ if (_timerTickEventHandler != null && played == true)
{
//here we send all data to user event handlers
return _timerTickEventHandler(this, e);
/// <since_tizen> 3 </since_tizen>
public Timer(uint milliSec) : this(NDalicPINVOKE.Timer_New(milliSec), true)
{
- Tizen.Log.Fatal("NUI", $"Timer({milliSec}) created! swigCPtr={swigCPtr.Handle}, current thread id={Thread.CurrentThread.ManagedThreadId}, main thread id={Registry.Instance.SavedApplicationThread.ManagedThreadId}");
+ stackTrace = Environment.StackTrace;
if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
}
/// <since_tizen> 3 </since_tizen>
public void Start()
{
+ played = true;
NDalicPINVOKE.Timer_Start(swigCPtr);
- Tizen.Log.Fatal("NUI", $"Timer() start! swigCPtr={swigCPtr.Handle}, current thread id={Thread.CurrentThread.ManagedThreadId}, main thread id={Registry.Instance.SavedApplicationThread?.ManagedThreadId}");
-
if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
}
/// <since_tizen> 3 </since_tizen>
public void Stop()
{
+ played = false;
NDalicPINVOKE.Timer_Stop(swigCPtr);
- Tizen.Log.Fatal("NUI", $"Timer() stop! swigCPtr={swigCPtr.Handle}, current thread id={Thread.CurrentThread.ManagedThreadId}, main thread id={Registry.Instance.SavedApplicationThread?.ManagedThreadId}");
-
if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
}
}
-}
\ No newline at end of file
+}
+