change ubOde module, hopefully for better handling of multiple scenes on same instance. ( may be broken now )

LSLKeyTest
UbitUmarov 2016-06-29 14:14:16 +01:00
parent 158e0ae402
commit ea140d7cac
1 changed files with 35 additions and 25 deletions

View File

@ -1,4 +1,5 @@
using System; using System;
using System.Collections.Generic;
using System.Reflection; using System.Reflection;
using log4net; using log4net;
using Nini.Config; using Nini.Config;
@ -15,10 +16,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde
{ {
private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
private static Dictionary<Scene, ODEScene> m_scenes = new Dictionary<Scene, ODEScene>();
private bool m_Enabled = false; private bool m_Enabled = false;
private IConfigSource m_config; private IConfigSource m_config;
private ODEScene m_scene;
private bool OSOdeLib; private bool OSOdeLib;
#region INonSharedRegionModule #region INonSharedRegionModule
@ -42,6 +44,22 @@ namespace OpenSim.Region.PhysicsModule.ubOde
{ {
m_config = source; m_config = source;
m_Enabled = true; m_Enabled = true;
if (Util.IsWindows())
Util.LoadArchSpecificWindowsDll("ode.dll");
d.InitODE();
string ode_config = d.GetConfiguration();
if (ode_config != null && ode_config != "")
{
m_log.InfoFormat("[ubODE] ode library configuration: {0}", ode_config);
if (ode_config.Contains("ODE_OPENSIM"))
{
OSOdeLib = true;
}
}
} }
} }
} }
@ -55,42 +73,34 @@ namespace OpenSim.Region.PhysicsModule.ubOde
if (!m_Enabled) if (!m_Enabled)
return; return;
if (Util.IsWindows()) if(m_scenes.ContainsKey(scene)) // ???
Util.LoadArchSpecificWindowsDll("ode.dll"); return;
ODEScene newodescene = new ODEScene(scene, m_config, Name, OSOdeLib);
// Initializing ODE only when a scene is created allows alternative ODE plugins to co-habit (according to m_scenes[scene] = newodescene;
// http://opensimulator.org/mantis/view.php?id=2750).
d.InitODE();
string ode_config = d.GetConfiguration();
if (ode_config != null && ode_config != "")
{
m_log.InfoFormat("[ubODE] ode library configuration: {0}", ode_config);
// ubODE still not avaiable
if (ode_config.Contains("ODE_OPENSIM"))
{
OSOdeLib = true;
}
}
m_scene = new ODEScene(scene, m_config, Name, OSOdeLib);
} }
public void RemoveRegion(Scene scene) public void RemoveRegion(Scene scene)
{ {
if (!m_Enabled || m_scene == null) if (!m_Enabled)
return; return;
m_scene.Dispose(); // a odescene.dispose is called later directly by scene.cs
m_scene = null; // since it is seen as a module interface
if(m_scenes.ContainsKey(scene))
m_scenes.Remove(scene);
} }
public void RegionLoaded(Scene scene) public void RegionLoaded(Scene scene)
{ {
if (!m_Enabled || m_scene == null) if (!m_Enabled)
return; return;
if(m_scenes.ContainsKey(scene))
{
m_scenes[scene].RegionLoaded();
}
m_scene.RegionLoaded();
} }
#endregion #endregion
} }