From f2d60976d0875c47398ff76ef9de192cc8f3fb02 Mon Sep 17 00:00:00 2001
From: Charles Krinke
Date: Sun, 14 Sep 2008 00:47:45 +0000
Subject: Mantis#2183. Thank you kindly, Ewe Loon for a patch that addresses:
after using llTakeControls my sim receives about 200 messages per second, l
of which get queued , this could be because there is no lag as the viewer and
sim are on the same computer. The patch I have included checks to see if the
"Changed" param is 0 then searches the EventQueue for Control messages being
sent to the same localid, if it finds a message already in the Queue and
Changed==0 then the new message is only notifing you the key is being held,
since there is already a message the new one isnt needed so it isnt added to
the queue.
---
.../Common/ScriptEngineBase/EventQueueManager.cs | 25 ++++++++++++++++++++++
1 file changed, 25 insertions(+)
(limited to 'OpenSim/Region/ScriptEngine/Common/ScriptEngineBase/EventQueueManager.cs')
diff --git a/OpenSim/Region/ScriptEngine/Common/ScriptEngineBase/EventQueueManager.cs b/OpenSim/Region/ScriptEngine/Common/ScriptEngineBase/EventQueueManager.cs
index 1a08795..af7fca3 100644
--- a/OpenSim/Region/ScriptEngine/Common/ScriptEngineBase/EventQueueManager.cs
+++ b/OpenSim/Region/ScriptEngine/Common/ScriptEngineBase/EventQueueManager.cs
@@ -288,6 +288,31 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
}
}
#endregion
+
+ #region " Check execution queue for a specified Event"
+ ///
+ /// checks to see if a specified event type is already in the queue
+ ///
+ /// Region object ID
+ /// Name of the function, will be state + "_event_" + FunctionName
+ /// true if event is found , false if not found
+ ///
+ public bool CheckEeventQueueForEvent(uint localID, string FunctionName)
+ {
+ if (eventQueue.Count > 0)
+ {
+ lock (eventQueue)
+ {
+ foreach (EventQueueManager.QueueItemStruct QIS in eventQueue)
+ {
+ if ((QIS.functionName == FunctionName) && (QIS.localID == localID))
+ return true;
+ }
+ }
+ }
+ return false;
+ }
+ #endregion
#region " Add events to execution queue "
///
--
cgit v1.1