llSetTimerEvent updated to use ticks instead of DateTime for internal timing.
parent
877713999c
commit
416d752829
|
@ -49,9 +49,9 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
|
|
||||||
string EventName = m_Script.State + "_event_" + FunctionName;
|
string EventName = m_Script.State + "_event_" + FunctionName;
|
||||||
|
|
||||||
#if DEBUG
|
//#if DEBUG
|
||||||
Console.WriteLine("ScriptEngine: Script event function name: " + EventName);
|
// Console.WriteLine("ScriptEngine: Script event function name: " + EventName);
|
||||||
#endif
|
//#endif
|
||||||
|
|
||||||
if (Events.ContainsKey(EventName) == false)
|
if (Events.ContainsKey(EventName) == false)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1244,7 +1244,7 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
{
|
{
|
||||||
m_host.AddScriptLPS(1);
|
m_host.AddScriptLPS(1);
|
||||||
// Setting timer repeat
|
// Setting timer repeat
|
||||||
m_ScriptEngine.m_ASYNCLSLCommandManager.SetTimerEvent(m_localID, m_itemID, sec / 1000);
|
m_ScriptEngine.m_ASYNCLSLCommandManager.SetTimerEvent(m_localID, m_itemID, sec);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void llSleep(double sec)
|
public void llSleep(double sec)
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using libsecondlife;
|
using libsecondlife;
|
||||||
|
@ -128,7 +129,7 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
xmlrpc.DeleteChannels(itemID);
|
xmlrpc.DeleteChannels(itemID);
|
||||||
|
|
||||||
xmlrpc.CancelSRDRequests(itemID);
|
xmlrpc.CancelSRDRequests(itemID);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#region TIMER
|
#region TIMER
|
||||||
|
@ -140,8 +141,10 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
{
|
{
|
||||||
public uint localID;
|
public uint localID;
|
||||||
public LLUUID itemID;
|
public LLUUID itemID;
|
||||||
public double interval;
|
//public double interval;
|
||||||
public DateTime next;
|
public long interval;
|
||||||
|
//public DateTime next;
|
||||||
|
public long next;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<TimerClass> Timers = new List<TimerClass>();
|
private List<TimerClass> Timers = new List<TimerClass>();
|
||||||
|
@ -160,8 +163,12 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
TimerClass ts = new TimerClass();
|
TimerClass ts = new TimerClass();
|
||||||
ts.localID = m_localID;
|
ts.localID = m_localID;
|
||||||
ts.itemID = m_itemID;
|
ts.itemID = m_itemID;
|
||||||
ts.interval = sec / 1000;
|
ts.interval = Convert.ToInt64(sec * 10000000); // How many 100 nanoseconds (ticks) should we wait
|
||||||
ts.next = DateTime.Now.ToUniversalTime().AddSeconds(ts.interval);
|
// 2193386136332921 ticks
|
||||||
|
// 219338613 seconds
|
||||||
|
|
||||||
|
//ts.next = DateTime.Now.ToUniversalTime().AddSeconds(ts.interval);
|
||||||
|
ts.next = DateTime.Now.Ticks + ts.interval;
|
||||||
lock (TimerListLock)
|
lock (TimerListLock)
|
||||||
{
|
{
|
||||||
Timers.Add(ts);
|
Timers.Add(ts);
|
||||||
|
@ -173,17 +180,25 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
// Remove from timer
|
// Remove from timer
|
||||||
lock (TimerListLock)
|
lock (TimerListLock)
|
||||||
{
|
{
|
||||||
List<TimerClass> NewTimers = new List<TimerClass>();
|
foreach (TimerClass ts in new ArrayList(Timers))
|
||||||
foreach (TimerClass ts in Timers)
|
|
||||||
{
|
{
|
||||||
if (ts.localID != m_localID && ts.itemID != m_itemID)
|
if (ts.localID == m_localID && ts.itemID == m_itemID)
|
||||||
{
|
Timers.Remove(ts);
|
||||||
NewTimers.Add(ts);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Timers.Clear();
|
|
||||||
Timers = NewTimers;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Old method: Create new list
|
||||||
|
//List<TimerClass> NewTimers = new List<TimerClass>();
|
||||||
|
//foreach (TimerClass ts in Timers)
|
||||||
|
//{
|
||||||
|
// if (ts.localID != m_localID && ts.itemID != m_itemID)
|
||||||
|
// {
|
||||||
|
// NewTimers.Add(ts);
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
//Timers.Clear();
|
||||||
|
//Timers = NewTimers;
|
||||||
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void CheckTimerEvents()
|
public void CheckTimerEvents()
|
||||||
|
@ -198,15 +213,17 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
foreach (TimerClass ts in Timers)
|
foreach (TimerClass ts in Timers)
|
||||||
{
|
{
|
||||||
// Time has passed?
|
// Time has passed?
|
||||||
if (ts.next.ToUniversalTime() < DateTime.Now.ToUniversalTime())
|
if (ts.next < DateTime.Now.Ticks)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
Console.WriteLine("Time has passed: Now: " + DateTime.Now.Ticks + ", Passed: " + ts.next);
|
||||||
// Add it to queue
|
// Add it to queue
|
||||||
m_ScriptEngine.m_EventQueueManager.AddToScriptQueue(ts.localID, ts.itemID, "timer", EventQueueManager.llDetectNull,
|
m_ScriptEngine.m_EventQueueManager.AddToScriptQueue(ts.localID, ts.itemID, "timer", EventQueueManager.llDetectNull,
|
||||||
new object[] {});
|
null);
|
||||||
// set next interval
|
// set next interval
|
||||||
|
|
||||||
|
//ts.next = DateTime.Now.ToUniversalTime().AddSeconds(ts.interval);
|
||||||
ts.next = DateTime.Now.ToUniversalTime().AddSeconds(ts.interval);
|
ts.next = DateTime.Now.Ticks + ts.interval;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // lock
|
} // lock
|
||||||
|
@ -322,7 +339,7 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -356,7 +373,7 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue