From 24a297697f8f3697c23b295e791df4d6e1c042c7 Mon Sep 17 00:00:00 2001 From: latonz Date: Sat, 26 Oct 2024 21:08:57 +0200 Subject: [PATCH] fix: lazy load types which are not available on netstandard2.0 --- .../Enumerables/CollectionInfoBuilder.cs | 81 ++++++++++++++----- .../Descriptors/Enumerables/CollectionType.cs | 2 + 2 files changed, 65 insertions(+), 18 deletions(-) diff --git a/src/Riok.Mapperly/Descriptors/Enumerables/CollectionInfoBuilder.cs b/src/Riok.Mapperly/Descriptors/Enumerables/CollectionInfoBuilder.cs index 8f065462c0..a7acfd8783 100644 --- a/src/Riok.Mapperly/Descriptors/Enumerables/CollectionInfoBuilder.cs +++ b/src/Riok.Mapperly/Descriptors/Enumerables/CollectionInfoBuilder.cs @@ -1,4 +1,3 @@ -using System.Collections.Immutable; using System.Diagnostics.CodeAnalysis; using Microsoft.CodeAnalysis; using Riok.Mapperly.Helpers; @@ -30,6 +29,8 @@ private readonly record struct CollectionTypeInfo( private static readonly CollectionTypeInfo _collectionTypeInfoArray = new(CollectionType.Array); + // types which may not be available on the target compiler platform + // are referenced via their full name instead of the reflection type private static readonly IReadOnlyCollection _collectionTypeInfos = [ new CollectionTypeInfo(CollectionType.IEnumerable, typeof(IEnumerable<>)), @@ -47,23 +48,67 @@ private readonly record struct CollectionTypeInfo( new CollectionTypeInfo(CollectionType.IDictionary, typeof(IDictionary<,>)), new CollectionTypeInfo(CollectionType.IReadOnlyDictionary, typeof(IReadOnlyDictionary<,>)), new CollectionTypeInfo(CollectionType.Dictionary, typeof(Dictionary<,>)), - new CollectionTypeInfo(CollectionType.ImmutableArray, typeof(ImmutableArray<>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableList, typeof(ImmutableList<>), Immutable: true), - new CollectionTypeInfo(CollectionType.IImmutableList, typeof(IImmutableList<>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableHashSet, typeof(ImmutableHashSet<>), Immutable: true), - new CollectionTypeInfo(CollectionType.IImmutableSet, typeof(IImmutableSet<>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableSortedSet, typeof(ImmutableSortedSet<>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableQueue, typeof(ImmutableQueue<>), Immutable: true), - new CollectionTypeInfo(CollectionType.IImmutableQueue, typeof(IImmutableQueue<>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableStack, typeof(ImmutableStack<>), Immutable: true), - new CollectionTypeInfo(CollectionType.IImmutableStack, typeof(IImmutableStack<>), Immutable: true), - new CollectionTypeInfo(CollectionType.IImmutableDictionary, typeof(IImmutableDictionary<,>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableDictionary, typeof(ImmutableDictionary<,>), Immutable: true), - new CollectionTypeInfo(CollectionType.ImmutableSortedDictionary, typeof(ImmutableSortedDictionary<,>), Immutable: true), - new CollectionTypeInfo(CollectionType.Span, typeof(Span<>)), - new CollectionTypeInfo(CollectionType.ReadOnlySpan, typeof(ReadOnlySpan<>)), - new CollectionTypeInfo(CollectionType.Memory, typeof(Memory<>)), - new CollectionTypeInfo(CollectionType.ReadOnlyMemory, typeof(ReadOnlyMemory<>)), + new CollectionTypeInfo( + CollectionType.ImmutableArray, + TypeFullName: "System.Collections.Immutable.ImmutableArray`1", + Immutable: true + ), + new CollectionTypeInfo(CollectionType.ImmutableList, TypeFullName: "System.Collections.Immutable.ImmutableList`1", Immutable: true), + new CollectionTypeInfo( + CollectionType.IImmutableList, + TypeFullName: "System.Collections.Immutable.IImmutableList`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.ImmutableHashSet, + TypeFullName: "System.Collections.Immutable.ImmutableHashSet`1", + Immutable: true + ), + new CollectionTypeInfo(CollectionType.IImmutableSet, TypeFullName: "System.Collections.Immutable.IImmutableSet`1", Immutable: true), + new CollectionTypeInfo( + CollectionType.ImmutableSortedSet, + TypeFullName: "System.Collections.Immutable.ImmutableSortedSet`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.ImmutableQueue, + TypeFullName: "System.Collections.Immutable.ImmutableQueue`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.IImmutableQueue, + TypeFullName: "System.Collections.Immutable.IImmutableQueue`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.ImmutableStack, + TypeFullName: "System.Collections.Immutable.ImmutableStack`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.IImmutableStack, + TypeFullName: "System.Collections.Immutable.IImmutableStack`1", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.IImmutableDictionary, + TypeFullName: "System.Collections.Immutable.IImmutableDictionary`2", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.ImmutableDictionary, + TypeFullName: "System.Collections.Immutable.ImmutableDictionary`2", + Immutable: true + ), + new CollectionTypeInfo( + CollectionType.ImmutableSortedDictionary, + TypeFullName: "System.Collections.Immutable.ImmutableSortedDictionary`2", + Immutable: true + ), + new CollectionTypeInfo(CollectionType.Span, TypeFullName: "System.Span`1"), + new CollectionTypeInfo(CollectionType.ReadOnlySpan, TypeFullName: "System.ReadOnlySpan`1"), + new CollectionTypeInfo(CollectionType.Memory, TypeFullName: "System.Memory`1"), + new CollectionTypeInfo(CollectionType.ReadOnlyMemory, TypeFullName: "System.ReadOnlyMemory`1"), ]; private static readonly IReadOnlyDictionary _collectionClrTypeByType = _collectionTypeInfos diff --git a/src/Riok.Mapperly/Descriptors/Enumerables/CollectionType.cs b/src/Riok.Mapperly/Descriptors/Enumerables/CollectionType.cs index d6fb3ffe06..c4b510b37f 100644 --- a/src/Riok.Mapperly/Descriptors/Enumerables/CollectionType.cs +++ b/src/Riok.Mapperly/Descriptors/Enumerables/CollectionType.cs @@ -1,3 +1,5 @@ +using System; + namespace Riok.Mapperly.Descriptors.Enumerables; [Flags]