mirror of
https://github.com/RRQM/TouchSocket.git
synced 2025-12-19 01:46:44 +08:00
196 lines
7.8 KiB
C#
196 lines
7.8 KiB
C#
//------------------------------------------------------------------------------
|
||
// 此代码版权(除特别声明或在RRQMCore.XREF命名空间的代码)归作者本人若汝棋茗所有
|
||
// 源代码使用协议遵循本仓库的开源协议及附加协议,若本仓库没有设置,则按MIT开源协议授权
|
||
// CSDN博客:https://blog.csdn.net/qq_40374647
|
||
// 哔哩哔哩视频:https://space.bilibili.com/94253567
|
||
// Gitee源代码仓库:https://gitee.com/RRQM_Home
|
||
// Github源代码仓库:https://github.com/RRQM
|
||
// API首页:https://www.yuque.com/eo2w71/rrqm
|
||
// 交流QQ群:234762506
|
||
// 感谢您的下载和使用
|
||
//------------------------------------------------------------------------------
|
||
//------------------------------------------------------------------------------
|
||
|
||
#region License
|
||
|
||
// Copyright (c) 2007 James Newton-King
|
||
//
|
||
// Permission is hereby granted, free of charge, to any person
|
||
// obtaining a copy of this software and associated documentation
|
||
// files (the "Software"), to deal in the Software without
|
||
// restriction, including without limitation the rights to use,
|
||
// copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
// copies of the Software, and to permit persons to whom the
|
||
// Software is furnished to do so, subject to the following
|
||
// conditions:
|
||
//
|
||
// The above copyright notice and this permission notice shall be
|
||
// included in all copies or substantial portions of the Software.
|
||
//
|
||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
|
||
// OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
|
||
// HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
|
||
// WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
||
// OTHER DEALINGS IN THE SOFTWARE.
|
||
|
||
#endregion License
|
||
|
||
using RRQMCore.XREF.Newtonsoft.Json.Serialization;
|
||
using System;
|
||
|
||
namespace RRQMCore.XREF.Newtonsoft.Json
|
||
{
|
||
/// <summary>
|
||
/// Instructs the <see cref="JsonSerializer"/> how to serialize the object.
|
||
/// </summary>
|
||
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Interface, AllowMultiple = false)]
|
||
public abstract class JsonContainerAttribute : Attribute
|
||
{
|
||
/// <summary>
|
||
/// Gets or sets the id.
|
||
/// </summary>
|
||
/// <value>The id.</value>
|
||
public string Id { get; set; }
|
||
|
||
/// <summary>
|
||
/// Gets or sets the title.
|
||
/// </summary>
|
||
/// <value>The title.</value>
|
||
public string Title { get; set; }
|
||
|
||
/// <summary>
|
||
/// Gets or sets the description.
|
||
/// </summary>
|
||
/// <value>The description.</value>
|
||
public string Description { get; set; }
|
||
|
||
/// <summary>
|
||
/// Gets or sets the collection's items converter.
|
||
/// </summary>
|
||
/// <value>The collection's items converter.</value>
|
||
public Type ItemConverterType { get; set; }
|
||
|
||
/// <summary>
|
||
/// The parameter list to use when constructing the <see cref="JsonConverter"/> described by <see cref="ItemConverterType"/>.
|
||
/// If <c>null</c>, the default constructor is used.
|
||
/// When non-<c>null</c>, there must be a constructor defined in the <see cref="JsonConverter"/> that exactly matches the number,
|
||
/// order, and type of these parameters.
|
||
/// </summary>
|
||
/// <example>
|
||
/// <code>
|
||
/// [JsonContainer(ItemConverterType = typeof(MyContainerConverter), ItemConverterParameters = new object[] { 123, "Four" })]
|
||
/// </code>
|
||
/// </example>
|
||
public object[] ItemConverterParameters { get; set; }
|
||
|
||
/// <summary>
|
||
/// Gets or sets the <see cref="Type"/> of the <see cref="NamingStrategy"/>.
|
||
/// </summary>
|
||
/// <value>The <see cref="Type"/> of the <see cref="NamingStrategy"/>.</value>
|
||
public Type NamingStrategyType
|
||
{
|
||
get => this._namingStrategyType;
|
||
set
|
||
{
|
||
this._namingStrategyType = value;
|
||
this.NamingStrategyInstance = null;
|
||
}
|
||
}
|
||
|
||
/// <summary>
|
||
/// The parameter list to use when constructing the <see cref="NamingStrategy"/> described by <see cref="NamingStrategyType"/>.
|
||
/// If <c>null</c>, the default constructor is used.
|
||
/// When non-<c>null</c>, there must be a constructor defined in the <see cref="NamingStrategy"/> that exactly matches the number,
|
||
/// order, and type of these parameters.
|
||
/// </summary>
|
||
/// <example>
|
||
/// <code>
|
||
/// [JsonContainer(NamingStrategyType = typeof(MyNamingStrategy), NamingStrategyParameters = new object[] { 123, "Four" })]
|
||
/// </code>
|
||
/// </example>
|
||
public object[] NamingStrategyParameters
|
||
{
|
||
get => this._namingStrategyParameters;
|
||
set
|
||
{
|
||
this._namingStrategyParameters = value;
|
||
this.NamingStrategyInstance = null;
|
||
}
|
||
}
|
||
|
||
internal NamingStrategy NamingStrategyInstance { get; set; }
|
||
|
||
// yuck. can't set nullable properties on an attribute in C#
|
||
// have to use this approach to get an unset default state
|
||
internal bool? _isReference;
|
||
|
||
internal bool? _itemIsReference;
|
||
internal ReferenceLoopHandling? _itemReferenceLoopHandling;
|
||
internal TypeNameHandling? _itemTypeNameHandling;
|
||
private Type _namingStrategyType;
|
||
private object[] _namingStrategyParameters;
|
||
|
||
/// <summary>
|
||
/// Gets or sets a value that indicates whether to preserve object references.
|
||
/// </summary>
|
||
/// <value>
|
||
/// <c>true</c> to keep object reference; otherwise, <c>false</c>. The default is <c>false</c>.
|
||
/// </value>
|
||
public bool IsReference
|
||
{
|
||
get => this._isReference ?? default(bool);
|
||
set => this._isReference = value;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets or sets a value that indicates whether to preserve collection's items references.
|
||
/// </summary>
|
||
/// <value>
|
||
/// <c>true</c> to keep collection's items object references; otherwise, <c>false</c>. The default is <c>false</c>.
|
||
/// </value>
|
||
public bool ItemIsReference
|
||
{
|
||
get => this._itemIsReference ?? default(bool);
|
||
set => this._itemIsReference = value;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets or sets the reference loop handling used when serializing the collection's items.
|
||
/// </summary>
|
||
/// <value>The reference loop handling.</value>
|
||
public ReferenceLoopHandling ItemReferenceLoopHandling
|
||
{
|
||
get => this._itemReferenceLoopHandling ?? default(ReferenceLoopHandling);
|
||
set => this._itemReferenceLoopHandling = value;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Gets or sets the type name handling used when serializing the collection's items.
|
||
/// </summary>
|
||
/// <value>The type name handling.</value>
|
||
public TypeNameHandling ItemTypeNameHandling
|
||
{
|
||
get => this._itemTypeNameHandling ?? default(TypeNameHandling);
|
||
set => this._itemTypeNameHandling = value;
|
||
}
|
||
|
||
/// <summary>
|
||
/// Initializes a new instance of the <see cref="JsonContainerAttribute"/> class.
|
||
/// </summary>
|
||
protected JsonContainerAttribute()
|
||
{
|
||
}
|
||
|
||
/// <summary>
|
||
/// Initializes a new instance of the <see cref="JsonContainerAttribute"/> class with the specified container Id.
|
||
/// </summary>
|
||
/// <param name="id">The container Id.</param>
|
||
protected JsonContainerAttribute(string id)
|
||
{
|
||
this.Id = id;
|
||
}
|
||
}
|
||
} |