Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2425)

Unified Diff: base/android/jni_array.cc

Issue 7518032: Android's paths and message loop implementation with JNI (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix dependence again. Created 9 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: base/android/jni_array.cc
diff --git a/base/android/jni_array.cc b/base/android/jni_array.cc
new file mode 100644
index 0000000000000000000000000000000000000000..9555abc2232787ffad38bfcac11954349d870014
--- /dev/null
+++ b/base/android/jni_array.cc
@@ -0,0 +1,52 @@
+// Copyright 2011 Google Inc. All Rights Reserved.
+// Author: michaelbai@google.com (Tao Bai)
+
+#include "base/android/jni_array.h"
+
+#include "base/android/auto_jobject.h"
+#include "base/android/jni_android.h"
+#include "base/logging.h"
+
+namespace base {
+namespace android {
+
+jbyteArray ToJavaByteArray(JNIEnv* env,
+ const unsigned char* bytes,
+ size_t len) {
+ jbyteArray byte_array = env->NewByteArray(len);
+ if (!byte_array) {
+ return NULL;
+ }
+
+ jbyte* elements = env->GetByteArrayElements(byte_array, NULL);
+ DCHECK(elements);
+ memcpy(elements, bytes, len);
+ env->ReleaseByteArrayElements(byte_array, elements, 0);
+ CheckException(env);
+
+ return byte_array;
+}
+
+jobjectArray ToJavaArrayOfByteArray(JNIEnv* env,
+ const std::vector<std::string>& v) {
+ size_t count = v.size();
+ DCHECK_GT(count, 0U);
+ jclass byte_array_class = env->FindClass("[B");
+ jobjectArray joa = env->NewObjectArray(count, byte_array_class, NULL);
+ if (joa == NULL)
+ return NULL;
+
+ for (size_t i = 0; i < count; ++i) {
+ AutoJObject byte_array = AutoJObject::FromLocalRef(env, ToJavaByteArray(env,
+ reinterpret_cast<const uint8*>(v[i].data()), v[i].length()));
M-A Ruel 2011/11/11 13:09:07 We never align at +8; AutoJObject byte_array = Au
+ if (!byte_array.obj()) {
+ env->DeleteLocalRef(joa);
+ return NULL;
+ }
+ env->SetObjectArrayElement(joa, i, byte_array.obj());
+ }
+ return joa;
+}
+
+} // namespace android
+} // namespace base

Powered by Google App Engine
This is Rietveld 408576698