diff options
author | Elliott Hughes <enh@google.com> | 2010-03-26 17:46:16 -0700 |
---|---|---|
committer | Elliott Hughes <enh@google.com> | 2010-03-26 17:46:16 -0700 |
commit | ccfdf99802ae83d6da20c5052b84bbefa63e2bf8 (patch) | |
tree | 672b30df33122daa627aa1c7bc00ca6ff90ac1a3 /icu/src/main/native | |
parent | 66a66f700738c07c7977cb023f8a7aa2b331af90 (diff) | |
download | libcore-ccfdf99802ae83d6da20c5052b84bbefa63e2bf8.zip libcore-ccfdf99802ae83d6da20c5052b84bbefa63e2bf8.tar.gz libcore-ccfdf99802ae83d6da20c5052b84bbefa63e2bf8.tar.bz2 |
Fix all our java.text.Bidi failures.
Two are invalid tests where we behave the same as the RI. The third reflects
a difference between ICU4C and the RI, so I've added code to recognize that
case and paper over the crack. I've also tidied up a bit more.
With any luck, I'll never see these files again...
Change-Id: I278502fbdea039e9a2318df830dc0b55851e96c0
Diffstat (limited to 'icu/src/main/native')
-rw-r--r-- | icu/src/main/native/BidiWrapper.cpp | 80 |
1 files changed, 49 insertions, 31 deletions
diff --git a/icu/src/main/native/BidiWrapper.cpp b/icu/src/main/native/BidiWrapper.cpp index 6bc650a..68419c0 100644 --- a/icu/src/main/native/BidiWrapper.cpp +++ b/icu/src/main/native/BidiWrapper.cpp @@ -17,25 +17,48 @@ #include "AndroidSystemNatives.h" #include <JNIHelp.h> #include "ErrorCode.h" +#include "UniquePtr.h" #include "unicode/ubidi.h" #include <stdlib.h> #include <string.h> struct BiDiData { - BiDiData(UBiDi* biDi) : mBiDi(biDi), embeddingLevels(NULL) { + BiDiData(UBiDi* biDi) : mBiDi(biDi), mEmbeddingLevels(NULL) { } + ~BiDiData() { ubidi_close(mBiDi); - delete[] embeddingLevels; } + + UBiDiLevel* embeddingLevels() { + return reinterpret_cast<UBiDiLevel*>(&mEmbeddingLevels[0]); + } + + void setEmbeddingLevels(jbyte* newEmbeddingLevels) { + mEmbeddingLevels.reset(newEmbeddingLevels); + } + + UBiDi* uBiDi() { + return mBiDi; + } + +private: UBiDi* mBiDi; - jbyte* embeddingLevels; + UniquePtr<jbyte[]> mEmbeddingLevels; + + // Disallow copy and assignment. + BiDiData(const BiDiData&); + void operator=(const BiDiData&); }; static BiDiData* biDiData(jlong ptr) { return reinterpret_cast<BiDiData*>(static_cast<uintptr_t>(ptr)); } +static UBiDi* uBiDi(jlong ptr) { + return reinterpret_cast<BiDiData*>(static_cast<uintptr_t>(ptr))->uBiDi(); +} + static jlong BidiWrapper_ubidi_open(JNIEnv* env, jclass) { return reinterpret_cast<uintptr_t>(new BiDiData(ubidi_open())); } @@ -46,72 +69,68 @@ static void BidiWrapper_ubidi_close(JNIEnv* env, jclass, jlong ptr) { static void BidiWrapper_ubidi_setPara(JNIEnv* env, jclass, jlong ptr, jcharArray text, jint length, jbyte paraLevel, jbyteArray newEmbeddingLevels) { BiDiData* data = biDiData(ptr); - jbyte* oldEmbeddingLevels = data->embeddingLevels; // Copy the new embedding levels from the Java heap to the native heap. if (newEmbeddingLevels != NULL) { - data->embeddingLevels = new jbyte[length]; - env->GetByteArrayRegion(newEmbeddingLevels, 0, length, data->embeddingLevels); + jbyte* dst; + data->setEmbeddingLevels(dst = new jbyte[length]); + env->GetByteArrayRegion(newEmbeddingLevels, 0, length, dst); } else { - data->embeddingLevels = NULL; + data->setEmbeddingLevels(NULL); } UErrorCode err = U_ZERO_ERROR; - jchar* _text = env->GetCharArrayElements(text, NULL); - ubidi_setPara(data->mBiDi, _text, length, paraLevel, (UBiDiLevel*) data->embeddingLevels, &err); - env->ReleaseCharArrayElements(text, _text, 0); - delete[] oldEmbeddingLevels; + jchar* chars = env->GetCharArrayElements(text, NULL); + ubidi_setPara(data->uBiDi(), chars, length, paraLevel, data->embeddingLevels(), &err); + env->ReleaseCharArrayElements(text, chars, 0); icu4jni_error(env, err); } static jlong BidiWrapper_ubidi_setLine(JNIEnv* env, jclass, jlong ptr, jint start, jint limit) { UErrorCode err = U_ZERO_ERROR; UBiDi* sized = ubidi_openSized(limit - start, 0, &err); - if (icu4jni_error(env, err)) { + if (icu4jni_error(env, err) != FALSE) { return 0; } - BiDiData* lineData = new BiDiData(sized); - BiDiData* data = biDiData(ptr); - ubidi_setLine(data->mBiDi, start, limit, lineData->mBiDi, &err); + UniquePtr<BiDiData> lineData(new BiDiData(sized)); + ubidi_setLine(uBiDi(ptr), start, limit, lineData->uBiDi(), &err); icu4jni_error(env, err); - return reinterpret_cast<uintptr_t>(lineData); + return reinterpret_cast<uintptr_t>(lineData.release()); } static jint BidiWrapper_ubidi_getDirection(JNIEnv * env, jclass clazz, jlong ptr) { - return ubidi_getDirection(biDiData(ptr)->mBiDi); + return ubidi_getDirection(uBiDi(ptr)); } static jint BidiWrapper_ubidi_getLength(JNIEnv* env, jclass, jlong ptr) { - return ubidi_getLength(biDiData(ptr)->mBiDi); + return ubidi_getLength(uBiDi(ptr)); } static jbyte BidiWrapper_ubidi_getParaLevel(JNIEnv* env, jclass, jlong ptr) { - return ubidi_getParaLevel(biDiData(ptr)->mBiDi); + return ubidi_getParaLevel(uBiDi(ptr)); } static jbyteArray BidiWrapper_ubidi_getLevels(JNIEnv* env, jclass, jlong ptr) { - BiDiData* data = biDiData(ptr); UErrorCode err = U_ZERO_ERROR; - const UBiDiLevel* levels = ubidi_getLevels(data->mBiDi, &err); + const UBiDiLevel* levels = ubidi_getLevels(uBiDi(ptr), &err); if (icu4jni_error(env, err)) { return NULL; } - int len = ubidi_getLength(data->mBiDi); + int len = ubidi_getLength(uBiDi(ptr)); jbyteArray result = env->NewByteArray(len); env->SetByteArrayRegion(result, 0, len, reinterpret_cast<const jbyte*>(levels)); return result; } static jint BidiWrapper_ubidi_countRuns(JNIEnv* env, jclass, jlong ptr) { - BiDiData* data = biDiData(ptr); UErrorCode err = U_ZERO_ERROR; - int count = ubidi_countRuns(data->mBiDi, &err); + int count = ubidi_countRuns(uBiDi(ptr), &err); icu4jni_error(env, err); return count; } static jobjectArray BidiWrapper_ubidi_getRuns(JNIEnv* env, jclass, jlong ptr) { - BiDiData* data = biDiData(ptr); + UBiDi* ubidi = uBiDi(ptr); UErrorCode err = U_ZERO_ERROR; - int runCount = ubidi_countRuns(data->mBiDi, &err); + int runCount = ubidi_countRuns(ubidi, &err); if (icu4jni_error(env, err)) { return NULL; } @@ -122,7 +141,7 @@ static jobjectArray BidiWrapper_ubidi_getRuns(JNIEnv* env, jclass, jlong ptr) { int start = 0; int limit = 0; for (int i = 0; i < runCount; ++i) { - ubidi_getLogicalRun(data->mBiDi, start, &limit, &level); + ubidi_getLogicalRun(ubidi, start, &limit, &level); jobject run = env->NewObject(bidiRunClass, bidiRunConstructor, start, limit, level); env->SetObjectArrayElement(runs, i, run); start = limit; @@ -131,13 +150,12 @@ static jobjectArray BidiWrapper_ubidi_getRuns(JNIEnv* env, jclass, jlong ptr) { } static jintArray BidiWrapper_ubidi_reorderVisual(JNIEnv* env, jclass, jbyteArray levels, jint length) { - int* local_indexMap = new int[length]; + UniquePtr<int[]> local_indexMap(new int[length]); jbyte* local_levelBytes = env->GetByteArrayElements(levels, NULL); UBiDiLevel* local_levels = reinterpret_cast<UBiDiLevel*>(local_levelBytes); - ubidi_reorderVisual(local_levels, length, local_indexMap); + ubidi_reorderVisual(local_levels, length, &local_indexMap[0]); jintArray result = env->NewIntArray(length); - env->SetIntArrayRegion(result, 0, length, local_indexMap); - delete[] local_indexMap; + env->SetIntArrayRegion(result, 0, length, &local_indexMap[0]); env->ReleaseByteArrayElements(levels, local_levelBytes, 0); return result; } |