From 833f5e8bed5b36501c4579859e380038400ecb75 Mon Sep 17 00:00:00 2001
From: Melanie Thielker
Date: Sat, 8 Nov 2008 02:24:34 +0000
Subject: Refactor IEventReceiver back into IScriptEngine
---
OpenSim/Region/Environment/Scenes/Scene.cs | 2 +
.../ScriptEngine/DotNetEngine/ScriptEngine.cs | 17 +++++-
.../ScriptEngine/Interfaces/IEventReceiver.cs | 71 ----------------------
.../Region/ScriptEngine/Interfaces/IScriptApi.cs | 2 +-
.../ScriptEngine/Interfaces/IScriptEngine.cs | 31 +++++++++-
.../ScriptEngine/Interfaces/IScriptInstance.cs | 3 +
.../Api/Implementation/AsyncCommandManager.cs | 42 ++++++-------
.../Shared/Api/Implementation/LSL_Api.cs | 4 +-
.../Shared/Api/Implementation/OSSL_Api.cs | 4 +-
.../Api/Implementation/Plugins/HttpRequest.cs | 2 +-
.../Shared/Api/Implementation/Plugins/Listener.cs | 2 +-
.../Api/Implementation/Plugins/XmlRequest.cs | 4 +-
.../ScriptEngine/Shared/CodeTools/Compiler.cs | 4 +-
.../ScriptEngine/Shared/Instance/ScriptInstance.cs | 11 ++++
OpenSim/Region/ScriptEngine/XEngine/XEngine.cs | 16 +++++
15 files changed, 110 insertions(+), 105 deletions(-)
delete mode 100644 OpenSim/Region/ScriptEngine/Interfaces/IEventReceiver.cs
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs
index 4b8df37..ab2b336 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.cs
@@ -2100,6 +2100,8 @@ namespace OpenSim.Region.Environment.Scenes
SceneObjectGroup sceneObject = m_serialiser.DeserializeGroupFromXml2(objXMLData);
AddRestoredSceneObject(sceneObject, true, false);
+ sceneObject.CreateScriptInstances(0, false, DefaultScriptEngine);
+
SceneObjectPart RootPrim = GetSceneObjectPart(primID);
if (RootPrim != null)
{
diff --git a/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs b/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs
index 9911fec..269afaa 100644
--- a/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs
+++ b/OpenSim/Region/ScriptEngine/DotNetEngine/ScriptEngine.cs
@@ -44,7 +44,7 @@ using OpenSim.Region.ScriptEngine.Shared.ScriptBase;
namespace OpenSim.Region.ScriptEngine.DotNetEngine
{
[Serializable]
- public class ScriptEngine : IRegionModule, IEventReceiver, IScriptModule
+ public class ScriptEngine : IRegionModule, IScriptEngine, IScriptModule
{
private static readonly ILog m_log =
LogManager.GetLogger(
@@ -388,5 +388,20 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine
{
return m_ScriptManager.GetApi(itemID, name);
}
+
+ public IScriptWorkItem QueueEventHandler(Object o)
+ {
+ return null;
+ }
+
+ public string GetAssemblyName(UUID itemID)
+ {
+ return "";
+ }
+
+ public string GetXMLState(UUID itemID)
+ {
+ return "";
+ }
}
}
diff --git a/OpenSim/Region/ScriptEngine/Interfaces/IEventReceiver.cs b/OpenSim/Region/ScriptEngine/Interfaces/IEventReceiver.cs
deleted file mode 100644
index 898d670..0000000
--- a/OpenSim/Region/ScriptEngine/Interfaces/IEventReceiver.cs
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * Copyright (c) Contributors, http://opensimulator.org/
- * See CONTRIBUTORS.TXT for a full list of copyright holders.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above copyright
- * notice, this list of conditions and the following disclaimer in the
- * documentation and/or other materials provided with the distribution.
- * * Neither the name of the OpenSim Project nor the
- * names of its contributors may be used to endorse or promote products
- * derived from this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
- * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
- * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
- * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
- * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
- * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- */
-
-using log4net;
-using System;
-using OpenSim.Region.ScriptEngine.Shared;
-using OpenSim.Region.Environment.Scenes;
-using OpenMetaverse;
-using Nini.Config;
-using OpenSim.Region.ScriptEngine.Interfaces;
-using Amib.Threading;
-using OpenSim.Framework;
-
-namespace OpenSim.Region.ScriptEngine.Interfaces
-{
- ///
- /// An interface for a script API module to communicate with
- /// the engine it's running under
- ///
- public interface IEventReceiver
- {
- Scene World { get; }
-
- ///
- /// Post an event to a single script
- ///
- bool PostScriptEvent(UUID itemID, EventParams parms);
-
- ///
- /// Post event to an entire prim
- ///
- bool PostObjectEvent(uint localID, EventParams parms);
-
- DetectParams GetDetectParams(UUID item, int number);
- int GetStartParameter(UUID itemID);
-
- void SetScriptState(UUID itemID, bool state);
- bool GetScriptState(UUID itemID);
- void SetState(UUID itemID, string newState);
- void ApiResetScript(UUID itemID);
- void ResetScript(UUID itemID);
- IConfig Config { get; }
- string ScriptEngineName { get; }
- ILog Log { get; }
- IScriptApi GetApi(UUID itemID, string name);
- }
-}
diff --git a/OpenSim/Region/ScriptEngine/Interfaces/IScriptApi.cs b/OpenSim/Region/ScriptEngine/Interfaces/IScriptApi.cs
index 13f043d..e94de68 100644
--- a/OpenSim/Region/ScriptEngine/Interfaces/IScriptApi.cs
+++ b/OpenSim/Region/ScriptEngine/Interfaces/IScriptApi.cs
@@ -38,6 +38,6 @@ namespace OpenSim.Region.ScriptEngine.Interfaces
// Each API has an identifier, which is used to load the
// proper runtime assembly at load time.
//
- void Initialize(IEventReceiver engine, SceneObjectPart part, uint localID, UUID item);
+ void Initialize(IScriptEngine engine, SceneObjectPart part, uint localID, UUID item);
}
}
diff --git a/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs b/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs
index 5bd2f79..29b83dc 100644
--- a/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs
+++ b/OpenSim/Region/ScriptEngine/Interfaces/IScriptEngine.cs
@@ -33,6 +33,7 @@ using OpenMetaverse;
using Nini.Config;
using OpenSim.Region.ScriptEngine.Interfaces;
using Amib.Threading;
+using OpenSim.Framework;
namespace OpenSim.Region.ScriptEngine.Interfaces
{
@@ -40,11 +41,39 @@ namespace OpenSim.Region.ScriptEngine.Interfaces
/// An interface for a script API module to communicate with
/// the engine it's running under
///
- public interface IScriptEngine : IEventReceiver
+ public interface IScriptEngine
{
///
/// Queue an event for execution
///
IScriptWorkItem QueueEventHandler(object parms);
+
+ Scene World { get; }
+
+ ///
+ /// Post an event to a single script
+ ///
+ bool PostScriptEvent(UUID itemID, EventParams parms);
+
+ ///
+ /// Post event to an entire prim
+ ///
+ bool PostObjectEvent(uint localID, EventParams parms);
+
+ DetectParams GetDetectParams(UUID item, int number);
+ int GetStartParameter(UUID itemID);
+
+ void SetScriptState(UUID itemID, bool state);
+ bool GetScriptState(UUID itemID);
+ void SetState(UUID itemID, string newState);
+ void ApiResetScript(UUID itemID);
+ void ResetScript(UUID itemID);
+ IConfig Config { get; }
+ string ScriptEngineName { get; }
+ ILog Log { get; }
+ IScriptApi GetApi(UUID itemID, string name);
+
+ string GetAssemblyName(UUID itemID);
+ string GetXMLState(UUID itemID);
}
}
diff --git a/OpenSim/Region/ScriptEngine/Interfaces/IScriptInstance.cs b/OpenSim/Region/ScriptEngine/Interfaces/IScriptInstance.cs
index dee7970..508e00f 100644
--- a/OpenSim/Region/ScriptEngine/Interfaces/IScriptInstance.cs
+++ b/OpenSim/Region/ScriptEngine/Interfaces/IScriptInstance.cs
@@ -99,5 +99,8 @@ namespace OpenSim.Region.ScriptEngine.Interfaces
Dictionary, KeyValuePair> LineMap
{ get; set; }
+
+ string GetAssemblyName();
+ string GetXMLState();
}
}
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/AsyncCommandManager.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/AsyncCommandManager.cs
index c828d69..71a8d0f 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/AsyncCommandManager.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/AsyncCommandManager.cs
@@ -48,24 +48,24 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
private static int cmdHandlerThreadCycleSleepms;
private static List m_Scenes = new List();
- private static List m_ScriptEngines =
- new List();
+ private static List m_ScriptEngines =
+ new List();
- public IEventReceiver m_ScriptEngine;
+ public IScriptEngine m_ScriptEngine;
private IScene m_Scene;
- private static Dictionary m_Dataserver =
- new Dictionary();
- private static Dictionary m_Timer =
- new Dictionary();
- private static Dictionary m_Listener =
- new Dictionary();
- private static Dictionary m_HttpRequest =
- new Dictionary();
- private static Dictionary m_SensorRepeat =
- new Dictionary();
- private static Dictionary m_XmlRequest =
- new Dictionary();
+ private static Dictionary m_Dataserver =
+ new Dictionary();
+ private static Dictionary m_Timer =
+ new Dictionary();
+ private static Dictionary m_Listener =
+ new Dictionary();
+ private static Dictionary m_HttpRequest =
+ new Dictionary();
+ private static Dictionary m_SensorRepeat =
+ new Dictionary();
+ private static Dictionary m_XmlRequest =
+ new Dictionary();
public Dataserver DataserverPlugin
{
@@ -97,12 +97,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
get { return m_XmlRequest[m_ScriptEngine]; }
}
- public IEventReceiver[] ScriptEngines
+ public IScriptEngine[] ScriptEngines
{
get { return m_ScriptEngines.ToArray(); }
}
- public AsyncCommandManager(IEventReceiver _ScriptEngine)
+ public AsyncCommandManager(IScriptEngine _ScriptEngine)
{
m_ScriptEngine = _ScriptEngine;
m_Scene = m_ScriptEngine.World;
@@ -202,7 +202,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
// Check XMLRPCRequests
m_XmlRequest[m_ScriptEngines[0]].CheckXMLRPCRequests();
- foreach (IEventReceiver s in m_ScriptEngines)
+ foreach (IScriptEngine s in m_ScriptEngines)
{
// Check Listeners
m_Listener[s].CheckListeners();
@@ -223,7 +223,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
///
///
///
- public static void RemoveScript(IEventReceiver engine, uint localID, UUID itemID)
+ public static void RemoveScript(IScriptEngine engine, uint localID, UUID itemID)
{
// Remove a specific script
@@ -250,7 +250,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
}
- public static Object[] GetSerializationData(IEventReceiver engine, UUID itemID)
+ public static Object[] GetSerializationData(IScriptEngine engine, UUID itemID)
{
List