From ccd47d0cf17b9f588192f5fd6162f55b77081572 Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Sat, 20 Jan 2018 10:43:19 +0000 Subject: improve LLSDHelpers DeserialiseOSDMap --- .../Handlers/FetchInventory/FetchInvDescHandler.cs | 17 +---------------- OpenSim/Capabilities/LLSDHelpers.cs | 14 +++++++++++++- 2 files changed, 14 insertions(+), 17 deletions(-) diff --git a/OpenSim/Capabilities/Handlers/FetchInventory/FetchInvDescHandler.cs b/OpenSim/Capabilities/Handlers/FetchInventory/FetchInvDescHandler.cs index 0f3f48e..1f4a8c9 100644 --- a/OpenSim/Capabilities/Handlers/FetchInventory/FetchInvDescHandler.cs +++ b/OpenSim/Capabilities/Handlers/FetchInventory/FetchInvDescHandler.cs @@ -64,22 +64,7 @@ namespace OpenSim.Capabilities.Handlers public string FetchInventoryDescendentsRequest(string request, string path, string param, IOSHttpRequest httpRequest, IOSHttpResponse httpResponse) { //m_log.DebugFormat("[XXX]: FetchInventoryDescendentsRequest in {0}, {1}", (m_Scene == null) ? "none" : m_Scene.Name, request); - - // nasty temporary hack here, the linden client falsely - // identifies the uuid 00000000-0000-0000-0000-000000000000 - // as a string which breaks us - // - // correctly mark it as a uuid - // - request = request.Replace("00000000-0000-0000-0000-000000000000", "00000000-0000-0000-0000-000000000000"); - - // another hack 1 results in a - // System.ArgumentException: Object type System.Int32 cannot - // be converted to target type: System.Boolean - // - request = request.Replace("fetch_folders0", "fetch_folders0"); - request = request.Replace("fetch_folders1", "fetch_folders1"); - + Hashtable hash = new Hashtable(); try { diff --git a/OpenSim/Capabilities/LLSDHelpers.cs b/OpenSim/Capabilities/LLSDHelpers.cs index d582267..e331cfb 100644 --- a/OpenSim/Capabilities/LLSDHelpers.cs +++ b/OpenSim/Capabilities/LLSDHelpers.cs @@ -30,6 +30,7 @@ using System.Collections; using System.IO; using System.Reflection; using System.Xml; +using OpenMetaverse; namespace OpenSim.Framework.Capabilities { @@ -160,7 +161,18 @@ namespace OpenSim.Framework.Capabilities else if(enumerator.Value is Boolean && field.FieldType == typeof(int) ) { int i = (bool)enumerator.Value ? 1 : 0; - field.SetValue(obj, (object)i); + field.SetValue(obj, i); + } + else if(field.FieldType == typeof(bool) && enumerator.Value is int) + { + bool b = (int)enumerator.Value != 0; + field.SetValue(obj, b); + } + else if(field.FieldType == typeof(UUID) && enumerator.Value is string) + { + UUID u; + UUID.TryParse((string)enumerator.Value, out u); + field.SetValue(obj, u); } else { -- cgit v1.1