From 21b3fdc467d7e71378dcf6c225759080585453cc Mon Sep 17 00:00:00 2001 From: Mike-E Date: Thu, 3 Dec 2020 01:32:39 -0500 Subject: [PATCH 1/3] Exposed MigrationsExtension. --- .../ExtensionModel/Xml/MigrationsExtension.cs | 9 ++++++++- .../Issue483Tests.cs | 19 +++++++++++++++++++ 2 files changed, 27 insertions(+), 1 deletion(-) create mode 100644 test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue483Tests.cs diff --git a/src/ExtendedXmlSerializer/ExtensionModel/Xml/MigrationsExtension.cs b/src/ExtendedXmlSerializer/ExtensionModel/Xml/MigrationsExtension.cs index 48bbdfc0e..0c9518305 100644 --- a/src/ExtendedXmlSerializer/ExtensionModel/Xml/MigrationsExtension.cs +++ b/src/ExtendedXmlSerializer/ExtensionModel/Xml/MigrationsExtension.cs @@ -19,13 +19,20 @@ namespace ExtendedXmlSerializer.ExtensionModel.Xml { - sealed class MigrationsExtension : TypedTable>>, ISerializerExtension + /// + /// This extension is meant for internal use, but has been exposed for extension authors who require access to it. + /// + /// + public sealed class MigrationsExtension : TypedTable>>, ISerializerExtension { + /// [UsedImplicitly] public MigrationsExtension() : this(new Dictionary>>()) {} + /// public MigrationsExtension(IDictionary>> store) : base(store) {} + /// public IServiceRepository Get(IServiceRepository parameter) => parameter.Decorate(Register); IContents Register(IServiceProvider services, IContents contents) diff --git a/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue483Tests.cs b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue483Tests.cs new file mode 100644 index 000000000..bacc30e65 --- /dev/null +++ b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue483Tests.cs @@ -0,0 +1,19 @@ +using ExtendedXmlSerializer.Configuration; +using ExtendedXmlSerializer.ExtensionModel.Xml; +using FluentAssertions; +using Xunit; + +namespace ExtendedXmlSerializer.Tests.ReportedIssues +{ + public sealed class Issue483Tests + { + [Fact] + public void Verify() + { + new ConfigurationContainer().Type().Root.With().Should().NotBeNull(); + + } + + + } +} From 787bfb8b6d4361ef8ad98c402f0fc3ccf021ac9c Mon Sep 17 00:00:00 2001 From: Mike-E Date: Thu, 3 Dec 2020 01:32:53 -0500 Subject: [PATCH 2/3] Attended to warnings. --- .../Issue477Tests_Extended.cs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue477Tests_Extended.cs b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue477Tests_Extended.cs index 3048e3919..60695f2ee 100644 --- a/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue477Tests_Extended.cs +++ b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue477Tests_Extended.cs @@ -3,6 +3,7 @@ using FluentAssertions; using System; using Xunit; +// ReSharper disable All namespace ExtendedXmlSerializer.Tests.ReportedIssues { @@ -33,9 +34,11 @@ public void Verify() class Test { - public DateTime Date1 { get; set; } = DateTime.Now; // Formatted OK - public DateTime? Date2 { get; set; } = null; // Is not emitted = OK - public DateTime? Date3 { get; set; } = DateTime.Now; // Completety ignores configured formatting + readonly static DateTime Now = new DateTime(2020, 11, 23); + + public DateTime Date1 { get; set; } = Now; // Formatted OK + public DateTime? Date2 { get; set; } = null; // Is not emitted = OK + public DateTime? Date3 { get; set; } = Now; // Completety ignores configured formatting } } } \ No newline at end of file From 226d766d6d329b6f7fe76e7a297c22fefd33ef10 Mon Sep 17 00:00:00 2001 From: Mike-E Date: Thu, 3 Dec 2020 04:10:54 -0500 Subject: [PATCH 3/3] Added support for ImmutableLists --- .../ExtensionModel/DefaultExtensions.cs | 1 + .../Types/ImmutableListExtension.cs | 94 +++++++++++++++++++ .../Issue485Tests.cs | 25 +++++ 3 files changed, 120 insertions(+) create mode 100644 src/ExtendedXmlSerializer/ExtensionModel/Types/ImmutableListExtension.cs create mode 100644 test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue485Tests.cs diff --git a/src/ExtendedXmlSerializer/ExtensionModel/DefaultExtensions.cs b/src/ExtendedXmlSerializer/ExtensionModel/DefaultExtensions.cs index 94deaf682..964ee2451 100644 --- a/src/ExtendedXmlSerializer/ExtensionModel/DefaultExtensions.cs +++ b/src/ExtendedXmlSerializer/ExtensionModel/DefaultExtensions.cs @@ -59,6 +59,7 @@ public override IEnumerator GetEnumerator() yield return new AllowedMemberValuesExtension(); yield return new MemberFormatExtension(); yield return ImmutableArrayExtension.Default; + yield return ImmutableListExtension.Default; yield return SerializationExtension.Default; yield return NullableStructureAwareExtension.Default; yield return new CustomSerializationExtension(); diff --git a/src/ExtendedXmlSerializer/ExtensionModel/Types/ImmutableListExtension.cs b/src/ExtendedXmlSerializer/ExtensionModel/Types/ImmutableListExtension.cs new file mode 100644 index 000000000..4fd1be181 --- /dev/null +++ b/src/ExtendedXmlSerializer/ExtensionModel/Types/ImmutableListExtension.cs @@ -0,0 +1,94 @@ +using ExtendedXmlSerializer.ContentModel; +using ExtendedXmlSerializer.ContentModel.Collections; +using ExtendedXmlSerializer.ContentModel.Content; +using ExtendedXmlSerializer.ContentModel.Format; +using ExtendedXmlSerializer.ContentModel.Identification; +using ExtendedXmlSerializer.ContentModel.Reflection; +using ExtendedXmlSerializer.Core; +using ExtendedXmlSerializer.Core.Specifications; +using ExtendedXmlSerializer.ReflectionModel; +using JetBrains.Annotations; +using System.Collections.Immutable; +using System.Collections.ObjectModel; +using System.Reflection; + +namespace ExtendedXmlSerializer.ExtensionModel.Types +{ + sealed class ImmutableListExtension : ISerializerExtension + { + public static ImmutableListExtension Default { get; } = new ImmutableListExtension(); + + ImmutableListExtension() : this(new IsAssignableGenericSpecification(typeof(ImmutableList<>))) {} + + readonly ISpecification _specification; + + public ImmutableListExtension(ISpecification specification) => _specification = specification; + + public IServiceRepository Get(IServiceRepository parameter) + => parameter.DecorateContentsWith() + .When(_specification) + .Decorate(); + + void ICommand.Execute(IServices parameter) {} + + sealed class GenericTypes : IGenericTypes + { + readonly static TypeInfo Check = typeof(ImmutableList).GetTypeInfo(); + readonly static ImmutableArray Type = typeof(ImmutableList<>).GetTypeInfo() + .Yield() + .ToImmutableArray(); + + readonly IGenericTypes _types; + + public GenericTypes(IGenericTypes types) => _types = types; + + public ImmutableArray Get(IIdentity parameter) + { + var type = _types.Get(parameter); + var result = Equals(type.Only(), Check) ? Type : type; + return result; + } + } + + sealed class ImmutableLists : Collections + { + public ImmutableLists(RuntimeSerializers serializers, Contents contents) : base(serializers, contents) {} + } + + sealed class Contents : ICollectionContents + { + readonly IInnerContentServices _contents; + readonly IEnumerators _enumerators; + + public Contents(IInnerContentServices contents, IEnumerators enumerators) + { + _contents = contents; + _enumerators = enumerators; + } + + public ISerializer Get(CollectionContentInput parameter) + => new Serializer(Readers.Instance.Get(parameter.ItemType)(_contents, parameter.Item), + new EnumerableWriter(_enumerators, parameter.Item).Adapt()); + + sealed class Readers : Generic + { + public static Readers Instance { get; } = new Readers(); + + Readers() : base(typeof(Reader<>)) {} + } + + sealed class Reader : IReader + { + readonly IReader> _reader; + + [UsedImplicitly] + public Reader(IInnerContentServices services, IReader item) + : this(services.CreateContents>(new CollectionInnerContentHandler(item, services))) {} + + Reader(IReader> reader) => _reader = reader; + + public object Get(IFormatReader parameter) => _reader.Get(parameter).ToImmutableList(); + } + } + } +} \ No newline at end of file diff --git a/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue485Tests.cs b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue485Tests.cs new file mode 100644 index 000000000..b03764038 --- /dev/null +++ b/test/ExtendedXmlSerializer.Tests.ReportedIssues/Issue485Tests.cs @@ -0,0 +1,25 @@ +using ExtendedXmlSerializer.Configuration; +using ExtendedXmlSerializer.Tests.ReportedIssues.Support; +using FluentAssertions; +using System.Collections.Immutable; +using Xunit; + +namespace ExtendedXmlSerializer.Tests.ReportedIssues +{ + public sealed class Issue485Tests + { + [Fact] + public void Verify() + { + var instance = new[] { 1, 2, 3, 4 }.ToImmutableList(); + + var serializer = new ConfigurationContainer().UseAutoFormatting() + .UseOptimizedNamespaces() + .EnableParameterizedContentWithPropertyAssignments() + .Create() + .ForTesting(); + + serializer.Cycle(instance).Should().BeEquivalentTo(instance); + } + } +} \ No newline at end of file