summaryrefslogtreecommitdiffstats
path: root/media/jni/android_media_MediaPlayer.cpp
diff options
context:
space:
mode:
authorJames Dong <jdong@google.com>2011-05-05 12:50:04 -0700
committerJames Dong <jdong@google.com>2011-05-05 15:11:23 -0700
commit79f407cc6c5ae34fc6f04d52fd034b49d1f002c4 (patch)
treed416e43ca5458a0292dfcc515eabdb15e1304c02 /media/jni/android_media_MediaPlayer.cpp
parent8b1b0548b21e6d8fdfb769d9064cd2ff4232bc3d (diff)
downloadframeworks_base-79f407cc6c5ae34fc6f04d52fd034b49d1f002c4.zip
frameworks_base-79f407cc6c5ae34fc6f04d52fd034b49d1f002c4.tar.gz
frameworks_base-79f407cc6c5ae34fc6f04d52fd034b49d1f002c4.tar.bz2
Refactor to share code between MediaPlayer and MediaMetadataRetriever JNI
Change-Id: Ib847213f566dee79126d7c14d00750a9a8dedeb9
Diffstat (limited to 'media/jni/android_media_MediaPlayer.cpp')
-rw-r--r--media/jni/android_media_MediaPlayer.cpp38
1 files changed, 6 insertions, 32 deletions
diff --git a/media/jni/android_media_MediaPlayer.cpp b/media/jni/android_media_MediaPlayer.cpp
index ad744dc..b03aa38 100644
--- a/media/jni/android_media_MediaPlayer.cpp
+++ b/media/jni/android_media_MediaPlayer.cpp
@@ -33,6 +33,8 @@
#include "utils/Errors.h" // for status_t
#include "utils/KeyedVector.h"
#include "utils/String8.h"
+#include "android_media_Utils.h"
+
#include "android_util_Binder.h"
#include <binder/Parcel.h>
#include <gui/SurfaceTexture.h>
@@ -209,46 +211,18 @@ android_media_MediaPlayer_setDataSourceAndHeaders(
env->ReleaseStringUTFChars(path, tmp);
tmp = NULL;
- int nKeyValuePairs = env->GetArrayLength(keys);
- if (nKeyValuePairs != env->GetArrayLength(values)) {
- LOGE("keys and values have different length: %d <-> %d",
- nKeyValuePairs, env->GetArrayLength(values));
- jniThrowException(env, "java/lang/IllegalArgumentException", NULL);
- return;
- }
-
// We build a KeyedVector out of the key and val arrays
KeyedVector<String8, String8> headersVector;
- for (int i = 0; i < nKeyValuePairs; ++i) {
- // No need to check ArrayIndexOutOfBoundsException, since we
- // know it won't happen here.
- jstring key = (jstring) env->GetObjectArrayElement(keys, i);
- jstring val = (jstring) env->GetObjectArrayElement(values, i);
-
- const char* keyStr = env->GetStringUTFChars(key, NULL);
- if (!keyStr) { // OutOfMemoryError
- return;
- }
-
- const char* valueStr = env->GetStringUTFChars(val, NULL);
- if (!valueStr) { // OutOfMemoryError
- env->ReleaseStringUTFChars(key, keyStr);
- return;
- }
-
- headersVector.add(String8(keyStr), String8(valueStr));
-
- env->ReleaseStringUTFChars(key, keyStr);
- env->ReleaseStringUTFChars(val, valueStr);
- env->DeleteLocalRef(key);
- env->DeleteLocalRef(val);
+ if (!ConvertKeyValueArraysToKeyedVector(
+ env, keys, values, &headersVector)) {
+ return;
}
LOGV("setDataSource: path %s", pathStr);
status_t opStatus =
mp->setDataSource(
pathStr,
- nKeyValuePairs > 0? &headersVector : NULL);
+ headersVector.size() > 0? &headersVector : NULL);
process_media_player_call(
env, thiz, opStatus, "java/io/IOException",