2021-10-12 03:49:01 +00:00
|
|
|
using System;
|
2021-10-27 04:28:01 +00:00
|
|
|
using System.Reactive.Disposables;
|
2021-10-12 03:49:01 +00:00
|
|
|
using System.Threading;
|
2021-10-12 05:19:13 +00:00
|
|
|
using System.Threading.Tasks;
|
2021-10-15 04:20:27 +00:00
|
|
|
using Avalonia.Threading;
|
2021-10-12 03:49:01 +00:00
|
|
|
using Microsoft.Extensions.DependencyInjection;
|
2021-10-12 05:19:13 +00:00
|
|
|
using Microsoft.Extensions.Logging;
|
2021-10-12 03:49:01 +00:00
|
|
|
using ReactiveUI;
|
2021-10-15 04:20:27 +00:00
|
|
|
using ReactiveUI.Fody.Helpers;
|
2021-10-12 03:49:01 +00:00
|
|
|
using Wabbajack.App.Messages;
|
|
|
|
using Wabbajack.App.ViewModels;
|
2021-10-12 05:19:13 +00:00
|
|
|
using Wabbajack.Common;
|
2021-10-12 03:49:01 +00:00
|
|
|
using Wabbajack.Compiler;
|
2021-10-15 04:20:27 +00:00
|
|
|
using Wabbajack.RateLimiter;
|
2021-10-12 03:49:01 +00:00
|
|
|
|
|
|
|
namespace Wabbajack.App.Screens;
|
|
|
|
|
2021-10-27 04:28:01 +00:00
|
|
|
public class CompilationViewModel : ViewModelBase
|
2021-10-12 03:49:01 +00:00
|
|
|
{
|
2021-10-23 16:51:17 +00:00
|
|
|
private readonly ILogger<CompilationViewModel> _logger;
|
2021-10-12 03:49:01 +00:00
|
|
|
private readonly IServiceProvider _provider;
|
|
|
|
private ACompiler _compiler;
|
2021-10-15 04:20:27 +00:00
|
|
|
|
2021-10-12 03:49:01 +00:00
|
|
|
|
2021-10-12 05:19:13 +00:00
|
|
|
public CompilationViewModel(ILogger<CompilationViewModel> logger, IServiceProvider provider)
|
2021-10-12 03:49:01 +00:00
|
|
|
{
|
2021-10-12 05:19:13 +00:00
|
|
|
_logger = logger;
|
2021-10-12 03:49:01 +00:00
|
|
|
_provider = provider;
|
|
|
|
Activator = new ViewModelActivator();
|
2021-10-27 04:28:01 +00:00
|
|
|
|
|
|
|
MessageBus.Current.Listen<StartCompilation>()
|
|
|
|
.Subscribe(Receive)
|
|
|
|
.DisposeWith(VMDisposables);
|
2021-10-12 03:49:01 +00:00
|
|
|
}
|
2021-10-23 16:51:17 +00:00
|
|
|
|
|
|
|
[Reactive] public string StatusText { get; set; } = "";
|
|
|
|
[Reactive] public Percent StepsProgress { get; set; } = Percent.Zero;
|
|
|
|
[Reactive] public Percent StepProgress { get; set; } = Percent.Zero;
|
|
|
|
|
2021-10-27 04:28:01 +00:00
|
|
|
private void Receive(StartCompilation val)
|
2021-10-12 03:49:01 +00:00
|
|
|
{
|
|
|
|
if (val.Settings is MO2CompilerSettings mo2)
|
|
|
|
{
|
|
|
|
var compiler = _provider.GetService<MO2Compiler>()!;
|
|
|
|
compiler.Settings = mo2;
|
|
|
|
_compiler = compiler;
|
2021-10-15 04:20:27 +00:00
|
|
|
_compiler.OnStatusUpdate += (sender, update) =>
|
|
|
|
{
|
|
|
|
Dispatcher.UIThread.InvokeAsync(() =>
|
|
|
|
{
|
|
|
|
StatusText = update.StatusText;
|
|
|
|
StepsProgress = update.StepsProgress;
|
|
|
|
StepProgress = update.StepProgress;
|
|
|
|
});
|
|
|
|
};
|
2021-10-12 03:49:01 +00:00
|
|
|
}
|
2021-10-23 16:51:17 +00:00
|
|
|
|
2021-10-12 05:19:13 +00:00
|
|
|
Compile().FireAndForget();
|
|
|
|
}
|
2021-10-12 03:49:01 +00:00
|
|
|
|
2021-10-12 05:19:13 +00:00
|
|
|
public async Task Compile()
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2021-11-08 13:32:51 +00:00
|
|
|
var result = await Task.Run(async () => await _compiler.Begin(CancellationToken.None));
|
2021-10-12 05:19:13 +00:00
|
|
|
}
|
|
|
|
catch (Exception ex)
|
|
|
|
{
|
|
|
|
_logger.LogError(ex, "During Compilation: {Message}", ex.Message);
|
2021-10-15 04:20:27 +00:00
|
|
|
StatusText = $"ERRORED: {ex.Message}";
|
2021-10-19 23:19:06 +00:00
|
|
|
ErrorPageViewModel.Display("During compilation", ex);
|
2021-10-12 05:19:13 +00:00
|
|
|
}
|
2021-10-12 03:49:01 +00:00
|
|
|
}
|
|
|
|
}
|