Skip to content

Commit

Permalink
Update README.md
Browse files Browse the repository at this point in the history
  • Loading branch information
NikolayPianikov committed Mar 12, 2024
1 parent b8ceb87 commit 0ced977
Show file tree
Hide file tree
Showing 76 changed files with 2,452 additions and 2,077 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,7 @@ dotnet run
- [Simplified binding](readme/simplified-binding.md)
- [Factory](readme/factory.md)
- [Injection](readme/injection.md)
- [Generic composition roots](readme/generic-composition-roots.md)
- [Generics](readme/generics.md)
- [Arguments](readme/arguments.md)
- [Root arguments](readme/root-arguments.md)
Expand Down
43 changes: 22 additions & 21 deletions readme/ArrayDetails.md
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ classDiagram
/// <see cref="Pure.DI.Benchmarks.Model.CompositionRoot"/> PureDIByCR
/// </term>
/// <description>
/// Provides a composition root of type <see cref="Pure.DI.Benchmarks.Model.CompositionRoot"/>.
/// </description>
/// </item>
/// </list>
Expand All @@ -116,14 +117,14 @@ classDiagram
[global::System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
partial class Array
{
private readonly Array _rootM03D11di;
private readonly Array _rootM03D12di;

/// <summary>
/// This constructor creates a new instance of <see cref="Array"/>.
/// </summary>
public Array()
{
_rootM03D11di = this;
_rootM03D12di = this;
}

/// <summary>
Expand All @@ -132,7 +133,7 @@ partial class Array
/// <param name="baseComposition">Base composition.</param>
internal Array(Array baseComposition)
{
_rootM03D11di = baseComposition._rootM03D11di;
_rootM03D12di = baseComposition._rootM03D12di;
}

#region Composition Roots
Expand All @@ -156,7 +157,7 @@ partial class Array
#endif
public T Resolve<T>()
{
return ResolverM03D11di<T>.Value.Resolve(this);
return ResolverM03D12di<T>.Value.Resolve(this);
}

/// <summary>
Expand All @@ -170,7 +171,7 @@ partial class Array
#endif
public T Resolve<T>(object? tag)
{
return ResolverM03D11di<T>.Value.ResolveByTag(this, tag);
return ResolverM03D12di<T>.Value.ResolveByTag(this, tag);
}

/// <summary>
Expand All @@ -183,10 +184,10 @@ partial class Array
#endif
public object Resolve(global::System.Type type)
{
var index = (int)(_bucketSizeM03D11di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D11di;
var index = (int)(_bucketSizeM03D12di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D12di;
do {
ref var pair = ref _bucketsM03D11di[index];
ref var pair = ref _bucketsM03D12di[index];
if (ReferenceEquals(pair.Key, type))
{
return pair.Value.Resolve(this);
Expand All @@ -207,10 +208,10 @@ partial class Array
#endif
public object Resolve(global::System.Type type, object? tag)
{
var index = (int)(_bucketSizeM03D11di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D11di;
var index = (int)(_bucketSizeM03D12di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D12di;
do {
ref var pair = ref _bucketsM03D11di[index];
ref var pair = ref _bucketsM03D12di[index];
if (ReferenceEquals(pair.Key, type))
{
return pair.Value.ResolveByTag(this, tag);
Expand Down Expand Up @@ -303,26 +304,26 @@ partial class Array
" Array ..> CompositionRoot : CompositionRoot PureDIByCR";
}

private readonly static int _bucketSizeM03D11di;
private readonly static global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Array, object>>[] _bucketsM03D11di;
private readonly static int _bucketSizeM03D12di;
private readonly static global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Array, object>>[] _bucketsM03D12di;

static Array()
{
var valResolverM03D11di_0000 = new ResolverM03D11di_0000();
ResolverM03D11di<Pure.DI.Benchmarks.Model.CompositionRoot>.Value = valResolverM03D11di_0000;
_bucketsM03D11di = global::Pure.DI.Buckets<global::System.Type, global::Pure.DI.IResolver<Array, object>>.Create(
var valResolverM03D12di_0000 = new ResolverM03D12di_0000();
ResolverM03D12di<Pure.DI.Benchmarks.Model.CompositionRoot>.Value = valResolverM03D12di_0000;
_bucketsM03D12di = global::Pure.DI.Buckets<global::System.Type, global::Pure.DI.IResolver<Array, object>>.Create(
1,
out _bucketSizeM03D11di,
out _bucketSizeM03D12di,
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Array, object>>[1]
{
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Array, object>>(typeof(Pure.DI.Benchmarks.Model.CompositionRoot), valResolverM03D11di_0000)
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Array, object>>(typeof(Pure.DI.Benchmarks.Model.CompositionRoot), valResolverM03D12di_0000)
});
}

#region Resolvers
private sealed class ResolverM03D11di<T>: global::Pure.DI.IResolver<Array, T>
private sealed class ResolverM03D12di<T>: global::Pure.DI.IResolver<Array, T>
{
public static global::Pure.DI.IResolver<Array, T> Value = new ResolverM03D11di<T>();
public static global::Pure.DI.IResolver<Array, T> Value = new ResolverM03D12di<T>();

public T Resolve(Array composite)
{
Expand All @@ -335,7 +336,7 @@ partial class Array
}
}

private sealed class ResolverM03D11di_0000: global::Pure.DI.IResolver<Array, Pure.DI.Benchmarks.Model.CompositionRoot>
private sealed class ResolverM03D12di_0000: global::Pure.DI.IResolver<Array, Pure.DI.Benchmarks.Model.CompositionRoot>
{
public Pure.DI.Benchmarks.Model.CompositionRoot Resolve(Array composition)
{
Expand Down
49 changes: 25 additions & 24 deletions readme/EnumDetails.md
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ classDiagram
/// <see cref="Pure.DI.Benchmarks.Model.CompositionRoot"/> PureDIByCR
/// </term>
/// <description>
/// Provides a composition root of type <see cref="Pure.DI.Benchmarks.Model.CompositionRoot"/>.
/// </description>
/// </item>
/// </list>
Expand All @@ -116,14 +117,14 @@ classDiagram
[global::System.Diagnostics.CodeAnalysis.ExcludeFromCodeCoverage]
partial class Enum
{
private readonly Enum _rootM03D11di;
private readonly Enum _rootM03D12di;

/// <summary>
/// This constructor creates a new instance of <see cref="Enum"/>.
/// </summary>
public Enum()
{
_rootM03D11di = this;
_rootM03D12di = this;
}

/// <summary>
Expand All @@ -132,7 +133,7 @@ partial class Enum
/// <param name="baseComposition">Base composition.</param>
internal Enum(Enum baseComposition)
{
_rootM03D11di = baseComposition._rootM03D11di;
_rootM03D12di = baseComposition._rootM03D12di;
}

#region Composition Roots
Expand All @@ -142,15 +143,15 @@ partial class Enum
public partial Pure.DI.Benchmarks.Model.CompositionRoot PureDIByCR()
{
[global::System.Runtime.CompilerServices.MethodImpl((global::System.Runtime.CompilerServices.MethodImplOptions)0x200)]
System.Collections.Generic.IEnumerable<Pure.DI.Benchmarks.Model.IService3> LocalperBlockM03D11di10_IEnumerable()
System.Collections.Generic.IEnumerable<Pure.DI.Benchmarks.Model.IService3> LocalperBlockM03D12di10_IEnumerable()
{
yield return new Pure.DI.Benchmarks.Model.Service3(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
yield return new Pure.DI.Benchmarks.Model.Service3v2(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
yield return new Pure.DI.Benchmarks.Model.Service3v3(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
yield return new Pure.DI.Benchmarks.Model.Service3v4(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
}
var perBlockM03D11di10_IEnumerable = LocalperBlockM03D11di10_IEnumerable();
return new Pure.DI.Benchmarks.Model.CompositionRoot(new Pure.DI.Benchmarks.Model.Service1(new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D11di10_IEnumerable)), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D11di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D11di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D11di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service3(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4()), new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
var perBlockM03D12di10_IEnumerable = LocalperBlockM03D12di10_IEnumerable();
return new Pure.DI.Benchmarks.Model.CompositionRoot(new Pure.DI.Benchmarks.Model.Service1(new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D12di10_IEnumerable)), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D12di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D12di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service2Enum(perBlockM03D12di10_IEnumerable), new Pure.DI.Benchmarks.Model.Service3(new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4()), new Pure.DI.Benchmarks.Model.Service4(), new Pure.DI.Benchmarks.Model.Service4());
}
#endregion

Expand All @@ -165,7 +166,7 @@ partial class Enum
#endif
public T Resolve<T>()
{
return ResolverM03D11di<T>.Value.Resolve(this);
return ResolverM03D12di<T>.Value.Resolve(this);
}

/// <summary>
Expand All @@ -179,7 +180,7 @@ partial class Enum
#endif
public T Resolve<T>(object? tag)
{
return ResolverM03D11di<T>.Value.ResolveByTag(this, tag);
return ResolverM03D12di<T>.Value.ResolveByTag(this, tag);
}

/// <summary>
Expand All @@ -192,10 +193,10 @@ partial class Enum
#endif
public object Resolve(global::System.Type type)
{
var index = (int)(_bucketSizeM03D11di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D11di;
var index = (int)(_bucketSizeM03D12di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D12di;
do {
ref var pair = ref _bucketsM03D11di[index];
ref var pair = ref _bucketsM03D12di[index];
if (ReferenceEquals(pair.Key, type))
{
return pair.Value.Resolve(this);
Expand All @@ -216,10 +217,10 @@ partial class Enum
#endif
public object Resolve(global::System.Type type, object? tag)
{
var index = (int)(_bucketSizeM03D11di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D11di;
var index = (int)(_bucketSizeM03D12di * ((uint)global::System.Runtime.CompilerServices.RuntimeHelpers.GetHashCode(type) % 1));
var finish = index + _bucketSizeM03D12di;
do {
ref var pair = ref _bucketsM03D11di[index];
ref var pair = ref _bucketsM03D12di[index];
if (ReferenceEquals(pair.Key, type))
{
return pair.Value.ResolveByTag(this, tag);
Expand Down Expand Up @@ -312,26 +313,26 @@ partial class Enum
" Enum ..> CompositionRoot : CompositionRoot PureDIByCR";
}

private readonly static int _bucketSizeM03D11di;
private readonly static global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Enum, object>>[] _bucketsM03D11di;
private readonly static int _bucketSizeM03D12di;
private readonly static global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Enum, object>>[] _bucketsM03D12di;

static Enum()
{
var valResolverM03D11di_0000 = new ResolverM03D11di_0000();
ResolverM03D11di<Pure.DI.Benchmarks.Model.CompositionRoot>.Value = valResolverM03D11di_0000;
_bucketsM03D11di = global::Pure.DI.Buckets<global::System.Type, global::Pure.DI.IResolver<Enum, object>>.Create(
var valResolverM03D12di_0000 = new ResolverM03D12di_0000();
ResolverM03D12di<Pure.DI.Benchmarks.Model.CompositionRoot>.Value = valResolverM03D12di_0000;
_bucketsM03D12di = global::Pure.DI.Buckets<global::System.Type, global::Pure.DI.IResolver<Enum, object>>.Create(
1,
out _bucketSizeM03D11di,
out _bucketSizeM03D12di,
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Enum, object>>[1]
{
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Enum, object>>(typeof(Pure.DI.Benchmarks.Model.CompositionRoot), valResolverM03D11di_0000)
new global::Pure.DI.Pair<global::System.Type, global::Pure.DI.IResolver<Enum, object>>(typeof(Pure.DI.Benchmarks.Model.CompositionRoot), valResolverM03D12di_0000)
});
}

#region Resolvers
private sealed class ResolverM03D11di<T>: global::Pure.DI.IResolver<Enum, T>
private sealed class ResolverM03D12di<T>: global::Pure.DI.IResolver<Enum, T>
{
public static global::Pure.DI.IResolver<Enum, T> Value = new ResolverM03D11di<T>();
public static global::Pure.DI.IResolver<Enum, T> Value = new ResolverM03D12di<T>();

public T Resolve(Enum composite)
{
Expand All @@ -344,7 +345,7 @@ partial class Enum
}
}

private sealed class ResolverM03D11di_0000: global::Pure.DI.IResolver<Enum, Pure.DI.Benchmarks.Model.CompositionRoot>
private sealed class ResolverM03D12di_0000: global::Pure.DI.IResolver<Enum, Pure.DI.Benchmarks.Model.CompositionRoot>
{
public Pure.DI.Benchmarks.Model.CompositionRoot Resolve(Enum composition)
{
Expand Down
Loading

0 comments on commit 0ced977

Please sign in to comment.