* The world can not contain ScriptFactories that creates unique instances of scripts for entities.
* Created Scripts folder to house trusted Scripts * The test script now lives in Scripts/FollowRandomAvatar.cs0.1-prestable
							parent
							
								
									7169acc47e
								
							
						
					
					
						commit
						f12ceff692
					
				|  | @ -10,6 +10,7 @@ using OpenSim.Framework.Inventory; | |||
| using libsecondlife; | ||||
| using OpenSim.RegionServer.world.scripting; | ||||
| using Avatar=libsecondlife.Avatar; | ||||
| using OpenSim.RegionServer.world.scripting.Scripts; | ||||
| 
 | ||||
| namespace OpenSim.CAPS | ||||
| { | ||||
|  | @ -139,35 +140,6 @@ namespace OpenSim.CAPS | |||
|             return responseString; | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
|         private class TestScript : Script | ||||
|         { | ||||
|             public TestScript() | ||||
|                 : base(LLUUID.Random()) | ||||
|             { | ||||
|                 OnFrame += MyOnFrame; | ||||
|             } | ||||
| 
 | ||||
|             private void MyOnFrame(IScriptContext context) | ||||
|             { | ||||
|                 LLVector3 pos = context.Entity.Pos; | ||||
| 
 | ||||
|                 IScriptReadonlyEntity avatar; | ||||
|                  | ||||
|                 if( context.TryGetRandomAvatar( out avatar ) ) | ||||
|                 { | ||||
|                     LLVector3 avatarPos = avatar.Pos; | ||||
| 
 | ||||
|                     float x = pos.X + ((float)avatarPos.X.CompareTo(pos.X))/2; | ||||
|                     float y = pos.Y + ((float)avatarPos.Y.CompareTo(pos.Y))/2; | ||||
| 
 | ||||
|                     LLVector3 newPos = new LLVector3( x, y, pos.Z ); | ||||
|                      | ||||
|                     context.Entity.Pos = newPos; | ||||
|                 }                 | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         private string AddTestScript(string request, string path) | ||||
|         { | ||||
|             int index = path.LastIndexOf('/'); | ||||
|  | @ -179,7 +151,7 @@ namespace OpenSim.CAPS | |||
|             if( LLUUID.TryParse( lluidStr, out id ) ) | ||||
|             { | ||||
|                 // This is just here for concept purposes... Remove! | ||||
|                 m_world.AddScript( m_world.Entities[id], new TestScript()); | ||||
|                 m_world.AddScript( m_world.Entities[id], new FollowRandomAvatar()); | ||||
|                 return String.Format("Added new script to object [{0}]", id); | ||||
|             } | ||||
|             else | ||||
|  |  | |||
|  | @ -196,6 +196,12 @@ | |||
|     <Compile Include="world\scripting\Script.cs"> | ||||
|       <SubType>Code</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="world\scripting\ScriptFactory.cs"> | ||||
|       <SubType>Code</SubType> | ||||
|     </Compile> | ||||
|     <Compile Include="world\scripting\Scripts\FollowRandomAvatar.cs"> | ||||
|       <SubType>Code</SubType> | ||||
|     </Compile> | ||||
|   </ItemGroup> | ||||
|   <Import Project="$(MSBuildBinPath)\Microsoft.CSHARP.Targets" /> | ||||
|   <PropertyGroup> | ||||
|  |  | |||
|  | @ -39,6 +39,8 @@ | |||
|                 <include name="world/scripting/IScriptEntity.cs" /> | ||||
|                 <include name="world/scripting/IScriptHandler.cs" /> | ||||
|                 <include name="world/scripting/Script.cs" /> | ||||
|                 <include name="world/scripting/ScriptFactory.cs" /> | ||||
|                 <include name="world/scripting/Scripts/FollowRandomAvatar.cs" /> | ||||
|             </sources> | ||||
|             <references basedir="${project::get-base-directory()}"> | ||||
|                 <lib> | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ using OpenSim.Framework.Inventory; | |||
| using OpenSim.Assets; | ||||
| using OpenSim.world.scripting; | ||||
| using OpenSim.RegionServer.world.scripting; | ||||
| using OpenSim.RegionServer.world.scripting.Scripts; | ||||
| 
 | ||||
| namespace OpenSim.world | ||||
| { | ||||
|  | @ -32,20 +33,20 @@ namespace OpenSim.world | |||
|         private int storageCount; | ||||
|         private Dictionary<uint, SimClient> m_clientThreads; | ||||
|         private Dictionary<LLUUID, ScriptHandler> m_scriptHandlers; | ||||
|         private Dictionary<string, Script> m_scripts; | ||||
|         private Dictionary<string, ScriptFactory> m_scripts; | ||||
|         private ulong m_regionHandle; | ||||
|         private string m_regionName; | ||||
|         private InventoryCache _inventoryCache; | ||||
|         private AssetCache _assetCache; | ||||
| 
 | ||||
|         public World(Dictionary<uint, SimClient> clientThreads, ulong regionHandle, string regionName) | ||||
|         {  | ||||
|         { | ||||
|             m_clientThreads = clientThreads; | ||||
|             m_regionHandle = regionHandle; | ||||
|             m_regionName = regionName; | ||||
| 
 | ||||
|             m_scriptHandlers = new Dictionary<LLUUID, ScriptHandler>(); | ||||
|             m_scripts = new Dictionary<string, Script>(); | ||||
|             m_scripts = new Dictionary<string, ScriptFactory>(); | ||||
| 
 | ||||
|             OpenSim.Framework.Console.MainConsole.Instance.WriteLine("World.cs - creating new entitities instance"); | ||||
|             Entities = new Dictionary<libsecondlife.LLUUID, Entity>(); | ||||
|  | @ -75,11 +76,17 @@ namespace OpenSim.world | |||
|             scriptend = scriptData.LastIndexOf("</Script>"); | ||||
|             substring = scriptData.Substring(scriptstart + 8, scriptend - scriptstart - 8); | ||||
|             substring = substring.Trim(); | ||||
|             Console.WriteLine("searching for script to add: " +  substring); | ||||
|             if (this.m_scripts.ContainsKey(substring)) | ||||
|             Console.WriteLine("searching for script to add: " + substring); | ||||
|              | ||||
|             ScriptFactory scriptFactory; | ||||
|              | ||||
|             if (this.m_scripts.TryGetValue(substring, out scriptFactory )) | ||||
|             { | ||||
|                 Console.WriteLine("added script"); | ||||
|                 this.AddScript(entity, this.m_scripts[substring]); | ||||
|                  | ||||
|                  | ||||
|                  | ||||
|                 this.AddScript(entity, scriptFactory()); | ||||
|             } | ||||
|             /*string delimStr = " "; | ||||
|             char[] delimiter = delimStr.ToCharArray(); | ||||
|  | @ -357,7 +364,7 @@ namespace OpenSim.world | |||
|                     prim.PhysActor = this.phyScene.AddPrim(pVec, pSize); | ||||
|                 } | ||||
|             } | ||||
|              | ||||
| 
 | ||||
|             this.Entities.Add(prim.uuid, prim); | ||||
|             this._primCount++; | ||||
|         } | ||||
|  | @ -557,31 +564,13 @@ namespace OpenSim.world | |||
| 
 | ||||
|         public void SetDefaultScripts() | ||||
|         { | ||||
|             this.m_scripts.Add("Test", new TestScript1()); | ||||
|             this.m_scripts.Add("FollowRandomAvatar", delegate() | ||||
|                                                              { | ||||
|                                                              return new FollowRandomAvatar(); | ||||
|                                                          }); | ||||
|         } | ||||
| 
 | ||||
| 
 | ||||
|         #endregion | ||||
|     } | ||||
| 
 | ||||
|     public class TestScript1 : Script | ||||
|     { | ||||
|         int toggle = 0; | ||||
| 
 | ||||
|         public TestScript1() | ||||
|             : base(LLUUID.Random()) | ||||
|         { | ||||
|             OnFrame += MyOnFrame; | ||||
|         } | ||||
| 
 | ||||
|         private void MyOnFrame(IScriptContext context) | ||||
|         { | ||||
|             toggle = 2 - toggle; | ||||
| 
 | ||||
|             LLVector3 pos = context.GetPos(); | ||||
| 
 | ||||
|             pos.X += (toggle - 1); | ||||
| 
 | ||||
|             context.MoveTo(pos); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -0,0 +1,8 @@ | |||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Text; | ||||
| 
 | ||||
| namespace OpenSim.RegionServer.world.scripting | ||||
| { | ||||
|     public delegate Script ScriptFactory(); | ||||
| } | ||||
|  | @ -0,0 +1,37 @@ | |||
| using System; | ||||
| using System.Collections.Generic; | ||||
| using System.Text; | ||||
| using libsecondlife; | ||||
| 
 | ||||
| namespace OpenSim.RegionServer.world.scripting.Scripts | ||||
| { | ||||
|     public class FollowRandomAvatar : Script | ||||
|     { | ||||
|         public FollowRandomAvatar() | ||||
|             : base(LLUUID.Random()) | ||||
|         { | ||||
|             OnFrame += MyOnFrame; | ||||
|         } | ||||
| 
 | ||||
|         private void MyOnFrame(IScriptContext context) | ||||
|         { | ||||
|             LLVector3 pos = context.Entity.Pos; | ||||
| 
 | ||||
|             IScriptReadonlyEntity avatar; | ||||
| 
 | ||||
|             if (context.TryGetRandomAvatar(out avatar)) | ||||
|             { | ||||
|                 LLVector3 avatarPos = avatar.Pos; | ||||
| 
 | ||||
|                 float x = pos.X + ((float)avatarPos.X.CompareTo(pos.X)) / 2; | ||||
|                 float y = pos.Y + ((float)avatarPos.Y.CompareTo(pos.Y)) / 2; | ||||
| 
 | ||||
|                 LLVector3 newPos = new LLVector3(x, y, pos.Z); | ||||
| 
 | ||||
|                 context.Entity.Pos = newPos; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
		Loading…
	
		Reference in New Issue
	
	 lbsa71
						lbsa71