2013-01-11 09:23:08 +00:00
|
|
|
/**
|
|
|
|
******************************************************************************
|
|
|
|
* Xenia : Xbox 360 Emulator Research Project *
|
|
|
|
******************************************************************************
|
|
|
|
* Copyright 2013 Ben Vanik. All rights reserved. *
|
|
|
|
* Released under the BSD license - see LICENSE in the root for more details. *
|
|
|
|
******************************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <xenia/xenia.h>
|
|
|
|
|
2013-01-24 05:31:23 +00:00
|
|
|
#include <gflags/gflags.h>
|
|
|
|
|
2013-01-13 07:25:41 +00:00
|
|
|
|
2013-01-20 09:13:59 +00:00
|
|
|
using namespace xe;
|
2013-01-13 08:34:08 +00:00
|
|
|
|
|
|
|
|
2013-05-30 04:45:54 +00:00
|
|
|
DEFINE_string(target, "",
|
|
|
|
"Specifies the target .xex or .iso to execute.");
|
|
|
|
|
|
|
|
|
2013-10-24 03:42:24 +00:00
|
|
|
int xenia_run(int argc, xechar_t** argv) {
|
|
|
|
int result_code = 1;
|
2013-01-20 09:13:59 +00:00
|
|
|
|
2014-05-28 20:59:43 +00:00
|
|
|
Profiler::Initialize();
|
2014-05-28 05:54:40 +00:00
|
|
|
Profiler::ThreadEnter("main");
|
|
|
|
|
2013-10-24 03:42:24 +00:00
|
|
|
Emulator* emulator = NULL;
|
2013-01-20 09:13:59 +00:00
|
|
|
|
2013-10-24 03:42:24 +00:00
|
|
|
// Grab path from the flag or unnamed argument.
|
|
|
|
if (!FLAGS_target.size() && argc < 2) {
|
|
|
|
google::ShowUsageWithFlags("xenia-run");
|
2014-01-17 06:16:06 +00:00
|
|
|
XEFATAL("Pass a file to launch.");
|
2013-10-24 03:42:24 +00:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
const xechar_t* path = NULL;
|
|
|
|
if (FLAGS_target.size()) {
|
|
|
|
// Passed as a named argument.
|
|
|
|
// TODO(benvanik): find something better than gflags that supports unicode.
|
|
|
|
xechar_t buffer[XE_MAX_PATH];
|
|
|
|
XEIGNORE(xestrwiden(buffer, sizeof(buffer), FLAGS_target.c_str()));
|
|
|
|
path = buffer;
|
|
|
|
} else {
|
|
|
|
// Passed as an unnamed argument.
|
|
|
|
path = argv[1];
|
|
|
|
}
|
2013-06-01 04:22:00 +00:00
|
|
|
|
2013-10-24 03:42:24 +00:00
|
|
|
// Create platform abstraction layer.
|
2013-01-20 09:13:59 +00:00
|
|
|
xe_pal_options_t pal_options;
|
2013-01-13 08:34:08 +00:00
|
|
|
xe_zero_struct(&pal_options, sizeof(pal_options));
|
2013-03-29 12:07:32 +00:00
|
|
|
XEEXPECTZERO(xe_pal_init(pal_options));
|
2013-01-13 08:34:08 +00:00
|
|
|
|
2013-02-01 00:52:50 +00:00
|
|
|
// Normalize the path and make absolute.
|
|
|
|
// TODO(benvanik): move this someplace common.
|
|
|
|
xechar_t abs_path[XE_MAX_PATH];
|
2013-02-09 16:05:39 +00:00
|
|
|
xe_path_get_absolute(path, abs_path, XECOUNT(abs_path));
|
2013-02-01 00:52:50 +00:00
|
|
|
|
|
|
|
// Grab file extension.
|
2014-01-19 06:23:26 +00:00
|
|
|
// May be NULL if an STFS file.
|
2013-02-01 00:52:50 +00:00
|
|
|
const xechar_t* dot = xestrrchr(abs_path, '.');
|
2013-01-31 06:44:32 +00:00
|
|
|
|
2013-10-24 03:42:24 +00:00
|
|
|
// Create the emulator.
|
|
|
|
emulator = new Emulator(XT(""));
|
|
|
|
XEEXPECTNOTNULL(emulator);
|
|
|
|
X_STATUS result = emulator->Setup();
|
|
|
|
if (XFAILED(result)) {
|
|
|
|
XELOGE("Failed to setup emulator: %.8X", result);
|
|
|
|
XEFAIL();
|
2013-02-01 13:37:42 +00:00
|
|
|
}
|
|
|
|
|
2013-02-01 00:52:50 +00:00
|
|
|
// Launch based on file type.
|
|
|
|
// This is a silly guess based on file extension.
|
|
|
|
// NOTE: the runtime launch routine will wait until the module exits.
|
2014-01-19 06:23:26 +00:00
|
|
|
if (!dot) {
|
|
|
|
// Likely an STFS container.
|
|
|
|
result = emulator->LaunchSTFSTitle(abs_path);
|
|
|
|
} else if (xestrcmp(dot, XT(".xex")) == 0) {
|
2013-02-01 00:52:50 +00:00
|
|
|
// Treat as a naked xex file.
|
2013-10-24 03:42:24 +00:00
|
|
|
result = emulator->LaunchXexFile(abs_path);
|
2013-02-01 00:52:50 +00:00
|
|
|
} else {
|
|
|
|
// Assume a disc image.
|
2013-10-24 03:42:24 +00:00
|
|
|
result = emulator->LaunchDiscImage(abs_path);
|
2013-01-13 08:34:08 +00:00
|
|
|
}
|
2013-10-24 03:42:24 +00:00
|
|
|
if (XFAILED(result)) {
|
|
|
|
XELOGE("Failed to launch target: %.8X", result);
|
|
|
|
XEFAIL();
|
2013-05-30 04:45:54 +00:00
|
|
|
}
|
2013-01-13 08:34:08 +00:00
|
|
|
|
2013-01-24 05:31:23 +00:00
|
|
|
result_code = 0;
|
2013-01-13 08:34:08 +00:00
|
|
|
XECLEANUP:
|
2013-10-24 03:42:24 +00:00
|
|
|
delete emulator;
|
2014-01-17 06:16:06 +00:00
|
|
|
if (result_code) {
|
|
|
|
XEFATAL("Failed to launch emulator: %d", result_code);
|
|
|
|
}
|
2014-05-28 05:54:40 +00:00
|
|
|
Profiler::Dump();
|
|
|
|
Profiler::Shutdown();
|
2013-01-13 08:34:08 +00:00
|
|
|
return result_code;
|
2013-01-11 09:23:08 +00:00
|
|
|
}
|
2014-01-17 05:43:25 +00:00
|
|
|
XE_MAIN_WINDOW_THUNK(xenia_run, XETEXT("xenia-run"), "xenia-run some.xex");
|