move linden notecard parsing from LSL_Api.cs to SLUtil so that region modules can use it
							parent
							
								
									716e6f20e1
								
							
						
					
					
						commit
						e07548d703
					
				|  | @ -1,4 +1,5 @@ | ||||||
| using System; | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
| using OpenMetaverse; | using OpenMetaverse; | ||||||
| 
 | 
 | ||||||
| namespace OpenSim.Framework | namespace OpenSim.Framework | ||||||
|  | @ -181,5 +182,101 @@ namespace OpenSim.Framework | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         #endregion SL / file extension / content-type conversions |         #endregion SL / file extension / content-type conversions | ||||||
|  | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         /// Parse a notecard in Linden format to a string of ordinary text. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="rawInput"></param> | ||||||
|  |         /// <returns></returns>         | ||||||
|  |         public static string ParseNotecardToString(string rawInput) | ||||||
|  |         { | ||||||
|  |             return string.Join("\n", ParseNotecardToList(rawInput).ToArray()); | ||||||
|  |         } | ||||||
|  |                  | ||||||
|  |         /// <summary> | ||||||
|  |         /// Parse a notecard in Linden format to a list of ordinary lines. | ||||||
|  |         /// </summary> | ||||||
|  |         /// <param name="rawInput"></param> | ||||||
|  |         /// <returns></returns> | ||||||
|  |         public static List<string> ParseNotecardToList(string rawInput) | ||||||
|  |         { | ||||||
|  |             string[] input = rawInput.Replace("\r", "").Split('\n');             | ||||||
|  |             int idx = 0; | ||||||
|  |             int level = 0; | ||||||
|  |             List<string> output = new List<string>(); | ||||||
|  |             string[] words; | ||||||
|  | 
 | ||||||
|  |             while (idx < input.Length) | ||||||
|  |             { | ||||||
|  |                 if (input[idx] == "{") | ||||||
|  |                 { | ||||||
|  |                     level++; | ||||||
|  |                     idx++; | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if (input[idx]== "}") | ||||||
|  |                 { | ||||||
|  |                     level--; | ||||||
|  |                     idx++; | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 switch (level) | ||||||
|  |                 { | ||||||
|  |                 case 0: | ||||||
|  |                     words = input[idx].Split(' '); // Linden text ver | ||||||
|  |                     // Notecards are created *really* empty. Treat that as "no text" (just like after saving an empty notecard) | ||||||
|  |                     if (words.Length < 3) | ||||||
|  |                         return output; | ||||||
|  | 
 | ||||||
|  |                     int version = int.Parse(words[3]); | ||||||
|  |                     if (version != 2) | ||||||
|  |                         return output; | ||||||
|  |                     break; | ||||||
|  |                 case 1: | ||||||
|  |                     words = input[idx].Split(' '); | ||||||
|  |                     if (words[0] == "LLEmbeddedItems") | ||||||
|  |                         break; | ||||||
|  |                     if (words[0] == "Text") | ||||||
|  |                     { | ||||||
|  |                         int len = int.Parse(words[2]); | ||||||
|  |                         idx++; | ||||||
|  | 
 | ||||||
|  |                         int count = -1; | ||||||
|  | 
 | ||||||
|  |                         while (count < len) | ||||||
|  |                         { | ||||||
|  |                             // int l = input[idx].Length; | ||||||
|  |                             string ln = input[idx]; | ||||||
|  | 
 | ||||||
|  |                             int need = len-count-1; | ||||||
|  |                             if (ln.Length > need) | ||||||
|  |                                 ln = ln.Substring(0, need); | ||||||
|  | 
 | ||||||
|  |                             output.Add(ln); | ||||||
|  |                             count += ln.Length + 1; | ||||||
|  |                             idx++; | ||||||
|  |                         } | ||||||
|  | 
 | ||||||
|  |                         return output; | ||||||
|  |                     } | ||||||
|  |                     break; | ||||||
|  |                 case 2: | ||||||
|  |                     words = input[idx].Split(' '); // count | ||||||
|  |                     if (words[0] == "count") | ||||||
|  |                     { | ||||||
|  |                         int c = int.Parse(words[1]); | ||||||
|  |                         if (c > 0) | ||||||
|  |                             return output; | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                     break; | ||||||
|  |                 } | ||||||
|  |                 idx++; | ||||||
|  |             } | ||||||
|  |              | ||||||
|  |             return output; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -164,12 +164,12 @@ namespace OpenSim | ||||||
|             m_config.Source = new IniConfigSource(); |             m_config.Source = new IniConfigSource(); | ||||||
|             m_config.Source.Merge(DefaultConfig()); |             m_config.Source.Merge(DefaultConfig()); | ||||||
| 
 | 
 | ||||||
|             m_log.Info("[CONFIG] Reading configuration settings"); |             m_log.Info("[CONFIG]: Reading configuration settings"); | ||||||
| 
 | 
 | ||||||
|             if (sources.Count == 0) |             if (sources.Count == 0) | ||||||
|             { |             { | ||||||
|                 m_log.FatalFormat("[CONFIG] Could not load any configuration"); |                 m_log.FatalFormat("[CONFIG]: Could not load any configuration"); | ||||||
|                 m_log.FatalFormat("[CONFIG] Did you copy the OpenSim.ini.example file to OpenSim.ini?"); |                 m_log.FatalFormat("[CONFIG]: Did you copy the OpenSim.ini.example file to OpenSim.ini?"); | ||||||
|                 Environment.Exit(1); |                 Environment.Exit(1); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -182,8 +182,8 @@ namespace OpenSim | ||||||
| 
 | 
 | ||||||
|             if (!iniFileExists) |             if (!iniFileExists) | ||||||
|             { |             { | ||||||
|                 m_log.FatalFormat("[CONFIG] Could not load any configuration"); |                 m_log.FatalFormat("[CONFIG]: Could not load any configuration"); | ||||||
|                 m_log.FatalFormat("[CONFIG] Configuration exists, but there was an error loading it!"); |                 m_log.FatalFormat("[CONFIG]: Configuration exists, but there was an error loading it!"); | ||||||
|                 Environment.Exit(1); |                 Environment.Exit(1); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | @ -257,20 +257,17 @@ namespace OpenSim | ||||||
| 
 | 
 | ||||||
|             if (!IsUri(iniPath)) |             if (!IsUri(iniPath)) | ||||||
|             { |             { | ||||||
|                 m_log.InfoFormat("[CONFIG] Reading configuration file {0}", |                 m_log.InfoFormat("[CONFIG]: Reading configuration file {0}", Path.GetFullPath(iniPath)); | ||||||
|                         Path.GetFullPath(iniPath)); |  | ||||||
| 
 | 
 | ||||||
|                 m_config.Source.Merge(new IniConfigSource(iniPath)); |                 m_config.Source.Merge(new IniConfigSource(iniPath)); | ||||||
|                 success = true; |                 success = true; | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 m_log.InfoFormat("[CONFIG] {0} is a http:// URI, fetching ...", |                 m_log.InfoFormat("[CONFIG]: {0} is a http:// URI, fetching ...", iniPath); | ||||||
|                         iniPath); |  | ||||||
| 
 | 
 | ||||||
|                 // The ini file path is a http URI |                 // The ini file path is a http URI | ||||||
|                 // Try to read it |                 // Try to read it | ||||||
|                 // |  | ||||||
|                 try |                 try | ||||||
|                 { |                 { | ||||||
|                     XmlReader r = XmlReader.Create(iniPath); |                     XmlReader r = XmlReader.Create(iniPath); | ||||||
|  | @ -281,7 +278,7 @@ namespace OpenSim | ||||||
|                 } |                 } | ||||||
|                 catch (Exception e) |                 catch (Exception e) | ||||||
|                 { |                 { | ||||||
|                     m_log.FatalFormat("[CONFIG] Exception reading config from URI {0}\n" + e.ToString(), iniPath); |                     m_log.FatalFormat("[CONFIG]: Exception reading config from URI {0}\n" + e.ToString(), iniPath); | ||||||
|                     Environment.Exit(1); |                     Environment.Exit(1); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
|  | @ -110,21 +110,24 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|         public event OnSetRootAgentSceneDelegate OnSetRootAgentScene; |         public event OnSetRootAgentSceneDelegate OnSetRootAgentScene; | ||||||
| 
 | 
 | ||||||
|         /// <summary> |         /// <summary> | ||||||
|         /// Called when an object is touched/grabbed. |         /// Fired when an object is touched/grabbed. | ||||||
|         /// </summary> |         /// </summary> | ||||||
|         /// The originalID is the local ID of the part that was actually touched.  The localID itself is always that of |         /// The originalID is the local ID of the part that was actually touched.  The localID itself is always that of | ||||||
|         /// the root part. |         /// the root part.         | ||||||
|         public delegate void ObjectGrabDelegate(uint localID, uint originalID, Vector3 offsetPos, IClientAPI remoteClient, SurfaceTouchEventArgs surfaceArgs); |  | ||||||
|         public event ObjectGrabDelegate OnObjectGrab; |         public event ObjectGrabDelegate OnObjectGrab; | ||||||
|  |         public delegate void ObjectGrabDelegate(uint localID, uint originalID, Vector3 offsetPos, IClientAPI remoteClient, SurfaceTouchEventArgs surfaceArgs);         | ||||||
|          |          | ||||||
|         public event ObjectGrabDelegate OnObjectGrabbing; |         public event ObjectGrabDelegate OnObjectGrabbing; | ||||||
|         public event ObjectDeGrabDelegate OnObjectDeGrab; |         public event ObjectDeGrabDelegate OnObjectDeGrab; | ||||||
|         public event ScriptResetDelegate OnScriptReset; |         public event ScriptResetDelegate OnScriptReset; | ||||||
| 
 | 
 | ||||||
|         public event OnPermissionErrorDelegate OnPermissionError; |         public event OnPermissionErrorDelegate OnPermissionError;         | ||||||
| 
 | 
 | ||||||
|         public delegate void NewRezScript(uint localID, UUID itemID, string script, int startParam, bool postOnRez, string engine, int stateSource); |         /// <summary> | ||||||
|  |         /// Fired when a new script is created. | ||||||
|  |         /// </summary> | ||||||
|         public event NewRezScript OnRezScript; |         public event NewRezScript OnRezScript; | ||||||
|  |         public delegate void NewRezScript(uint localID, UUID itemID, string script, int startParam, bool postOnRez, string engine, int stateSource); | ||||||
| 
 | 
 | ||||||
|         public delegate void RemoveScript(uint localID, UUID itemID); |         public delegate void RemoveScript(uint localID, UUID itemID); | ||||||
|         public event RemoveScript OnRemoveScript; |         public event RemoveScript OnRemoveScript; | ||||||
|  | @ -166,38 +169,35 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
| 
 | 
 | ||||||
|         public delegate void ClientClosed(UUID clientID, Scene scene); |         public delegate void ClientClosed(UUID clientID, Scene scene); | ||||||
| 
 | 
 | ||||||
|         public event ClientClosed OnClientClosed; |         public event ClientClosed OnClientClosed;         | ||||||
| 
 | 
 | ||||||
|  |         /// <summary> | ||||||
|  |         /// This is fired when a scene object property that a script might be interested in (such as color, scale or | ||||||
|  |         /// inventory) changes.  Only enough information is sent for the LSL changed event | ||||||
|  |         /// (see http://lslwiki.net/lslwiki/wakka.php?wakka=changed) | ||||||
|  |         /// </summary> | ||||||
|  |         public event ScriptChangedEvent OnScriptChangedEvent; | ||||||
|         public delegate void ScriptChangedEvent(uint localID, uint change); |         public delegate void ScriptChangedEvent(uint localID, uint change); | ||||||
| 
 | 
 | ||||||
|         public event ScriptChangedEvent OnScriptChangedEvent; |  | ||||||
| 
 |  | ||||||
|         public delegate void ScriptControlEvent(uint localID, UUID item, UUID avatarID, uint held, uint changed); |         public delegate void ScriptControlEvent(uint localID, UUID item, UUID avatarID, uint held, uint changed); | ||||||
| 
 |  | ||||||
|         public event ScriptControlEvent OnScriptControlEvent; |         public event ScriptControlEvent OnScriptControlEvent; | ||||||
| 
 | 
 | ||||||
|         public delegate void ScriptAtTargetEvent(uint localID, uint handle, Vector3 targetpos, Vector3 atpos); |         public delegate void ScriptAtTargetEvent(uint localID, uint handle, Vector3 targetpos, Vector3 atpos); | ||||||
| 
 |  | ||||||
|         public event ScriptAtTargetEvent OnScriptAtTargetEvent; |         public event ScriptAtTargetEvent OnScriptAtTargetEvent; | ||||||
| 
 | 
 | ||||||
|         public delegate void ScriptNotAtTargetEvent(uint localID); |         public delegate void ScriptNotAtTargetEvent(uint localID); | ||||||
| 
 |  | ||||||
|         public event ScriptNotAtTargetEvent OnScriptNotAtTargetEvent; |         public event ScriptNotAtTargetEvent OnScriptNotAtTargetEvent; | ||||||
| 
 | 
 | ||||||
|         public delegate void ScriptAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion atrot); |         public delegate void ScriptAtRotTargetEvent(uint localID, uint handle, Quaternion targetrot, Quaternion atrot); | ||||||
| 
 |  | ||||||
|         public event ScriptAtRotTargetEvent OnScriptAtRotTargetEvent; |         public event ScriptAtRotTargetEvent OnScriptAtRotTargetEvent; | ||||||
| 
 | 
 | ||||||
|         public delegate void ScriptNotAtRotTargetEvent(uint localID); |         public delegate void ScriptNotAtRotTargetEvent(uint localID); | ||||||
| 
 |  | ||||||
|         public event ScriptNotAtRotTargetEvent OnScriptNotAtRotTargetEvent; |         public event ScriptNotAtRotTargetEvent OnScriptNotAtRotTargetEvent; | ||||||
| 
 | 
 | ||||||
|         public delegate void ScriptColliding(uint localID, ColliderArgs colliders); |         public delegate void ScriptColliding(uint localID, ColliderArgs colliders); | ||||||
| 
 |  | ||||||
|         public event ScriptColliding OnScriptColliderStart; |         public event ScriptColliding OnScriptColliderStart; | ||||||
|         public event ScriptColliding OnScriptColliding; |         public event ScriptColliding OnScriptColliding; | ||||||
|         public event ScriptColliding OnScriptCollidingEnd; |         public event ScriptColliding OnScriptCollidingEnd; | ||||||
| 
 |  | ||||||
|         public event ScriptColliding OnScriptLandColliderStart; |         public event ScriptColliding OnScriptLandColliderStart; | ||||||
|         public event ScriptColliding OnScriptLandColliding; |         public event ScriptColliding OnScriptLandColliding; | ||||||
|         public event ScriptColliding OnScriptLandColliderEnd; |         public event ScriptColliding OnScriptLandColliderEnd; | ||||||
|  |  | ||||||
|  | @ -637,7 +637,6 @@ namespace OpenSim.Region.Framework.Scenes | ||||||
|                     m_items[item.ItemID] = item; |                     m_items[item.ItemID] = item; | ||||||
|                     m_inventorySerial++; |                     m_inventorySerial++; | ||||||
|                     m_part.TriggerScriptChangedEvent(Changed.INVENTORY); |                     m_part.TriggerScriptChangedEvent(Changed.INVENTORY); | ||||||
| 
 |  | ||||||
|                     HasInventoryChanged = true; |                     HasInventoryChanged = true; | ||||||
|                     m_part.ParentGroup.HasGroupChanged = true; |                     m_part.ParentGroup.HasGroupChanged = true; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9705,90 +9705,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
| 
 | 
 | ||||||
|                 Notecard nc = new Notecard(); |                 Notecard nc = new Notecard(); | ||||||
|                 nc.lastRef = DateTime.Now; |                 nc.lastRef = DateTime.Now; | ||||||
|                 nc.text = ParseText(text.Replace("\r", "").Split('\n')); |                 nc.text = SLUtil.ParseNotecardToList(text).ToArray(); | ||||||
|                 m_Notecards[assetID] = nc; |                 m_Notecards[assetID] = nc; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         protected static string[] ParseText(string[] input) |  | ||||||
|         { |  | ||||||
|             int idx = 0; |  | ||||||
|             int level = 0; |  | ||||||
|             List<string> output = new List<string>(); |  | ||||||
|             string[] words; |  | ||||||
| 
 |  | ||||||
|             while (idx < input.Length) |  | ||||||
|             { |  | ||||||
|                 if (input[idx] == "{") |  | ||||||
|                 { |  | ||||||
|                     level++; |  | ||||||
|                     idx++; |  | ||||||
|                     continue; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (input[idx]== "}") |  | ||||||
|                 { |  | ||||||
|                     level--; |  | ||||||
|                     idx++; |  | ||||||
|                     continue; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 switch (level) |  | ||||||
|                 { |  | ||||||
|                 case 0: |  | ||||||
|                     words = input[idx].Split(' '); // Linden text ver |  | ||||||
|                     // Notecards are created *really* empty. Treat that as "no text" (just like after saving an empty notecard) |  | ||||||
|                     if (words.Length < 3) |  | ||||||
|                         return new String[0]; |  | ||||||
| 
 |  | ||||||
|                     int version = int.Parse(words[3]); |  | ||||||
|                     if (version != 2) |  | ||||||
|                         return new String[0]; |  | ||||||
|                     break; |  | ||||||
|                 case 1: |  | ||||||
|                     words = input[idx].Split(' '); |  | ||||||
|                     if (words[0] == "LLEmbeddedItems") |  | ||||||
|                         break; |  | ||||||
|                     if (words[0] == "Text") |  | ||||||
|                     { |  | ||||||
|                         int len = int.Parse(words[2]); |  | ||||||
|                         idx++; |  | ||||||
| 
 |  | ||||||
|                         int count = -1; |  | ||||||
| 
 |  | ||||||
|                         while (count < len) |  | ||||||
|                         { |  | ||||||
|                             // int l = input[idx].Length; |  | ||||||
|                             string ln = input[idx]; |  | ||||||
| 
 |  | ||||||
|                             int need = len-count-1; |  | ||||||
|                             if (ln.Length > need) |  | ||||||
|                                 ln = ln.Substring(0, need); |  | ||||||
| 
 |  | ||||||
|                             output.Add(ln); |  | ||||||
|                             count += ln.Length + 1; |  | ||||||
|                             idx++; |  | ||||||
|                         } |  | ||||||
| 
 |  | ||||||
|                         return output.ToArray(); |  | ||||||
|                     } |  | ||||||
|                     break; |  | ||||||
|                 case 2: |  | ||||||
|                     words = input[idx].Split(' '); // count |  | ||||||
|                     if (words[0] == "count") |  | ||||||
|                     { |  | ||||||
|                         int c = int.Parse(words[1]); |  | ||||||
|                         if (c > 0) |  | ||||||
|                             return new String[0]; |  | ||||||
|                         break; |  | ||||||
|                     } |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|                 idx++; |  | ||||||
|             } |  | ||||||
|             return output.ToArray(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         public static bool IsCached(UUID assetID) |         public static bool IsCached(UUID assetID) | ||||||
|         { |         { | ||||||
|             lock (m_Notecards) |             lock (m_Notecards) | ||||||
|  | @ -9844,4 +9765,4 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
		Loading…
	
		Reference in New Issue
	
	 Justin Clark-Casey (justincc)
						Justin Clark-Casey (justincc)