mirror of
https://github.com/PepperDash/PepperDashCore.git
synced 2026-02-15 20:54:46 +00:00
Updates to json2.4.1 to resolve issues with reading nested array objects
This commit is contained in:
@@ -11,8 +11,7 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
public class JsonToSimplArrayLookupChild : JsonToSimplChildObjectBase
|
public class JsonToSimplArrayLookupChild : JsonToSimplChildObjectBase
|
||||||
{
|
{
|
||||||
public string SearchPropertyName { get; set; }
|
public string SearchPropertyName { get; set; }
|
||||||
public string SearchPropertyValue { get; set; }
|
public string SearchPropertyValue { get; set; }
|
||||||
public string AppendToPathPrefix { get; set; }
|
|
||||||
|
|
||||||
int ArrayIndex;
|
int ArrayIndex;
|
||||||
|
|
||||||
@@ -46,11 +45,12 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
/// <param name="searchPropertyValue"></param>
|
/// <param name="searchPropertyValue"></param>
|
||||||
public void InitializeWithAppend(string file, string key, string pathPrefix, string pathAppend,
|
public void InitializeWithAppend(string file, string key, string pathPrefix, string pathAppend,
|
||||||
string pathSuffix, string searchPropertyName, string searchPropertyValue)
|
string pathSuffix, string searchPropertyName, string searchPropertyValue)
|
||||||
{
|
{
|
||||||
base.Initialize(file, key, pathPrefix, pathSuffix);
|
string pathPrefixWithAppend = (pathPrefix != null ? pathPrefix : "") + GetPathAppend(pathAppend);
|
||||||
|
base.Initialize(file, key, pathPrefixWithAppend, pathSuffix);
|
||||||
|
|
||||||
SearchPropertyName = searchPropertyName;
|
SearchPropertyName = searchPropertyName;
|
||||||
SearchPropertyValue = searchPropertyValue;
|
SearchPropertyValue = searchPropertyValue;
|
||||||
AppendToPathPrefix = pathAppend;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -63,11 +63,10 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
protected override string GetFullPath(string path)
|
protected override string GetFullPath(string path)
|
||||||
{
|
{
|
||||||
return string.Format("{0}[{1}]{2}.{3}{4}",
|
return string.Format("{0}[{1}].{2}{3}",
|
||||||
PathPrefix == null ? "" : PathPrefix,
|
PathPrefix == null ? "" : PathPrefix,
|
||||||
ArrayIndex,
|
ArrayIndex,
|
||||||
GetPathAppend(),
|
path,
|
||||||
path,
|
|
||||||
PathSuffix == null ? "" : PathSuffix);
|
PathSuffix == null ? "" : PathSuffix);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -81,9 +80,8 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
/// Provides the path append for GetFullPath
|
/// Provides the path append for GetFullPath
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
string GetPathAppend()
|
string GetPathAppend(string a)
|
||||||
{
|
{
|
||||||
var a = AppendToPathPrefix;
|
|
||||||
if (string.IsNullOrEmpty(a))
|
if (string.IsNullOrEmpty(a))
|
||||||
{
|
{
|
||||||
return "";
|
return "";
|
||||||
@@ -109,42 +107,45 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
if (Master.JsonObject == null)
|
if (Master.JsonObject == null)
|
||||||
throw new InvalidOperationException("Cannot do operations before master JSON has read");
|
throw new InvalidOperationException("Cannot do operations before master JSON has read");
|
||||||
if (PathPrefix == null)
|
if (PathPrefix == null)
|
||||||
throw new InvalidOperationException("Cannot do operations before PathPrefix is set");
|
throw new InvalidOperationException("Cannot do operations before PathPrefix is set");
|
||||||
|
|
||||||
var token = Master.JsonObject.SelectToken(PathPrefix);
|
|
||||||
if (token is JArray)
|
var token = Master.JsonObject.SelectToken(PathPrefix);
|
||||||
{
|
if (token is JArray)
|
||||||
var array = token as JArray;
|
{
|
||||||
try
|
var array = token as JArray;
|
||||||
{
|
try
|
||||||
var item = array.FirstOrDefault(o =>
|
{
|
||||||
{
|
var item = array.FirstOrDefault(o =>
|
||||||
var prop = o[SearchPropertyName];
|
{
|
||||||
return prop != null && prop.Value<string>()
|
var prop = o[SearchPropertyName];
|
||||||
.Equals(SearchPropertyValue, StringComparison.OrdinalIgnoreCase);
|
return prop != null && prop.Value<string>()
|
||||||
});
|
.Equals(SearchPropertyValue, StringComparison.OrdinalIgnoreCase);
|
||||||
if (item == null)
|
});
|
||||||
{
|
if (item == null)
|
||||||
Debug.Console(1, "JSON Child[{0}] Array '{1}' '{2}={3}' not found: ", Key,
|
{
|
||||||
PathPrefix, SearchPropertyName, SearchPropertyValue);
|
Debug.Console(1, "JSON Child[{0}] Array '{1}' '{2}={3}' not found: ", Key,
|
||||||
this.LinkedToObject = false;
|
PathPrefix, SearchPropertyName, SearchPropertyValue);
|
||||||
return false;
|
this.LinkedToObject = false;
|
||||||
}
|
return false;
|
||||||
|
}
|
||||||
this.LinkedToObject = true;
|
|
||||||
ArrayIndex = array.IndexOf(item);
|
this.LinkedToObject = true;
|
||||||
OnStringChange(GetFullPath(""), 0, JsonToSimplConstants.FullPathToArrayChange);
|
ArrayIndex = array.IndexOf(item);
|
||||||
Debug.Console(1, "JSON Child[{0}] Found array match at index {1}", Key, ArrayIndex);
|
OnStringChange(string.Format("{0}[{1}]", PathPrefix, ArrayIndex), 0, JsonToSimplConstants.FullPathToArrayChange);
|
||||||
return true;
|
Debug.Console(1, "JSON Child[{0}] Found array match at index {1}", Key, ArrayIndex);
|
||||||
}
|
return true;
|
||||||
catch (Exception e)
|
}
|
||||||
{
|
catch (Exception e)
|
||||||
Debug.Console(1, "JSON Child[{0}] Array '{1}' lookup error: '{2}={3}'\r{4}", Key,
|
{
|
||||||
PathPrefix, SearchPropertyName, SearchPropertyValue, e);
|
Debug.Console(1, "JSON Child[{0}] Array '{1}' lookup error: '{2}={3}'\r{4}", Key,
|
||||||
}
|
PathPrefix, SearchPropertyName, SearchPropertyValue, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Debug.Console(1, "JSON Child[{0}] Path '{1}' is not an array", Key, PathPrefix);
|
||||||
}
|
}
|
||||||
else
|
|
||||||
Debug.Console(1, "JSON Child[{0}] Path '{1}' is not an array", Key, PathPrefix);
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
/// This will be prepended to all paths to allow path swapping or for more organized
|
/// This will be prepended to all paths to allow path swapping or for more organized
|
||||||
/// sub-paths
|
/// sub-paths
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public string PathPrefix { get; protected set; }
|
public string PathPrefix { get; protected set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// This is added to the end of all paths
|
/// This is added to the end of all paths
|
||||||
@@ -285,7 +285,7 @@ namespace PepperDash.Core.JsonToSimpl
|
|||||||
protected virtual string GetFullPath(string path)
|
protected virtual string GetFullPath(string path)
|
||||||
{
|
{
|
||||||
return (PathPrefix != null ? PathPrefix : "") +
|
return (PathPrefix != null ? PathPrefix : "") +
|
||||||
path + (PathSuffix != null ? PathSuffix : "");
|
path + (PathSuffix != null ? PathSuffix : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Helpers for events
|
// Helpers for events
|
||||||
|
|||||||
Reference in New Issue
Block a user