diff options
author | asuonpaa <34128694+asuonpaa@users.noreply.github.com> | 2019-11-20 17:40:11 +0200 |
---|---|---|
committer | dan sinclair <dsinclair@google.com> | 2019-11-20 10:40:11 -0500 |
commit | 8122b09cf0163f5b7bf77d33e901e960c2f0e64c (patch) | |
tree | 6c0272922cf70fcabfeaf7dd1afd358e3c5d9451 /samples | |
parent | 76a97eddd95641dcf4b96850d50935fbeb36f0bf (diff) | |
download | amber-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.cc | 36 |
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()); } |