Files
romrepomgr/RomRepoMgr/Program.cs

74 lines
2.6 KiB
C#
Raw Permalink Normal View History

2020-08-21 23:34:07 +01:00
/******************************************************************************
// RomRepoMgr - ROM repository manager
// ----------------------------------------------------------------------------
//
// Author(s) : Natalia Portillo <claunia@claunia.com>
//
// --[ License ] --------------------------------------------------------------
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as
// published by the Free Software Foundation, either version 3 of the
// License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
//
// ----------------------------------------------------------------------------
2024-11-08 19:13:57 +00:00
// Copyright © 2020-2024 Natalia Portillo
2020-08-21 23:34:07 +01:00
*******************************************************************************/
2025-07-24 16:20:22 +01:00
using System;
2020-08-21 23:34:07 +01:00
using Avalonia;
2024-11-09 06:14:25 +00:00
using Avalonia.Logging;
2025-07-24 16:20:22 +01:00
using Serilog;
2020-08-21 22:22:24 +01:00
2024-11-09 01:37:59 +00:00
namespace RomRepoMgr;
2024-11-10 04:17:05 +00:00
internal static class Program
2020-08-21 22:22:24 +01:00
{
2024-11-09 01:37:59 +00:00
// Initialization code. Don't use any Avalonia, third-party APIs or any
// SynchronizationContext-reliant code before AppMain is called: things aren't initialized
// yet and stuff might break.
2025-07-24 16:20:22 +01:00
public static void Main(string[] args)
{
Log.Logger = new LoggerConfiguration()
#if DEBUG
.MinimumLevel.Debug()
#else
.MinimumLevel.Information()
#endif
.WriteTo.Console()
.CreateLogger();
try
{
Log.Information("Starting up");
BuildAvaloniaApp().StartWithClassicDesktopLifetime(args);
}
catch(Exception ex)
{
Log.Fatal(ex, "Application start-up failed");
}
finally
{
Log.CloseAndFlush();
}
}
2020-08-21 22:22:24 +01:00
2024-11-09 01:37:59 +00:00
// Avalonia configuration, don't remove; also used by visual designer.
2024-11-09 06:14:25 +00:00
public static AppBuilder BuildAvaloniaApp() => AppBuilder.Configure<App>()
.UsePlatformDetect()
2025-07-31 04:21:06 +01:00
#if DEBUG
.LogToSerilog(LogEventLevel.Debug);
#else
2025-07-24 16:20:22 +01:00
.LogToSerilog(LogEventLevel.Information);
#endif
2020-08-21 22:22:24 +01:00
}