mirror of
https://github.com/wabbajack-tools/wabbajack.git
synced 2024-08-30 18:42:17 +00:00
Several fixes to the compiler performance code
This commit is contained in:
parent
e71abd82f7
commit
6958f34c32
@ -62,6 +62,47 @@ public static class AsyncParallelExtensions
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Faster version of PMapAll for when the function invocation will take a very small amount of time
|
||||
/// batches all the inputs into N groups and executes them all on one task, where N is the number of
|
||||
/// threads supported by the limiter
|
||||
/// </summary>
|
||||
/// <param name="coll"></param>
|
||||
/// <param name="limiter"></param>
|
||||
/// <param name="mapFn"></param>
|
||||
/// <typeparam name="TIn"></typeparam>
|
||||
/// <typeparam name="TJob"></typeparam>
|
||||
/// <typeparam name="TOut"></typeparam>
|
||||
/// <returns></returns>
|
||||
public static async IAsyncEnumerable<TOut> PMapAllBatched<TIn, TJob, TOut>(this IEnumerable<TIn> coll,
|
||||
IResource<TJob> limiter, Func<TIn, Task<TOut>> mapFn)
|
||||
{
|
||||
var asList = coll.ToList();
|
||||
|
||||
var tasks = new List<Task<List<TOut>>>();
|
||||
|
||||
tasks.AddRange(Enumerable.Range(0, limiter.MaxTasks).Select(i => Task.Run(async () =>
|
||||
{
|
||||
using var job = await limiter.Begin(limiter.Name, asList.Count / limiter.MaxTasks, CancellationToken.None);
|
||||
var list = new List<TOut>();
|
||||
for (var idx = i; idx < asList.Count; idx += limiter.MaxTasks)
|
||||
{
|
||||
job.ReportNoWait(1);
|
||||
list.Add(await mapFn(asList[idx]));
|
||||
}
|
||||
|
||||
return list;
|
||||
})));
|
||||
|
||||
foreach (var result in tasks)
|
||||
{
|
||||
foreach (var itm in (await result))
|
||||
{
|
||||
yield return itm;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static async IAsyncEnumerable<TOut> PKeepAll<TIn, TJob, TOut>(this IEnumerable<TIn> coll,
|
||||
IResource<TJob> limiter, Func<TIn, Task<TOut>> mapFn)
|
||||
where TOut : class
|
||||
|
@ -1,6 +1,7 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Reflection.Metadata;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace Wabbajack.Common;
|
||||
@ -13,6 +14,7 @@ public static class IEnumerableExtensions
|
||||
}
|
||||
|
||||
#region Shuffle
|
||||
|
||||
/// https://stackoverflow.com/questions/5807128/an-extension-method-on-ienumerable-needed-for-shuffling
|
||||
|
||||
public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> source, Random rng)
|
||||
@ -32,6 +34,7 @@ public static class IEnumerableExtensions
|
||||
buffer[j] = buffer[i];
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
|
||||
@ -55,6 +58,22 @@ public static class IEnumerableExtensions
|
||||
return data;
|
||||
}
|
||||
|
||||
public static IEnumerable<IEnumerable<T>> Partition<T>(this IEnumerable<T> coll, int size)
|
||||
{
|
||||
var asList = coll.ToList();
|
||||
|
||||
IEnumerable<T> SkipEnumerable(IList<T> list, int offset, int size)
|
||||
{
|
||||
for (var i = offset; i < list.Count; i += size)
|
||||
{
|
||||
yield return list[i];
|
||||
}
|
||||
}
|
||||
|
||||
return Enumerable.Range(0, size).Select(offset => SkipEnumerable(asList, offset, size));
|
||||
}
|
||||
|
||||
|
||||
public static IEnumerable<T> OnEach<T>(this IEnumerable<T> coll, Action<T> fn)
|
||||
{
|
||||
foreach (var itm in coll)
|
||||
|
@ -141,7 +141,7 @@ public class MO2Compiler : ACompiler
|
||||
var stack = MakeStack();
|
||||
|
||||
NextStep("Compiling", "Running Compilation Stack", AllFiles.Count);
|
||||
var results = await AllFiles.PMapAll(CompilerLimiter, f =>
|
||||
var results = await AllFiles.PMapAllBatched(CompilerLimiter, f =>
|
||||
{
|
||||
UpdateProgress(1);
|
||||
return RunStack(stack, f);
|
||||
|
@ -1,6 +1,7 @@
|
||||
using System;
|
||||
using System.Diagnostics;
|
||||
using System.IO;
|
||||
using System.Linq;
|
||||
using System.Reflection;
|
||||
|
||||
namespace Wabbajack.Paths.IO;
|
||||
@ -13,8 +14,15 @@ public static class KnownFolders
|
||||
{
|
||||
var result = Process.GetCurrentProcess().MainModule?.FileName?.ToAbsolutePath() ?? default;
|
||||
|
||||
if (result != default &&
|
||||
result.PathParts.Any(p => p.Equals("TestRunner", StringComparison.CurrentCultureIgnoreCase)))
|
||||
{
|
||||
return Assembly.GetExecutingAssembly().Location.ToAbsolutePath().Parent;
|
||||
}
|
||||
|
||||
if ((result != default && result.Depth > 1 && result.FileName == "dotnet".ToRelativePath()) || Assembly.GetEntryAssembly() != null)
|
||||
|
||||
if ((result != default && result.Depth > 1 && result.FileName == "dotnet".ToRelativePath())
|
||||
|| Assembly.GetEntryAssembly() != null)
|
||||
{
|
||||
result = Assembly.GetEntryAssembly()!.Location.ToAbsolutePath();
|
||||
}
|
||||
|
@ -21,6 +21,8 @@ public struct AbsolutePath : IPath, IComparable<AbsolutePath>, IEquatable<Absolu
|
||||
|
||||
internal readonly string[] Parts;
|
||||
|
||||
public string[] PathParts => Parts == default ? Array.Empty<string>() : Parts;
|
||||
|
||||
public Extension Extension => Extension.FromPath(Parts[^1]);
|
||||
public RelativePath FileName => new(Parts[^1..]);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user