From 2a1cd4fda8a4a8e649910d16b4dfa1ce7ae63543 Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Fri, 12 May 2023 09:24:40 +0800 Subject: *misc --- .../src/CsvHelper/IObjectResolver.cs | 57 ++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 ThirdParty/CsvHelper-master/src/CsvHelper/IObjectResolver.cs (limited to 'ThirdParty/CsvHelper-master/src/CsvHelper/IObjectResolver.cs') diff --git a/ThirdParty/CsvHelper-master/src/CsvHelper/IObjectResolver.cs b/ThirdParty/CsvHelper-master/src/CsvHelper/IObjectResolver.cs new file mode 100644 index 0000000..c419114 --- /dev/null +++ b/ThirdParty/CsvHelper-master/src/CsvHelper/IObjectResolver.cs @@ -0,0 +1,57 @@ +// Copyright 2009-2022 Josh Close +// This file is a part of CsvHelper and is dual licensed under MS-PL and Apache 2.0. +// See LICENSE.txt for details or visit http://www.opensource.org/licenses/ms-pl.html for MS-PL and http://opensource.org/licenses/Apache-2.0 for Apache 2.0. +// https://github.com/JoshClose/CsvHelper +using System; + +namespace CsvHelper +{ + /// + /// Defines the functionality of a class that creates objects + /// from a given type. + /// + public interface IObjectResolver + { + /// + /// A value indicating if the resolver's + /// returns false that an object will still be created using + /// CsvHelper's object creation. True to fallback, otherwise false. + /// Default value is true. + /// + bool UseFallback { get; } + + /// + /// A value indicating if the resolver is able to resolve + /// the given type. True if the type can be resolved, + /// otherwise false. + /// + Func CanResolve { get; } + + /// + /// The function that creates an object from a given type. + /// + Func ResolveFunction { get; } + + /// + /// Creates an object from the given type using the + /// function. If is false, the object will be + /// created using CsvHelper's default object creation. If + /// is false, an exception is thrown. + /// + /// The type to create an instance from. The created object + /// may not be the same type as the given type. + /// Constructor arguments used to create the type. + object Resolve( Type type, params object[] constructorArgs ); + + /// + /// Creates an object from the given type using the + /// function. If is false, the object will be + /// created using CsvHelper's default object creation. If + /// is false, an exception is thrown. + /// + /// The type to create an instance from. The created object + /// may not be the same type as the given type. + /// Constructor arguments used to create the type. + T Resolve( params object[] constructorArgs ); + } +} -- cgit v1.1-26-g67d0