summaryrefslogtreecommitdiff
path: root/ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs
diff options
context:
space:
mode:
Diffstat (limited to 'ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs')
-rw-r--r--ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs143
1 files changed, 143 insertions, 0 deletions
diff --git a/ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs b/ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs
new file mode 100644
index 0000000..99a17e0
--- /dev/null
+++ b/ThirdParty/CsvHelper-master/src/CsvHelper/ObjectResolver.cs
@@ -0,0 +1,143 @@
+// 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
+{
+ /// <summary>
+ /// Creates objects from a given type.
+ /// </summary>
+ public class ObjectResolver : IObjectResolver
+ {
+ private static IObjectResolver current;
+ private readonly ObjectCreator objectCreator = new ObjectCreator();
+
+ /// <summary>
+ /// Gets or sets the current resolver.
+ /// Use an instance of this instead if at all possible.
+ /// </summary>
+ public static IObjectResolver Current
+ {
+ get
+ {
+ return current;
+ }
+ set
+ {
+ if (value == null)
+ {
+ throw new InvalidOperationException($"{nameof(IObjectResolver)} cannot be null.");
+ }
+
+ current = value;
+ }
+ }
+
+ /// <summary>
+ /// A value indicating if the resolver's <see cref="CanResolve"/>
+ /// returns false that an object will still be created using
+ /// CsvHelper's object creation. True to fallback, otherwise false.
+ /// Default value is true.
+ /// </summary>
+ public bool UseFallback { get; private set; }
+
+ /// <summary>
+ /// A function that returns a value indicating if the resolver
+ /// is able to resolve the given type. True if the type can be
+ /// resolved, otherwise false.
+ /// </summary>
+ public Func<Type, bool> CanResolve { get; private set; }
+
+ /// <summary>
+ /// The function that creates an object from a given type.
+ /// </summary>
+ public Func<Type, object[], object> ResolveFunction { get; private set; }
+
+ static ObjectResolver()
+ {
+ var objectCreator = new ObjectCreator();
+ var locker = new object();
+ current = new ObjectResolver(type => true, (type, args) =>
+ {
+ lock (locker)
+ {
+ return objectCreator.CreateInstance(type, args);
+ }
+ });
+ }
+
+ /// <summary>
+ /// Creates an instance of the object resolver using default values.
+ /// </summary>
+ public ObjectResolver()
+ {
+ CanResolve = type => true;
+ ResolveFunction = ResolveWithObjectCreator;
+ UseFallback = true;
+ }
+
+ /// <summary>
+ /// Creates an instance of the object resolver using the given can create function
+ /// and create function.
+ /// </summary>
+ /// <param name="canResolve">A function that returns a value indicating if the resolver
+ /// is able to resolve the given type. True if the type can be
+ /// resolved, otherwise false.</param>
+ /// <param name="resolveFunction">The function that creates an object from a given type.</param>
+ /// <param name="useFallback">A value indicating if the resolver's <see cref="CanResolve"/>
+ /// returns false that an object will still be created using
+ /// CsvHelper's object creation. True to fallback, otherwise false.
+ /// Default value is true.</param>
+ public ObjectResolver(Func<Type, bool> canResolve, Func<Type, object[], object> resolveFunction, bool useFallback = true)
+ {
+ CanResolve = canResolve ?? throw new ArgumentNullException(nameof(canResolve));
+ ResolveFunction = resolveFunction ?? throw new ArgumentNullException(nameof(resolveFunction));
+ UseFallback = useFallback;
+ }
+
+ /// <summary>
+ /// Creates an object from the given type using the <see cref="ResolveFunction"/>
+ /// function. If <see cref="CanResolve"/> is false, the object will be
+ /// created using CsvHelper's default object creation. If <see cref="UseFallback"/>
+ /// is false, an exception is thrown.
+ /// </summary>
+ /// <param name="type">The type to create an instance from. The created object
+ /// may not be the same type as the given type.</param>
+ /// <param name="constructorArgs">Constructor arguments used to create the type.</param>
+ public object Resolve(Type type, params object[] constructorArgs)
+ {
+ if (CanResolve(type))
+ {
+ return ResolveFunction(type, constructorArgs);
+ }
+
+ if (UseFallback)
+ {
+ return objectCreator.CreateInstance(type, constructorArgs);
+ }
+
+ throw new CsvHelperException($"Type '{type.FullName}' can't be resolved and fallback is turned off.");
+ }
+
+ /// <summary>
+ /// Creates an object from the given type using the <see cref="ResolveFunction"/>
+ /// function. If <see cref="CanResolve"/> is false, the object will be
+ /// created using CsvHelper's default object creation. If <see cref="UseFallback"/>
+ /// is false, an exception is thrown.
+ /// </summary>
+ /// <typeparam name="T">The type to create an instance from. The created object
+ /// may not be the same type as the given type.</typeparam>
+ /// <param name="constructorArgs">Constructor arguments used to create the type.</param>
+ public T Resolve<T>(params object[] constructorArgs)
+ {
+ return (T)Resolve(typeof(T), constructorArgs);
+ }
+
+ private object ResolveWithObjectCreator(Type type, params object[] args)
+ {
+ return objectCreator.CreateInstance(type, args);
+ }
+ }
+}