// 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.Collections;
using System.Collections.Generic;
using System.Linq;
using CsvHelper.Configuration;
namespace CsvHelper.TypeConversion
{
///
/// Converts an to and from a .
///
public class IEnumerableGenericConverter : IEnumerableConverter
{
///
/// Converts the string to an object.
///
/// The string to convert to an object.
/// The for the current record.
/// The for the member being created.
/// The object created from the string.
public override object? ConvertFromString(string? text, IReaderRow row, MemberMapData memberMapData)
{
var type = memberMapData.Member.MemberType().GetGenericArguments()[0];
var listType = typeof(List<>);
listType = listType.MakeGenericType(type);
var list = (IList)ObjectResolver.Current.Resolve(listType);
var converter = row.Context.TypeConverterCache.GetConverter(type);
if (memberMapData.IsNameSet || row.Configuration.HasHeaderRecord && !memberMapData.IsIndexSet)
{
// Use the name.
var nameIndex = 0;
while (true)
{
if (!row.TryGetField(type, memberMapData.Names.FirstOrDefault(), nameIndex, out var field))
{
break;
}
list.Add(field);
nameIndex++;
}
}
else
{
// Use the index.
var indexEnd = memberMapData.IndexEnd < memberMapData.Index
? row.Parser.Count - 1
: memberMapData.IndexEnd;
for (var i = memberMapData.Index; i <= indexEnd; i++)
{
var field = converter.ConvertFromString(row.GetField(i), row, memberMapData);
list.Add(field);
}
}
return list;
}
}
}