// 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.Configuration.Attributes { /// /// Gets a value indicating that during writing if a new /// object should be created when a reference member is null. /// True to create a new object and use it's defaults for the /// fields, or false to leave the fields empty for all the /// reference member's member. /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = false, Inherited = true)] public class UseNewObjectForNullReferenceMembersAttribute : Attribute, IClassMapper { /// /// Gets a value indicating that during writing if a new /// object should be created when a reference member is null. /// True to create a new object and use it's defaults for the /// fields, or false to leave the fields empty for all the /// reference member's member. /// public bool UseNewObjectForNullReferenceMembers { get; private set; } /// /// Gets a value indicating that during writing if a new /// object should be created when a reference member is null. /// True to create a new object and use it's defaults for the /// fields, or false to leave the fields empty for all the /// reference member's member. /// /// The value. public UseNewObjectForNullReferenceMembersAttribute(bool useNewObjectForNullReferenceMembers) { UseNewObjectForNullReferenceMembers = useNewObjectForNullReferenceMembers; } /// public void ApplyTo(CsvConfiguration configuration) { configuration.UseNewObjectForNullReferenceMembers = UseNewObjectForNullReferenceMembers; } } }