* MRM Scripts will now no longer disconnect the client if there was an error in compilation or script initialisation.
* Clarified some debug text for MRM Enabling0.6.5-rc1
parent
7e91f41535
commit
36bc485e7e
|
@ -35,6 +35,7 @@ using log4net;
|
||||||
using Microsoft.CSharp;
|
using Microsoft.CSharp;
|
||||||
using Nini.Config;
|
using Nini.Config;
|
||||||
using OpenMetaverse;
|
using OpenMetaverse;
|
||||||
|
using OpenSim.Framework;
|
||||||
using OpenSim.Region.Framework.Interfaces;
|
using OpenSim.Region.Framework.Interfaces;
|
||||||
using OpenSim.Region.Framework.Scenes;
|
using OpenSim.Region.Framework.Scenes;
|
||||||
|
|
||||||
|
@ -61,12 +62,12 @@ namespace OpenSim.Region.OptionalModules.Scripting.Minimodule
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_log.Info("[MRM] Disabled MRM Module (Express)");
|
m_log.Info("[MRM] Disabled MRM Module (Disabled in ini)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_log.Info("[MRM] Disabled MRM Module (Omission)");
|
m_log.Info("[MRM] Disabled MRM Module (Default disabled)");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -74,19 +75,30 @@ namespace OpenSim.Region.OptionalModules.Scripting.Minimodule
|
||||||
{
|
{
|
||||||
if (script.StartsWith("//MiniMod:C#"))
|
if (script.StartsWith("//MiniMod:C#"))
|
||||||
{
|
{
|
||||||
m_log.Info("[MRM] Found C# MRM");
|
try
|
||||||
IWorld m_world = new World(m_scene);
|
{
|
||||||
IHost m_host = new Host(new SOPObject(m_scene, localID));
|
m_log.Info("[MRM] Found C# MRM");
|
||||||
|
IWorld m_world = new World(m_scene);
|
||||||
|
IHost m_host = new Host(new SOPObject(m_scene, localID));
|
||||||
|
|
||||||
MRMBase mmb = (MRMBase) AppDomain.CurrentDomain.CreateInstanceFromAndUnwrap(
|
MRMBase mmb = (MRMBase)AppDomain.CurrentDomain.CreateInstanceFromAndUnwrap(
|
||||||
CompileFromDotNetText(script, itemID.ToString()),
|
CompileFromDotNetText(script, itemID.ToString()),
|
||||||
"OpenSim.MiniModule");
|
"OpenSim.MiniModule");
|
||||||
m_log.Info("[MRM] Created MRM Instance");
|
m_log.Info("[MRM] Created MRM Instance");
|
||||||
mmb.InitMiniModule(m_world, m_host, itemID);
|
mmb.InitMiniModule(m_world, m_host, itemID);
|
||||||
m_scripts[itemID] = mmb;
|
m_scripts[itemID] = mmb;
|
||||||
|
|
||||||
m_log.Info("[MRM] Starting MRM");
|
m_log.Info("[MRM] Starting MRM");
|
||||||
mmb.Start();
|
mmb.Start();
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
m_scene.Broadcast(delegate(IClientAPI user)
|
||||||
|
{
|
||||||
|
user.SendAlertMessage(
|
||||||
|
"MiniRegionModule Compilation and Initialisation failed: " + e);
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue