Car/Assets/Plugin/YogiGameCore/FullSerializer/Source/fsConfig.cs

95 lines
3.8 KiB
C#
Raw Permalink Normal View History

2024-12-31 07:57:41 +08:00
using System;
using System.Reflection;
namespace FullSerializer {
// Global configuration options.
public static class fsGlobalConfig {
/// <summary>
/// Should deserialization be case sensitive? If this is false and the JSON has multiple members with the
/// same keys only separated by case, then this results in undefined behavior.
/// </summary>
public static bool IsCaseSensitive = true;
/// <summary>
/// If exceptions are allowed internally, then additional date formats can be deserialized.
/// Note that the Full Serializer public API will *not* throw exceptions with this enabled;
/// errors will still be returned in a fsResult instance.
/// </summary>
public static bool AllowInternalExceptions = true;
/// <summary>
/// This string will be used to prefix fields used internally by FullSerializer.
/// </summary>
public static string InternalFieldPrefix = "$";
}
/// <summary>
/// Enables some top-level customization of Full Serializer.
/// </summary>
public class fsConfig {
/// <summary>
/// The attributes that will force a field or property to be serialized.
/// </summary>
public Type[] SerializeAttributes = {
#if !NO_UNITY
typeof(UnityEngine.SerializeField),
#endif
typeof(fsPropertyAttribute)
};
/// <summary>
/// The attributes that will force a field or property to *not* be serialized.
/// </summary>
public Type[] IgnoreSerializeAttributes = { typeof(NonSerializedAttribute), typeof(fsIgnoreAttribute) };
/// <summary>
/// The default member serialization.
/// </summary>
public fsMemberSerialization DefaultMemberSerialization = fsMemberSerialization.Default;
/// <summary>
/// Convert a C# field/property name into the key used for the JSON object. For example, you could
/// force all JSON names to lowercase with:
///
/// fsConfig.GetJsonNameFromMemberName = (name, info) => name.ToLower();
///
/// This will only be used when the name is not explicitly specified with fsProperty.
/// </summary>
public Func<string, MemberInfo, string> GetJsonNameFromMemberName = (name, info) => name;
/// <summary>
/// If false, then *all* property serialization support will be disabled - even properties
/// explicitly annotated with fsProperty or any other opt-in annotation.
///
/// Setting this to false means that SerializeNonAutoProperties and
/// SerializeNonPublicSetProperties will be completely ignored.
/// </summary>
public bool EnablePropertySerialization = true;
/// <summary>
/// Should the default serialization behaviour include non-auto properties?
/// </summary>
public bool SerializeNonAutoProperties = false;
/// <summary>
/// Should the default serialization behaviour include properties with non-public setters?
/// </summary>
public bool SerializeNonPublicSetProperties = true;
/// <summary>
/// If not null, this string format will be used for DateTime instead of the default one.
/// </summary>
public string CustomDateTimeFormatString = null;
/// <summary>
/// Int64 and UInt64 will be serialized and deserialized as string for compatibility
/// </summary>
public bool Serialize64BitIntegerAsString = false;
/// <summary>
/// Enums are serialized using their names by default. Setting this to true will serialize them as integers instead.
/// </summary>
public bool SerializeEnumsAsInteger = false;
}
}