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,12 +110,12 @@ 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;
|
||||||
|
@ -123,8 +123,11 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
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;
|
||||||
|
@ -168,36 +171,33 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
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)
|
||||||
|
|
Loading…
Reference in New Issue