<PackageReference Include="Newtonsoft.Json" Version="13.0.1" />

JsonSerializerInternalBase

using Newtonsoft.Json.Utilities; using System; using System.Collections.Generic; using System.Diagnostics; using System.Runtime.CompilerServices; namespace Newtonsoft.Json.Serialization { [System.Runtime.CompilerServices.NullableContext(1)] [System.Runtime.CompilerServices.Nullable(0)] internal abstract class JsonSerializerInternalBase { [System.Runtime.CompilerServices.Nullable(0)] private class ReferenceEqualsEqualityComparer : IEqualityComparer<object> { bool IEqualityComparer<object>.Equals(object x, object y) { return x == y; } int IEqualityComparer<object>.GetHashCode(object obj) { return RuntimeHelpers.GetHashCode(obj); } } [System.Runtime.CompilerServices.Nullable(2)] private ErrorContext _currentErrorContext; [System.Runtime.CompilerServices.Nullable(new byte[] { 2, 1, 1 })] private BidirectionalDictionary<string, object> _mappings; internal readonly JsonSerializer Serializer; [System.Runtime.CompilerServices.Nullable(2)] internal readonly ITraceWriter TraceWriter; [System.Runtime.CompilerServices.Nullable(2)] protected JsonSerializerProxy InternalSerializer; internal BidirectionalDictionary<string, object> DefaultReferenceMappings { get { if (_mappings == null) _mappings = new BidirectionalDictionary<string, object>(EqualityComparer<string>.Default, new ReferenceEqualsEqualityComparer(), "A different value already has the Id '{0}'.", "A different Id has already been assigned for value '{0}'. This error may be caused by an object being reused multiple times during deserialization and can be fixed with the setting ObjectCreationHandling.Replace."); return _mappings; } } protected JsonSerializerInternalBase(JsonSerializer serializer) { ValidationUtils.ArgumentNotNull(serializer, "serializer"); Serializer = serializer; TraceWriter = serializer.TraceWriter; } protected NullValueHandling ResolvedNullValueHandling([System.Runtime.CompilerServices.Nullable(2)] JsonObjectContract containerContract, JsonProperty property) { return property.NullValueHandling ?? containerContract?.ItemNullValueHandling ?? Serializer._nullValueHandling; } private ErrorContext GetErrorContext([System.Runtime.CompilerServices.Nullable(2)] object currentObject, [System.Runtime.CompilerServices.Nullable(2)] object member, string path, Exception error) { if (_currentErrorContext == null) _currentErrorContext = new ErrorContext(currentObject, member, path, error); if (_currentErrorContext.Error != error) throw new InvalidOperationException("Current error context error is different to requested error."); return _currentErrorContext; } protected void ClearErrorContext() { if (_currentErrorContext == null) throw new InvalidOperationException("Could not clear error context. Error context is already null."); _currentErrorContext = null; } [System.Runtime.CompilerServices.NullableContext(2)] protected bool IsErrorHandled(object currentObject, JsonContract contract, object keyValue, IJsonLineInfo lineInfo, [System.Runtime.CompilerServices.Nullable(1)] string path, [System.Runtime.CompilerServices.Nullable(1)] Exception ex) { ErrorContext errorContext = GetErrorContext(currentObject, keyValue, path, ex); if (TraceWriter != null && TraceWriter.LevelFilter >= TraceLevel.Error && !errorContext.Traced) { errorContext.Traced = true; string str = (GetType() == typeof(JsonSerializerInternalWriter)) ? "Error serializing" : "Error deserializing"; if (contract != null) str = str + " " + contract.UnderlyingType?.ToString(); str = str + ". " + ex.Message; if (!(ex is JsonException)) str = JsonPosition.FormatMessage(lineInfo, path, str); TraceWriter.Trace(TraceLevel.Error, str, ex); } if (contract != null && currentObject != null) contract.InvokeOnError(currentObject, Serializer.Context, errorContext); if (!errorContext.Handled) Serializer.OnError(new ErrorEventArgs(currentObject, errorContext)); return errorContext.Handled; } } }