using System; using System.Diagnostics; using System.IO; using System.Linq; using System.Threading.Tasks; using ApplicationServices; using Avalonia; using Avalonia.Controls.ApplicationLifetimes; using Avalonia.ReactiveUI; using LibationFileManager; namespace LibationAvalonia { static class Program { static void Main() { //***********************************************// // // // do not use Configuration before this line // // // //***********************************************// // Migrations which must occur before configuration is loaded for the first time. Usually ones which alter the Configuration var config = AppScaffolding.LibationScaffolding.RunPreConfigMigrations(); App.SetupRequired = !config.LibationSettingsAreValid; //Start as much work in parallel as possible. var classicLifetimeTask = Task.Run(() => new ClassicDesktopStyleApplicationLifetime()); var appBuilderTask = Task.Run(BuildAvaloniaApp); if (Configuration.IsWindows) AppScaffolding.LibationScaffolding.SetReleaseIdentifier(AppScaffolding.ReleaseIdentifier.WindowsAvalonia); else if (Configuration.IsLinux) AppScaffolding.LibationScaffolding.SetReleaseIdentifier(AppScaffolding.ReleaseIdentifier.LinuxAvalonia); else if (Configuration.IsMacOs) AppScaffolding.LibationScaffolding.SetReleaseIdentifier(AppScaffolding.ReleaseIdentifier.MacOSAvalonia); else return; if (!App.SetupRequired) { if (!RunDbMigrations(config)) return; App.LibraryTask = Task.Run(() => DbContexts.GetLibrary_Flat_NoTracking(includeParents: true)); } (appBuilderTask.GetAwaiter().GetResult()).SetupWithLifetime(classicLifetimeTask.GetAwaiter().GetResult()); classicLifetimeTask.Result.Start(null); } public static AppBuilder BuildAvaloniaApp() => AppBuilder.Configure() .UsePlatformDetect() .LogToTrace() .UseReactiveUI(); public static bool RunDbMigrations(Configuration config) { try { // most migrations go in here AppScaffolding.LibationScaffolding.RunPostConfigMigrations(config); AppScaffolding.LibationScaffolding.RunPostMigrationScaffolding(config); return true; } catch (Exception exDebug) { Serilog.Log.Logger.Debug(exDebug, "Silent failure"); return false; } } } }