2018-03-15 21:06:24 -03:00
|
|
|
|
using Ryujinx.Audio;
|
2018-10-17 14:15:50 -03:00
|
|
|
|
using Ryujinx.Common.Logging;
|
2018-02-20 22:09:23 +02:00
|
|
|
|
using Ryujinx.Graphics.Gal;
|
|
|
|
|
using Ryujinx.Graphics.Gal.OpenGL;
|
2018-06-10 21:46:42 -03:00
|
|
|
|
using Ryujinx.HLE;
|
2018-02-04 20:08:20 -03:00
|
|
|
|
using System;
|
|
|
|
|
using System.IO;
|
|
|
|
|
|
|
|
|
|
namespace Ryujinx
|
|
|
|
|
{
|
|
|
|
|
class Program
|
|
|
|
|
{
|
2019-02-13 10:24:11 +11:00
|
|
|
|
public static string ApplicationDirectory => AppDomain.CurrentDomain.BaseDirectory;
|
|
|
|
|
|
2018-02-04 20:08:20 -03:00
|
|
|
|
static void Main(string[] args)
|
|
|
|
|
{
|
2018-02-09 01:43:22 +01:00
|
|
|
|
Console.Title = "Ryujinx Console";
|
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
IGalRenderer renderer = new OGLRenderer();
|
2018-02-04 20:08:20 -03:00
|
|
|
|
|
2018-11-15 13:22:50 +11:00
|
|
|
|
IAalOutput audioOut = InitializeAudioEngine();
|
2018-03-15 21:06:24 -03:00
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
Switch device = new Switch(renderer, audioOut);
|
2018-02-04 20:08:20 -03:00
|
|
|
|
|
2019-02-13 10:24:11 +11:00
|
|
|
|
Configuration.Load(Path.Combine(ApplicationDirectory, "Config.jsonc"));
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Configuration.Configure(device);
|
2019-01-31 04:49:15 +02:00
|
|
|
|
|
|
|
|
|
AppDomain.CurrentDomain.UnhandledException += CurrentDomain_UnhandledException;
|
|
|
|
|
AppDomain.CurrentDomain.ProcessExit += CurrentDomain_ProcessExit;
|
2018-04-24 15:57:39 -03:00
|
|
|
|
|
2018-02-04 20:08:20 -03:00
|
|
|
|
if (args.Length == 1)
|
|
|
|
|
{
|
|
|
|
|
if (Directory.Exists(args[0]))
|
|
|
|
|
{
|
2018-10-30 19:43:02 -06:00
|
|
|
|
string[] romFsFiles = Directory.GetFiles(args[0], "*.istorage");
|
2018-02-04 20:08:20 -03:00
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
if (romFsFiles.Length == 0)
|
2018-04-06 02:02:13 -03:00
|
|
|
|
{
|
2018-10-30 19:43:02 -06:00
|
|
|
|
romFsFiles = Directory.GetFiles(args[0], "*.romfs");
|
2018-04-06 02:02:13 -03:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
if (romFsFiles.Length > 0)
|
2018-02-04 20:08:20 -03:00
|
|
|
|
{
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as cart with RomFS.");
|
2018-02-04 20:08:20 -03:00
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadCart(args[0], romFsFiles[0]);
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as cart WITHOUT RomFS.");
|
2018-02-04 20:08:20 -03:00
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadCart(args[0]);
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else if (File.Exists(args[0]))
|
|
|
|
|
{
|
2018-09-08 12:33:27 -06:00
|
|
|
|
switch (Path.GetExtension(args[0]).ToLowerInvariant())
|
|
|
|
|
{
|
|
|
|
|
case ".xci":
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as XCI.");
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadXci(args[0]);
|
2018-09-08 12:33:27 -06:00
|
|
|
|
break;
|
|
|
|
|
case ".nca":
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as NCA.");
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadNca(args[0]);
|
2018-09-08 12:33:27 -06:00
|
|
|
|
break;
|
|
|
|
|
case ".nsp":
|
2019-01-25 02:51:28 +01:00
|
|
|
|
case ".pfs0":
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as NSP.");
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadNsp(args[0]);
|
2018-09-08 12:33:27 -06:00
|
|
|
|
break;
|
|
|
|
|
default:
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Loading as homebrew.");
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.LoadProgram(args[0]);
|
2018-09-08 12:33:27 -06:00
|
|
|
|
break;
|
|
|
|
|
}
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.PrintInfo(LogClass.Application, "Please specify the folder with the NSOs/IStorage or a NSO/NRO.");
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
using (GlScreen screen = new GlScreen(device, renderer))
|
2018-02-04 20:08:20 -03:00
|
|
|
|
{
|
2018-10-30 19:43:02 -06:00
|
|
|
|
screen.MainLoop();
|
2018-08-16 20:47:36 -03:00
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
device.Dispose();
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
|
2018-10-30 19:43:02 -06:00
|
|
|
|
audioOut.Dispose();
|
2019-02-11 23:00:32 +11:00
|
|
|
|
|
|
|
|
|
Logger.Shutdown();
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
2018-11-15 13:22:50 +11:00
|
|
|
|
|
2019-01-31 04:49:15 +02:00
|
|
|
|
private static void CurrentDomain_ProcessExit(object sender, EventArgs e)
|
|
|
|
|
{
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.Shutdown();
|
2019-01-31 04:49:15 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void CurrentDomain_UnhandledException(object sender, UnhandledExceptionEventArgs e)
|
|
|
|
|
{
|
|
|
|
|
var exception = e.ExceptionObject as Exception;
|
|
|
|
|
|
|
|
|
|
Logger.PrintError(LogClass.Emulation, $"Unhandled exception caught: {exception}");
|
|
|
|
|
|
|
|
|
|
if (e.IsTerminating)
|
|
|
|
|
{
|
2019-02-11 23:00:32 +11:00
|
|
|
|
Logger.Shutdown();
|
2019-01-31 04:49:15 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2018-11-15 13:22:50 +11:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Picks an <see cref="IAalOutput"/> audio output renderer supported on this machine
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <returns>An <see cref="IAalOutput"/> supported by this machine</returns>
|
|
|
|
|
private static IAalOutput InitializeAudioEngine()
|
|
|
|
|
{
|
|
|
|
|
if (SoundIoAudioOut.IsSupported)
|
|
|
|
|
{
|
|
|
|
|
return new SoundIoAudioOut();
|
|
|
|
|
}
|
|
|
|
|
else if (OpenALAudioOut.IsSupported)
|
|
|
|
|
{
|
|
|
|
|
return new OpenALAudioOut();
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
return new DummyAudioOut();
|
|
|
|
|
}
|
|
|
|
|
}
|
2018-02-04 20:08:20 -03:00
|
|
|
|
}
|
|
|
|
|
}
|