aboutsummaryrefslogtreecommitdiff
path: root/samples
diff options
context:
space:
mode:
authorasuonpaa <34128694+asuonpaa@users.noreply.github.com>2019-11-20 17:40:11 +0200
committerdan sinclair <dsinclair@google.com>2019-11-20 10:40:11 -0500
commit8122b09cf0163f5b7bf77d33e901e960c2f0e64c (patch)
tree6c0272922cf70fcabfeaf7dd1afd358e3c5d9451 /samples
parent76a97eddd95641dcf4b96850d50935fbeb36f0bf (diff)
downloadamber-8122b09cf0163f5b7bf77d33e901e960c2f0e64c.tar.gz
Don't add -d by default. Parse options for stdout/stderr files. (#710)
Fixes #706
Diffstat (limited to 'samples')
-rw-r--r--samples/android_main.cc36
1 files changed, 24 insertions, 12 deletions
diff --git a/samples/android_main.cc b/samples/android_main.cc
index cc82335..b24a9bb 100644
--- a/samples/android_main.cc
+++ b/samples/android_main.cc
@@ -23,23 +23,35 @@ extern int main(int argc, const char** argv);
extern "C" JNIEXPORT JNICALL int Java_com_google_amber_Amber_androidMain(
JNIEnv* env,
jobject,
- jstring args_jstring) {
+ jobjectArray args,
+ jstring stdoutFile,
+ jstring stderrFile) {
+ const char* stdout_file_cstr = env->GetStringUTFChars(stdoutFile, NULL);
+ const char* stderr_file_cstr = env->GetStringUTFChars(stderrFile, NULL);
+
// Redirect std output to a file
- freopen("/sdcard/amberlog.txt", "w", stdout);
- freopen("/sdcard/amberlog.txt", "a", stderr);
+ freopen(stdout_file_cstr, "w", stdout);
+ freopen(stderr_file_cstr, "w", stderr);
+
+ env->ReleaseStringUTFChars(stdoutFile, stdout_file_cstr);
+ env->ReleaseStringUTFChars(stderrFile, stderr_file_cstr);
+
+ jsize arg_count = env->GetArrayLength(args);
+
+ std::vector<std::string> argv_string;
+ argv_string.push_back("amber");
- std::string args(env->GetStringUTFChars(args_jstring, NULL));
+ for (jsize i = 0; i < arg_count; i++) {
+ jstring js = static_cast<jstring>(env->GetObjectArrayElement(args, i));
+ const char* arg_cstr = env->GetStringUTFChars(js, NULL);
+ argv_string.push_back(arg_cstr);
+ env->ReleaseStringUTFChars(js, arg_cstr);
+ }
- // Parse argument string and add -d by default
- std::stringstream ss(args);
- std::vector<std::string> argv_string{std::istream_iterator<std::string>{ss},
- std::istream_iterator<std::string>{}};
std::vector<const char*> argv;
- argv.push_back("amber");
- argv.push_back("-d");
- for (auto s : argv_string)
- argv.push_back(s.c_str());
+ for (const std::string& arg : argv_string)
+ argv.push_back(arg.c_str());
return main(argv.size(), argv.data());
}