/* * Copyright (C) 2010 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef SCOPED_JAVA_UNICODE_STRING_H_included #define SCOPED_JAVA_UNICODE_STRING_H_included #include <nativehelper/JNIHelp.h> #include "unicode/unistr.h" // A smart pointer that provides access to an ICU UnicodeString given a JNI // jstring. We give ICU a direct pointer to the characters on the Java heap. // It's clever enough to copy-on-write if necessary. class ScopedJavaUnicodeString { public: ScopedJavaUnicodeString(JNIEnv* env, jstring s) : mEnv(env), mString(s) { if (s == NULL) { jniThrowNullPointerException(mEnv, NULL); } else { mChars = env->GetStringChars(mString, NULL); const int32_t charCount = env->GetStringLength(mString); mUnicodeString.setTo(false, mChars, charCount); } } ~ScopedJavaUnicodeString() { if (mString != NULL) { mEnv->ReleaseStringChars(mString, mChars); } } bool valid() const { return (mString != NULL); } const icu::UnicodeString& unicodeString() const { return mUnicodeString; } icu::UnicodeString& unicodeString() { return mUnicodeString; } private: JNIEnv* mEnv; jstring mString; const jchar* mChars; icu::UnicodeString mUnicodeString; // Disallow copy and assignment. ScopedJavaUnicodeString(const ScopedJavaUnicodeString&); void operator=(const ScopedJavaUnicodeString&); }; #endif // SCOPED_JAVA_UNICODE_STRING_H_included