aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2016-07-14 22:25:52 -0400
committerGitHub <noreply@github.com>2016-07-14 22:25:52 -0400
commitf95d119dde2addd4a83fe8dd5ca6de5139c20336 (patch)
tree7b47be1c71ca918f6acd2a49350c2b48c0e2550d
parentffda82eea546830d15284810e91e58c5b6627a0c (diff)
parentf9e3824820b92b886dd072f396dee2221daabb20 (diff)
Merge pull request #1890 from LFsWang/fix-encode-problem
Fix boot_filename encode on Windows
-rw-r--r--src/citra/citra.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/citra/citra.cpp b/src/citra/citra.cpp
index e01216734c..128b9a16dd 100644
--- a/src/citra/citra.cpp
+++ b/src/citra/citra.cpp
@@ -17,11 +17,16 @@
#include <getopt.h>
#endif
+#ifdef _WIN32
+#include <Windows.h>
+#endif
+
#include "common/logging/log.h"
#include "common/logging/backend.h"
#include "common/logging/filter.h"
#include "common/scm_rev.h"
#include "common/scope_exit.h"
+#include "common/string_util.h"
#include "core/settings.h"
#include "core/system.h"
@@ -55,6 +60,15 @@ int main(int argc, char **argv) {
bool use_gdbstub = Settings::values.use_gdbstub;
u32 gdb_port = static_cast<u32>(Settings::values.gdbstub_port);
char *endarg;
+#ifdef _WIN32
+ int argc_w;
+ auto argv_w = CommandLineToArgvW(GetCommandLineW(), &argc_w);
+
+ if (argv_w == nullptr) {
+ LOG_CRITICAL(Frontend, "Failed to get command line arguments");
+ return -1;
+ }
+#endif
std::string boot_filename;
static struct option long_options[] = {
@@ -86,11 +100,19 @@ int main(int argc, char **argv) {
return 0;
}
} else {
+#ifdef _WIN32
+ boot_filename = Common::UTF16ToUTF8(argv_w[optind]);
+#else
boot_filename = argv[optind];
+#endif
optind++;
}
}
+#ifdef _WIN32
+ LocalFree(argv_w);
+#endif
+
Log::Filter log_filter(Log::Level::Debug);
Log::SetFilter(&log_filter);