diff options
author | lbsa71 | 2007-09-20 07:49:11 +0000 |
---|---|---|
committer | lbsa71 | 2007-09-20 07:49:11 +0000 |
commit | 14d5a2e9b757c258c6ad15f0939973ef172d2d1f (patch) | |
tree | e0eb78ae9b3d3dfcc1a811b127cdb968b3d625e1 /OpenSim | |
parent | * Rewired Touch to route to group/part (Still triggering EventManager as well) (diff) | |
download | opensim-SC-14d5a2e9b757c258c6ad15f0939973ef172d2d1f.zip opensim-SC-14d5a2e9b757c258c6ad15f0939973ef172d2d1f.tar.gz opensim-SC-14d5a2e9b757c258c6ad15f0939973ef172d2d1f.tar.bz2 opensim-SC-14d5a2e9b757c258c6ad15f0939973ef172d2d1f.tar.xz |
* moved SceneManager to RegionApplicationBase
* Implemented SceneManager.StopScene() and Scene.Stop()
* Some SimpleApping
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/Application/OpenSimMain.cs | 41 | ||||
-rw-r--r-- | OpenSim/Region/ClientStack/RegionApplicationBase.cs | 2 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Scenes/Scene.cs | 7 | ||||
-rw-r--r-- | OpenSim/Region/Environment/Scenes/SceneManager.cs | 6 | ||||
-rw-r--r-- | OpenSim/Region/Examples/SimpleApp/MyNpcCharacter.cs | 11 | ||||
-rw-r--r-- | OpenSim/Region/Examples/SimpleApp/Program.cs | 7 |
6 files changed, 49 insertions, 25 deletions
diff --git a/OpenSim/Region/Application/OpenSimMain.cs b/OpenSim/Region/Application/OpenSimMain.cs index a32b625..66ae987 100644 --- a/OpenSim/Region/Application/OpenSimMain.cs +++ b/OpenSim/Region/Application/OpenSimMain.cs | |||
@@ -67,7 +67,6 @@ namespace OpenSim | |||
67 | 67 | ||
68 | protected List<UDPServer> m_udpServers = new List<UDPServer>(); | 68 | protected List<UDPServer> m_udpServers = new List<UDPServer>(); |
69 | protected List<RegionInfo> m_regionData = new List<RegionInfo>(); | 69 | protected List<RegionInfo> m_regionData = new List<RegionInfo>(); |
70 | protected SceneManager m_localScenes = new SceneManager(); | ||
71 | 70 | ||
72 | private bool m_silent; | 71 | private bool m_silent; |
73 | private readonly string m_logFilename = ("region-console.log"); | 72 | private readonly string m_logFilename = ("region-console.log"); |
@@ -215,7 +214,7 @@ namespace OpenSim | |||
215 | //Server side object editing permissions checking | 214 | //Server side object editing permissions checking |
216 | scene.PermissionsMngr.BypassPermissions = !m_permissions; | 215 | scene.PermissionsMngr.BypassPermissions = !m_permissions; |
217 | 216 | ||
218 | m_localScenes.Add(scene); | 217 | m_sceneManager.Add(scene); |
219 | 218 | ||
220 | m_udpServers.Add(udpServer); | 219 | m_udpServers.Add(udpServer); |
221 | m_regionData.Add(regionInfo); | 220 | m_regionData.Add(regionInfo); |
@@ -332,7 +331,7 @@ namespace OpenSim | |||
332 | // IMPLEMENT THIS | 331 | // IMPLEMENT THIS |
333 | m_log.Verbose("Closing console and terminating"); | 332 | m_log.Verbose("Closing console and terminating"); |
334 | 333 | ||
335 | m_localScenes.Close(); | 334 | m_sceneManager.Close(); |
336 | 335 | ||
337 | m_log.Close(); | 336 | m_log.Close(); |
338 | Environment.Exit(0); | 337 | Environment.Exit(0); |
@@ -377,19 +376,19 @@ namespace OpenSim | |||
377 | switch (command) | 376 | switch (command) |
378 | { | 377 | { |
379 | case "set-time": | 378 | case "set-time": |
380 | m_localScenes.SetCurrentSceneTimePhase(Convert.ToInt32(cmdparams[0])); | 379 | m_sceneManager.SetCurrentSceneTimePhase(Convert.ToInt32(cmdparams[0])); |
381 | break; | 380 | break; |
382 | 381 | ||
383 | case "force-update": | 382 | case "force-update": |
384 | Console.WriteLine("Updating all clients"); | 383 | Console.WriteLine("Updating all clients"); |
385 | m_localScenes.ForceCurrentSceneClientUpdate(); | 384 | m_sceneManager.ForceCurrentSceneClientUpdate(); |
386 | break; | 385 | break; |
387 | 386 | ||
388 | 387 | ||
389 | case "edit-scale": | 388 | case "edit-scale": |
390 | if (cmdparams.Length == 4) | 389 | if (cmdparams.Length == 4) |
391 | { | 390 | { |
392 | m_localScenes.HandleEditCommandOnCurrentScene(cmdparams); | 391 | m_sceneManager.HandleEditCommandOnCurrentScene(cmdparams); |
393 | } | 392 | } |
394 | break; | 393 | break; |
395 | 394 | ||
@@ -427,34 +426,34 @@ namespace OpenSim | |||
427 | case "save-xml": | 426 | case "save-xml": |
428 | if (cmdparams.Length > 0) | 427 | if (cmdparams.Length > 0) |
429 | { | 428 | { |
430 | m_localScenes.SaveCurrentSceneToXml(cmdparams[0]); | 429 | m_sceneManager.SaveCurrentSceneToXml(cmdparams[0]); |
431 | } | 430 | } |
432 | else | 431 | else |
433 | { | 432 | { |
434 | m_localScenes.SaveCurrentSceneToXml(DEFAULT_PRIM_BACKUP_FILENAME); | 433 | m_sceneManager.SaveCurrentSceneToXml(DEFAULT_PRIM_BACKUP_FILENAME); |
435 | } | 434 | } |
436 | break; | 435 | break; |
437 | 436 | ||
438 | case "load-xml": | 437 | case "load-xml": |
439 | if (cmdparams.Length > 0) | 438 | if (cmdparams.Length > 0) |
440 | { | 439 | { |
441 | m_localScenes.LoadCurrentSceneFromXml(cmdparams[0]); | 440 | m_sceneManager.LoadCurrentSceneFromXml(cmdparams[0]); |
442 | } | 441 | } |
443 | else | 442 | else |
444 | { | 443 | { |
445 | m_localScenes.LoadCurrentSceneFromXml(DEFAULT_PRIM_BACKUP_FILENAME); | 444 | m_sceneManager.LoadCurrentSceneFromXml(DEFAULT_PRIM_BACKUP_FILENAME); |
446 | } | 445 | } |
447 | break; | 446 | break; |
448 | 447 | ||
449 | case "terrain": | 448 | case "terrain": |
450 | if (!m_localScenes.RunTerrainCmdOnCurrentScene(cmdparams, ref result)) | 449 | if (!m_sceneManager.RunTerrainCmdOnCurrentScene(cmdparams, ref result)) |
451 | { | 450 | { |
452 | m_log.Error(result); | 451 | m_log.Error(result); |
453 | } | 452 | } |
454 | break; | 453 | break; |
455 | 454 | ||
456 | case "script": | 455 | case "script": |
457 | m_localScenes.SendCommandToCurrentSceneScripts(cmdparams); | 456 | m_sceneManager.SendCommandToCurrentSceneScripts(cmdparams); |
458 | break; | 457 | break; |
459 | 458 | ||
460 | case "command-script": | 459 | case "command-script": |
@@ -468,16 +467,16 @@ namespace OpenSim | |||
468 | // Treats each user as a super-admin when disabled | 467 | // Treats each user as a super-admin when disabled |
469 | bool permissions = Convert.ToBoolean(cmdparams[0]); | 468 | bool permissions = Convert.ToBoolean(cmdparams[0]); |
470 | 469 | ||
471 | m_localScenes.SetBypassPermissionsOnCurrentScene(!permissions); | 470 | m_sceneManager.SetBypassPermissionsOnCurrentScene(!permissions); |
472 | 471 | ||
473 | break; | 472 | break; |
474 | 473 | ||
475 | case "backup": | 474 | case "backup": |
476 | m_localScenes.BackupCurrentScene(); | 475 | m_sceneManager.BackupCurrentScene(); |
477 | break; | 476 | break; |
478 | 477 | ||
479 | case "alert": | 478 | case "alert": |
480 | m_localScenes.HandleAlertCommandOnCurrentScene(cmdparams); | 479 | m_sceneManager.HandleAlertCommandOnCurrentScene(cmdparams); |
481 | break; | 480 | break; |
482 | 481 | ||
483 | case "create": | 482 | case "create": |
@@ -497,7 +496,7 @@ namespace OpenSim | |||
497 | { | 496 | { |
498 | string regionName = this.CombineParams(cmdparams, 0); | 497 | string regionName = this.CombineParams(cmdparams, 0); |
499 | 498 | ||
500 | if (m_localScenes.TrySetCurrentScene(regionName)) | 499 | if (m_sceneManager.TrySetCurrentScene(regionName)) |
501 | { | 500 | { |
502 | 501 | ||
503 | } | 502 | } |
@@ -507,13 +506,13 @@ namespace OpenSim | |||
507 | } | 506 | } |
508 | } | 507 | } |
509 | 508 | ||
510 | if (m_localScenes.CurrentScene == null) | 509 | if (m_sceneManager.CurrentScene == null) |
511 | { | 510 | { |
512 | MainLog.Instance.Verbose("Currently at Root level. To change region please use 'change-region <regioname>'"); | 511 | MainLog.Instance.Verbose("Currently at Root level. To change region please use 'change-region <regioname>'"); |
513 | } | 512 | } |
514 | else | 513 | else |
515 | { | 514 | { |
516 | MainLog.Instance.Verbose("Current Region: " + m_localScenes.CurrentScene.RegionInfo.RegionName + ". To change region please use 'change-region <regioname>'"); | 515 | MainLog.Instance.Verbose("Current Region: " + m_sceneManager.CurrentScene.RegionInfo.RegionName + ". To change region please use 'change-region <regioname>'"); |
517 | } | 516 | } |
518 | 517 | ||
519 | break; | 518 | break; |
@@ -535,7 +534,7 @@ namespace OpenSim | |||
535 | int newDebug; | 534 | int newDebug; |
536 | if (int.TryParse(args[1], out newDebug)) | 535 | if (int.TryParse(args[1], out newDebug)) |
537 | { | 536 | { |
538 | m_localScenes.SetDebugPacketOnCurrentScene(m_log, newDebug); | 537 | m_sceneManager.SetDebugPacketOnCurrentScene(m_log, newDebug); |
539 | } | 538 | } |
540 | else | 539 | else |
541 | { | 540 | { |
@@ -568,11 +567,11 @@ namespace OpenSim | |||
568 | case "users": | 567 | case "users": |
569 | m_log.Error(String.Format("{0,-16}{1,-16}{2,-25}{3,-25}{4,-16}{5,-16}{6,-16}", "Firstname", "Lastname", "Agent ID", "Session ID", "Circuit", "IP", "World")); | 568 | m_log.Error(String.Format("{0,-16}{1,-16}{2,-25}{3,-25}{4,-16}{5,-16}{6,-16}", "Firstname", "Lastname", "Agent ID", "Session ID", "Circuit", "IP", "World")); |
570 | 569 | ||
571 | List<ScenePresence> avatars = m_localScenes.GetCurrentSceneAvatars(); | 570 | List<ScenePresence> avatars = m_sceneManager.GetCurrentSceneAvatars(); |
572 | 571 | ||
573 | foreach (ScenePresence avatar in avatars) | 572 | foreach (ScenePresence avatar in avatars) |
574 | { | 573 | { |
575 | RegionInfo regionInfo = m_localScenes.GetRegionInfo(avatar.RegionHandle); | 574 | RegionInfo regionInfo = m_sceneManager.GetRegionInfo(avatar.RegionHandle); |
576 | string regionName; | 575 | string regionName; |
577 | 576 | ||
578 | if (regionInfo == null) | 577 | if (regionInfo == null) |
diff --git a/OpenSim/Region/ClientStack/RegionApplicationBase.cs b/OpenSim/Region/ClientStack/RegionApplicationBase.cs index 78d551a..df8d747 100644 --- a/OpenSim/Region/ClientStack/RegionApplicationBase.cs +++ b/OpenSim/Region/ClientStack/RegionApplicationBase.cs | |||
@@ -56,6 +56,8 @@ namespace OpenSim.Region.ClientStack | |||
56 | protected LogBase m_log; | 56 | protected LogBase m_log; |
57 | protected CommunicationsManager m_commsManager; | 57 | protected CommunicationsManager m_commsManager; |
58 | 58 | ||
59 | protected SceneManager m_sceneManager = new SceneManager(); | ||
60 | |||
59 | public RegionApplicationBase() | 61 | public RegionApplicationBase() |
60 | { | 62 | { |
61 | m_startuptime = DateTime.Now; | 63 | m_startuptime = DateTime.Now; |
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs index 874bb41..a542ab0 100644 --- a/OpenSim/Region/Environment/Scenes/Scene.cs +++ b/OpenSim/Region/Environment/Scenes/Scene.cs | |||
@@ -1416,5 +1416,12 @@ namespace OpenSim.Region.Environment.Scenes | |||
1416 | avatar = null; | 1416 | avatar = null; |
1417 | return false; | 1417 | return false; |
1418 | } | 1418 | } |
1419 | |||
1420 | public override void Close() | ||
1421 | { | ||
1422 | m_heartbeatTimer.Close(); | ||
1423 | |||
1424 | base.Close(); | ||
1425 | } | ||
1419 | } | 1426 | } |
1420 | } \ No newline at end of file | 1427 | } \ No newline at end of file |
diff --git a/OpenSim/Region/Environment/Scenes/SceneManager.cs b/OpenSim/Region/Environment/Scenes/SceneManager.cs index 0670fc7..a97020e 100644 --- a/OpenSim/Region/Environment/Scenes/SceneManager.cs +++ b/OpenSim/Region/Environment/Scenes/SceneManager.cs | |||
@@ -227,5 +227,11 @@ namespace OpenSim.Region.Environment.Scenes | |||
227 | avatar = null; | 227 | avatar = null; |
228 | return false; | 228 | return false; |
229 | } | 229 | } |
230 | |||
231 | public void CloseScene(Scene scene) | ||
232 | { | ||
233 | m_localScenes.Remove(scene); | ||
234 | scene.Close(); | ||
235 | } | ||
230 | } | 236 | } |
231 | } \ No newline at end of file | 237 | } \ No newline at end of file |
diff --git a/OpenSim/Region/Examples/SimpleApp/MyNpcCharacter.cs b/OpenSim/Region/Examples/SimpleApp/MyNpcCharacter.cs index d2dce6b..7836199 100644 --- a/OpenSim/Region/Examples/SimpleApp/MyNpcCharacter.cs +++ b/OpenSim/Region/Examples/SimpleApp/MyNpcCharacter.cs | |||
@@ -179,8 +179,15 @@ namespace SimpleApp | |||
179 | 179 | ||
180 | public virtual void SendRegionHandshake(RegionInfo regionInfo) | 180 | public virtual void SendRegionHandshake(RegionInfo regionInfo) |
181 | { | 181 | { |
182 | this.OnRegionHandShakeReply(this); | 182 | if (OnRegionHandShakeReply != null) |
183 | this.OnCompleteMovementToRegion(); | 183 | { |
184 | this.OnRegionHandShakeReply(this); | ||
185 | } | ||
186 | |||
187 | if (OnCompleteMovementToRegion != null) | ||
188 | { | ||
189 | this.OnCompleteMovementToRegion(); | ||
190 | } | ||
184 | } | 191 | } |
185 | 192 | ||
186 | private void Update( ) | 193 | private void Update( ) |
diff --git a/OpenSim/Region/Examples/SimpleApp/Program.cs b/OpenSim/Region/Examples/SimpleApp/Program.cs index 52e279b..9892866 100644 --- a/OpenSim/Region/Examples/SimpleApp/Program.cs +++ b/OpenSim/Region/Examples/SimpleApp/Program.cs | |||
@@ -72,6 +72,8 @@ namespace SimpleApp | |||
72 | 72 | ||
73 | scene.StartTimer(); | 73 | scene.StartTimer(); |
74 | 74 | ||
75 | m_sceneManager.Add(scene); | ||
76 | |||
75 | m_moduleLoader.PostInitialise(); | 77 | m_moduleLoader.PostInitialise(); |
76 | m_moduleLoader.ClearCache(); | 78 | m_moduleLoader.ClearCache(); |
77 | 79 | ||
@@ -89,7 +91,7 @@ namespace SimpleApp | |||
89 | scene.AddEntity(complexObject); | 91 | scene.AddEntity(complexObject); |
90 | } | 92 | } |
91 | 93 | ||
92 | /*for (int i = 0; i < 500; i++) | 94 | for (int i = 0; i < 2; i++) |
93 | { | 95 | { |
94 | MyNpcCharacter m_character = new MyNpcCharacter(scene.EventManager); | 96 | MyNpcCharacter m_character = new MyNpcCharacter(scene.EventManager); |
95 | scene.AddNewClient(m_character, false); | 97 | scene.AddNewClient(m_character, false); |
@@ -100,7 +102,8 @@ namespace SimpleApp | |||
100 | { | 102 | { |
101 | avatar.AbsolutePosition = new LLVector3((float)OpenSim.Framework.Utilities.Util.RandomClass.Next(100,200), (float)OpenSim.Framework.Utilities.Util.RandomClass.Next(30, 200), 2); | 103 | avatar.AbsolutePosition = new LLVector3((float)OpenSim.Framework.Utilities.Util.RandomClass.Next(100,200), (float)OpenSim.Framework.Utilities.Util.RandomClass.Next(30, 200), 2); |
102 | 104 | ||
103 | }*/ | 105 | } |
106 | |||
104 | 107 | ||
105 | 108 | ||
106 | DirectoryInfo dirInfo = new DirectoryInfo( "." ); | 109 | DirectoryInfo dirInfo = new DirectoryInfo( "." ); |