* LLObject is gone, it is now merged into Primitive * Avatar inherits from Primitive Simian: * Added SimulationObject to track prims * Added IMeshingProvider and a connector to OpenMetaverse.Rendering plugins git-svn-id: http://libopenmetaverse.googlecode.com/svn/trunk@2161 52acb1d6-8a22-11de-b505-999d5b087335
68 lines
3.0 KiB
C#
68 lines
3.0 KiB
C#
using System;
|
|
using System.Text.RegularExpressions;
|
|
using OpenMetaverse;
|
|
|
|
namespace OpenMetaverse.TestClient
|
|
{
|
|
public class PrimRegexCommand : Command
|
|
{
|
|
public PrimRegexCommand(TestClient testClient)
|
|
{
|
|
Name = "primregex";
|
|
Description = "Find prim by text predicat. " +
|
|
"Usage: primregex [text predicat] (eg findprim .away.)";
|
|
Category = CommandCategory.Objects;
|
|
}
|
|
|
|
public override string Execute(string[] args, UUID fromAgentID)
|
|
{
|
|
if (args.Length < 1)
|
|
return "Usage: primregex [text predicat]";
|
|
|
|
try
|
|
{
|
|
// Build the predicat from the args list
|
|
string predicatPrim = string.Empty;
|
|
for (int i = 0; i < args.Length; i++)
|
|
predicatPrim += args[i] + " ";
|
|
predicatPrim = predicatPrim.TrimEnd();
|
|
|
|
// Build Regex
|
|
Regex regexPrimName = new Regex(predicatPrim.ToLower());
|
|
|
|
// Print result
|
|
Logger.Log(string.Format("Searching prim for [{0}] ({1} prims loaded in simulator)\n", predicatPrim,
|
|
Client.Network.CurrentSim.ObjectsPrimitives.Count), Helpers.LogLevel.Info, Client);
|
|
|
|
Client.Network.CurrentSim.ObjectsPrimitives.ForEach(
|
|
delegate(Primitive prim)
|
|
{
|
|
if (prim.Text != null && regexPrimName.IsMatch(prim.Text.ToLower()))
|
|
{
|
|
Logger.Log(string.Format("\nNAME={0}\nID = {1}\nFLAGS = {2}\nTEXT = '{3}'\nDESC='{4}", prim.Properties.Name,
|
|
prim.ID, prim.Flags.ToString(), prim.Text, prim.Properties.Description), Helpers.LogLevel.Info, Client);
|
|
}
|
|
else if (prim.Properties.Name != null && regexPrimName.IsMatch(prim.Properties.Name.ToLower()))
|
|
{
|
|
Logger.Log(string.Format("\nNAME={0}\nID = {1}\nFLAGS = {2}\nTEXT = '{3}'\nDESC='{4}", prim.Properties.Name,
|
|
prim.ID, prim.Flags.ToString(), prim.Text, prim.Properties.Description), Helpers.LogLevel.Info, Client);
|
|
}
|
|
else if (prim.Properties.Description != null && regexPrimName.IsMatch(prim.Properties.Description.ToLower()))
|
|
{
|
|
Logger.Log(string.Format("\nNAME={0}\nID = {1}\nFLAGS = {2}\nTEXT = '{3}'\nDESC='{4}", prim.Properties.Name,
|
|
prim.ID, prim.Flags.ToString(), prim.Text, prim.Properties.Description), Helpers.LogLevel.Info, Client);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (System.Exception e)
|
|
{
|
|
Logger.Log(e.Message, Helpers.LogLevel.Error, Client, e);
|
|
return "Error searching";
|
|
}
|
|
|
|
return "Done searching";
|
|
}
|
|
}
|
|
}
|