diff options
Diffstat (limited to 'OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs')
-rw-r--r-- | OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs | 60 |
1 files changed, 35 insertions, 25 deletions
diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs b/OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs index bd66b4d..dd1c0ab 100644 --- a/OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs +++ b/OpenSim/Region/PhysicsModules/ubOde/ODEModule.cs | |||
@@ -1,4 +1,5 @@ | |||
1 | using System; | 1 | using System; |
2 | using System.Collections.Generic; | ||
2 | using System.Reflection; | 3 | using System.Reflection; |
3 | using log4net; | 4 | using log4net; |
4 | using Nini.Config; | 5 | using Nini.Config; |
@@ -15,10 +16,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde | |||
15 | { | 16 | { |
16 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 17 | private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
17 | 18 | ||
19 | private static Dictionary<Scene, ODEScene> m_scenes = new Dictionary<Scene, ODEScene>(); | ||
18 | private bool m_Enabled = false; | 20 | private bool m_Enabled = false; |
19 | private IConfigSource m_config; | 21 | private IConfigSource m_config; |
20 | private ODEScene m_scene; | ||
21 | private bool OSOdeLib; | 22 | private bool OSOdeLib; |
23 | |||
22 | 24 | ||
23 | #region INonSharedRegionModule | 25 | #region INonSharedRegionModule |
24 | 26 | ||
@@ -42,6 +44,22 @@ namespace OpenSim.Region.PhysicsModule.ubOde | |||
42 | { | 44 | { |
43 | m_config = source; | 45 | m_config = source; |
44 | m_Enabled = true; | 46 | m_Enabled = true; |
47 | |||
48 | if (Util.IsWindows()) | ||
49 | Util.LoadArchSpecificWindowsDll("ode.dll"); | ||
50 | |||
51 | d.InitODE(); | ||
52 | |||
53 | string ode_config = d.GetConfiguration(); | ||
54 | if (ode_config != null && ode_config != "") | ||
55 | { | ||
56 | m_log.InfoFormat("[ubODE] ode library configuration: {0}", ode_config); | ||
57 | |||
58 | if (ode_config.Contains("ODE_OPENSIM")) | ||
59 | { | ||
60 | OSOdeLib = true; | ||
61 | } | ||
62 | } | ||
45 | } | 63 | } |
46 | } | 64 | } |
47 | } | 65 | } |
@@ -55,42 +73,34 @@ namespace OpenSim.Region.PhysicsModule.ubOde | |||
55 | if (!m_Enabled) | 73 | if (!m_Enabled) |
56 | return; | 74 | return; |
57 | 75 | ||
58 | if (Util.IsWindows()) | 76 | if(m_scenes.ContainsKey(scene)) // ??? |
59 | Util.LoadArchSpecificWindowsDll("ode.dll"); | 77 | return; |
60 | 78 | ODEScene newodescene = new ODEScene(scene, m_config, Name, OSOdeLib); | |
61 | // Initializing ODE only when a scene is created allows alternative ODE plugins to co-habit (according to | 79 | m_scenes[scene] = newodescene; |
62 | // http://opensimulator.org/mantis/view.php?id=2750). | ||
63 | d.InitODE(); | ||
64 | |||
65 | string ode_config = d.GetConfiguration(); | ||
66 | if (ode_config != null && ode_config != "") | ||
67 | { | ||
68 | m_log.InfoFormat("[ubODE] ode library configuration: {0}", ode_config); | ||
69 | // ubODE still not avaiable | ||
70 | if (ode_config.Contains("ODE_OPENSIM")) | ||
71 | { | ||
72 | OSOdeLib = true; | ||
73 | } | ||
74 | } | ||
75 | |||
76 | m_scene = new ODEScene(scene, m_config, Name, OSOdeLib); | ||
77 | } | 80 | } |
78 | 81 | ||
79 | public void RemoveRegion(Scene scene) | 82 | public void RemoveRegion(Scene scene) |
80 | { | 83 | { |
81 | if (!m_Enabled || m_scene == null) | 84 | if (!m_Enabled) |
82 | return; | 85 | return; |
83 | 86 | ||
84 | m_scene.Dispose(); | 87 | // a odescene.dispose is called later directly by scene.cs |
85 | m_scene = null; | 88 | // since it is seen as a module interface |
89 | |||
90 | if(m_scenes.ContainsKey(scene)) | ||
91 | m_scenes.Remove(scene); | ||
86 | } | 92 | } |
87 | 93 | ||
88 | public void RegionLoaded(Scene scene) | 94 | public void RegionLoaded(Scene scene) |
89 | { | 95 | { |
90 | if (!m_Enabled || m_scene == null) | 96 | if (!m_Enabled) |
91 | return; | 97 | return; |
98 | |||
99 | if(m_scenes.ContainsKey(scene)) | ||
100 | { | ||
101 | m_scenes[scene].RegionLoaded(); | ||
102 | } | ||
92 | 103 | ||
93 | m_scene.RegionLoaded(); | ||
94 | } | 104 | } |
95 | #endregion | 105 | #endregion |
96 | } | 106 | } |