From bce3e7cb06611db887ee50c793d72674ad326ba7 Mon Sep 17 00:00:00 2001
From: Justin Clark-Casey (justincc)
Date: Thu, 10 May 2012 22:48:03 +0100
Subject: Add "attachments" show console command that will show the server's
record of which attachments an in-scene avatar has.
For debugging purposes.
---
.../Avatar/Attachments/AttachmentsCommandModule.cs | 177 +++++++++++++++++++++
1 file changed, 177 insertions(+)
create mode 100644 OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
(limited to 'OpenSim/Region/OptionalModules/Avatar/Attachments')
diff --git a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
new file mode 100644
index 0000000..ce23613
--- /dev/null
+++ b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
@@ -0,0 +1,177 @@
+/*
+ * Copyright (c) Contributors, http://opensimulator.org/
+ * See CONTRIBUTORS.TXT for a full list of copyright holders.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the OpenSimulator Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS'' AND ANY
+ * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Reflection;
+using System.Text;
+using log4net;
+using Mono.Addins;
+using Nini.Config;
+using OpenMetaverse;
+using OpenSim.Framework;
+using OpenSim.Framework.Console;
+using OpenSim.Framework.Statistics;
+using OpenSim.Region.ClientStack.LindenUDP;
+using OpenSim.Region.Framework.Interfaces;
+using OpenSim.Region.Framework.Scenes;
+
+namespace OpenSim.Region.OptionalModules.Avatar.Attachments
+{
+ ///
+ /// A module that just holds commands for inspecting avatar appearance.
+ ///
+ [Extension(Path = "/OpenSim/RegionModules", NodeName = "RegionModule", Id = "AttachmentsCommandModule")]
+ public class AttachmentsCommandModule : ISharedRegionModule
+ {
+// private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);
+
+ private List m_scenes = new List();
+// private IAvatarFactoryModule m_avatarFactory;
+
+ public string Name { get { return "Attachments Command Module"; } }
+
+ public Type ReplaceableInterface { get { return null; } }
+
+ public void Initialise(IConfigSource source)
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: INITIALIZED MODULE");
+ }
+
+ public void PostInitialise()
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: POST INITIALIZED MODULE");
+ }
+
+ public void Close()
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: CLOSED MODULE");
+ }
+
+ public void AddRegion(Scene scene)
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: REGION {0} ADDED", scene.RegionInfo.RegionName);
+ }
+
+ public void RemoveRegion(Scene scene)
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: REGION {0} REMOVED", scene.RegionInfo.RegionName);
+
+ lock (m_scenes)
+ m_scenes.Remove(scene);
+ }
+
+ public void RegionLoaded(Scene scene)
+ {
+// m_log.DebugFormat("[ATTACHMENTS COMMAND MODULE]: REGION {0} LOADED", scene.RegionInfo.RegionName);
+
+ lock (m_scenes)
+ m_scenes.Add(scene);
+
+ scene.AddCommand(
+ "Users", this, "attachments show",
+ "attachments show [ ]",
+ "Show attachment information for avatars in this simulator.",
+ HandleShowAttachmentsCommand);
+ }
+
+ protected void HandleShowAttachmentsCommand(string module, string[] cmd)
+ {
+ if (cmd.Length != 2 && cmd.Length < 4)
+ {
+ MainConsole.Instance.OutputFormat("Usage: attachments show [ ]");
+ return;
+ }
+
+ bool targetNameSupplied = false;
+ string optionalTargetFirstName = null;
+ string optionalTargetLastName = null;
+
+ if (cmd.Length >= 4)
+ {
+ targetNameSupplied = true;
+ optionalTargetFirstName = cmd[2];
+ optionalTargetLastName = cmd[3];
+ }
+
+ StringBuilder sb = new StringBuilder();
+
+ lock (m_scenes)
+ {
+ foreach (Scene scene in m_scenes)
+ {
+ if (targetNameSupplied)
+ {
+ ScenePresence sp = scene.GetScenePresence(optionalTargetFirstName, optionalTargetLastName);
+ if (sp != null && !sp.IsChildAgent)
+ GetAttachmentsReport(sp, sb);
+ }
+ else
+ {
+ scene.ForEachRootScenePresence(sp => GetAttachmentsReport(sp, sb));
+ }
+ }
+ }
+
+ MainConsole.Instance.Output(sb.ToString());
+ }
+
+ private void GetAttachmentsReport(ScenePresence sp, StringBuilder sb)
+ {
+ sb.AppendFormat("Attachments for {0}\n", sp.Name);
+
+ sb.AppendFormat(
+ " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
+ "Attachment Name", "Local ID", "Item ID", "Attach Point", "Position");
+
+ List attachmentObjects = sp.GetAttachments();
+ foreach (SceneObjectGroup attachmentObject in attachmentObjects)
+ {
+// InventoryItemBase attachmentItem
+// = m_scenes[0].InventoryService.GetItem(new InventoryItemBase(attachmentObject.FromItemID));
+
+// if (attachmentItem == null)
+// {
+// sb.AppendFormat(
+// "WARNING: Couldn't find attachment for item {0} at point {1}\n",
+// attachmentData.ItemID, (AttachmentPoint)attachmentData.AttachPoint);
+// continue;
+// }
+// else
+// {
+ sb.AppendFormat(
+ " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
+ attachmentObject.Name, attachmentObject.LocalId, attachmentObject.FromItemID,
+ (AttachmentPoint)attachmentObject.AttachmentPoint, attachmentObject.RootPart.AttachedPos);
+// }
+ }
+
+ sb.Append("\n");
+ }
+ }
+}
\ No newline at end of file
--
cgit v1.1
From 903cff9264ce405d00eab2739fcfb461749b4772 Mon Sep 17 00:00:00 2001
From: Justin Clark-Casey (justincc)
Date: Thu, 10 May 2012 23:47:39 +0100
Subject: Add ConsoleTable framework class for future uniform formatting of
console output tables.
Still subject to change - if you use this be prepared to change your output code if/when the methods change.
Make new "attachments show" command use this.
---
.../Avatar/Attachments/AttachmentsCommandModule.cs | 34 +++++++++++++++++-----
1 file changed, 26 insertions(+), 8 deletions(-)
(limited to 'OpenSim/Region/OptionalModules/Avatar/Attachments')
diff --git a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
index ce23613..a95514c 100644
--- a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
+++ b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
@@ -53,7 +53,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
private List m_scenes = new List();
// private IAvatarFactoryModule m_avatarFactory;
-
+
public string Name { get { return "Attachments Command Module"; } }
public Type ReplaceableInterface { get { return null; } }
@@ -145,9 +145,16 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
{
sb.AppendFormat("Attachments for {0}\n", sp.Name);
- sb.AppendFormat(
- " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
- "Attachment Name", "Local ID", "Item ID", "Attach Point", "Position");
+ ConsoleTable ct = new ConsoleTable() { Indent = 2 };
+ ct.Columns.Add(new ConsoleTableColumn("Attachment Name", 36));
+ ct.Columns.Add(new ConsoleTableColumn("Local ID", 10));
+ ct.Columns.Add(new ConsoleTableColumn("Item ID", 36));
+ ct.Columns.Add(new ConsoleTableColumn("Attach Point", 14));
+ ct.Columns.Add(new ConsoleTableColumn("Position", 15));
+
+// sb.AppendFormat(
+// " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
+// "Attachment Name", "Local ID", "Item ID", "Attach Point", "Position");
List attachmentObjects = sp.GetAttachments();
foreach (SceneObjectGroup attachmentObject in attachmentObjects)
@@ -164,13 +171,24 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
// }
// else
// {
- sb.AppendFormat(
- " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
- attachmentObject.Name, attachmentObject.LocalId, attachmentObject.FromItemID,
- (AttachmentPoint)attachmentObject.AttachmentPoint, attachmentObject.RootPart.AttachedPos);
+// sb.AppendFormat(
+// " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
+// attachmentObject.Name, attachmentObject.LocalId, attachmentObject.FromItemID,
+// (AttachmentPoint)attachmentObject.AttachmentPoint, attachmentObject.RootPart.AttachedPos);
+ ct.Rows.Add(
+ new ConsoleTableRow(
+ new List()
+ {
+ attachmentObject.Name,
+ attachmentObject.LocalId.ToString(),
+ attachmentObject.FromItemID.ToString(),
+ ((AttachmentPoint)attachmentObject.AttachmentPoint).ToString(),
+ attachmentObject.RootPart.AttachedPos.ToString()
+ }));
// }
}
+ ct.AddToStringBuilder(sb);
sb.Append("\n");
}
}
--
cgit v1.1
From 2222d979cc723ee2f3bad92ffe4991d074b2403a Mon Sep 17 00:00:00 2001
From: Justin Clark-Casey (justincc)
Date: Wed, 23 May 2012 02:37:38 +0100
Subject: refactor: rename ConsoleTable -> ConsoleDisplayTable for clarity
---
.../OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
(limited to 'OpenSim/Region/OptionalModules/Avatar/Attachments')
diff --git a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
index a95514c..df32a1d 100644
--- a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
+++ b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
@@ -145,7 +145,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
{
sb.AppendFormat("Attachments for {0}\n", sp.Name);
- ConsoleTable ct = new ConsoleTable() { Indent = 2 };
+ ConsoleDisplayTable ct = new ConsoleDisplayTable() { Indent = 2 };
ct.Columns.Add(new ConsoleTableColumn("Attachment Name", 36));
ct.Columns.Add(new ConsoleTableColumn("Local ID", 10));
ct.Columns.Add(new ConsoleTableColumn("Item ID", 36));
--
cgit v1.1
From 8f88c17df969b1fd3e4a93747201e9436c9a1fcd Mon Sep 17 00:00:00 2001
From: Justin Clark-Casey (justincc)
Date: Wed, 23 May 2012 03:23:37 +0100
Subject: refactor: Rename ConsoleTableRow and ConsoleTableColumn to
ConsoleDisplayTableRow and ConsoleDisplayTableColumn
---
.../Avatar/Attachments/AttachmentsCommandModule.cs | 12 ++++++------
1 file changed, 6 insertions(+), 6 deletions(-)
(limited to 'OpenSim/Region/OptionalModules/Avatar/Attachments')
diff --git a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
index df32a1d..1b9e3ac 100644
--- a/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
+++ b/OpenSim/Region/OptionalModules/Avatar/Attachments/AttachmentsCommandModule.cs
@@ -146,11 +146,11 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
sb.AppendFormat("Attachments for {0}\n", sp.Name);
ConsoleDisplayTable ct = new ConsoleDisplayTable() { Indent = 2 };
- ct.Columns.Add(new ConsoleTableColumn("Attachment Name", 36));
- ct.Columns.Add(new ConsoleTableColumn("Local ID", 10));
- ct.Columns.Add(new ConsoleTableColumn("Item ID", 36));
- ct.Columns.Add(new ConsoleTableColumn("Attach Point", 14));
- ct.Columns.Add(new ConsoleTableColumn("Position", 15));
+ ct.Columns.Add(new ConsoleDisplayTableColumn("Attachment Name", 36));
+ ct.Columns.Add(new ConsoleDisplayTableColumn("Local ID", 10));
+ ct.Columns.Add(new ConsoleDisplayTableColumn("Item ID", 36));
+ ct.Columns.Add(new ConsoleDisplayTableColumn("Attach Point", 14));
+ ct.Columns.Add(new ConsoleDisplayTableColumn("Position", 15));
// sb.AppendFormat(
// " {0,-36} {1,-10} {2,-36} {3,-14} {4,-15}\n",
@@ -176,7 +176,7 @@ namespace OpenSim.Region.OptionalModules.Avatar.Attachments
// attachmentObject.Name, attachmentObject.LocalId, attachmentObject.FromItemID,
// (AttachmentPoint)attachmentObject.AttachmentPoint, attachmentObject.RootPart.AttachedPos);
ct.Rows.Add(
- new ConsoleTableRow(
+ new ConsoleDisplayTableRow(
new List()
{
attachmentObject.Name,
--
cgit v1.1