corrade-vassal – Rev 1

Subversion Repositories:
Rev:
using System;
using System.Threading;
using OpenMetaverse;

namespace OpenMetaverse.TestClient
{
    public class PrimInfoCommand : Command
    {
        public PrimInfoCommand(TestClient testClient)
        {
            Name = "priminfo";
            Description = "Dumps information about a specified prim. " + "Usage: priminfo [prim-uuid]";
            Category = CommandCategory.Objects;
        }

        public override string Execute(string[] args, UUID fromAgentID)
        {
            UUID primID;

            if (args.Length != 1)
                return "Usage: priminfo [prim-uuid]";

            if (UUID.TryParse(args[0], out primID))
            {
                Primitive target = Client.Network.CurrentSim.ObjectsPrimitives.Find(
                    delegate(Primitive prim) { return prim.ID == primID; }
                );

                if (target != null)
                {
                    if (target.Text != String.Empty)
                    {
                        Logger.Log("Text: " + target.Text, Helpers.LogLevel.Info, Client);
                    }
                    if(target.Light != null)
                        Logger.Log("Light: " + target.Light.ToString(), Helpers.LogLevel.Info, Client);

                    if (target.ParticleSys.CRC != 0)
                        Logger.Log("Particles: " + target.ParticleSys.ToString(), Helpers.LogLevel.Info, Client);

                    Logger.Log("TextureEntry:", Helpers.LogLevel.Info, Client);
                    if (target.Textures != null)
                    {
                        Logger.Log(String.Format("Default texure: {0}",
                            target.Textures.DefaultTexture.TextureID.ToString()),
                            Helpers.LogLevel.Info);

                        for (int i = 0; i < target.Textures.FaceTextures.Length; i++)
                        {
                            if (target.Textures.FaceTextures[i] != null)
                            {
                                Logger.Log(String.Format("Face {0}: {1}", i,
                                    target.Textures.FaceTextures[i].TextureID.ToString()),
                                    Helpers.LogLevel.Info, Client);
                            }
                        }
                    }
                    else
                    {
                        Logger.Log("null", Helpers.LogLevel.Info, Client);
                    }

                    AutoResetEvent propsEvent = new AutoResetEvent(false);
                    EventHandler<ObjectPropertiesEventArgs> propsCallback =
                        delegate(object sender, ObjectPropertiesEventArgs e)
                        {
                            Logger.Log(String.Format(
                                "Category: {0}\nFolderID: {1}\nFromTaskID: {2}\nInventorySerial: {3}\nItemID: {4}\nCreationDate: {5}",
                                e.Properties.Category, e.Properties.FolderID, e.Properties.FromTaskID, e.Properties.InventorySerial, 
                                e.Properties.ItemID, e.Properties.CreationDate), Helpers.LogLevel.Info);
                            propsEvent.Set();
                        };

                    Client.Objects.ObjectProperties += propsCallback;

                    Client.Objects.SelectObject(Client.Network.CurrentSim, target.LocalID, true);

                    propsEvent.WaitOne(1000 * 10, false);
                    Client.Objects.ObjectProperties -= propsCallback;

                    return "Done.";
                }
                else
                {
                    return "Could not find prim " + primID.ToString();
                }
            }
            else
            {
                return "Usage: priminfo [prim-uuid]";
            }
        }
    }
}