/* * 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_UTF_CHARS_H_included #define SCOPED_UTF_CHARS_H_included #include "JNIHelp.h" #include <string.h> // A smart pointer that provides read-only access to a Java string's UTF chars. // Unlike GetStringUTFChars, we throw NullPointerException rather than abort if // passed a null jstring, and c_str will return NULL. // This makes the correct idiom very simple: // // ScopedUtfChars name(env, javaName); // if (name.c_str() == NULL) { // return NULL; // } class ScopedUtfChars { public: ScopedUtfChars(JNIEnv* env, jstring s) : mEnv(env), mString(s) { if (s == NULL) { mUtfChars = NULL; jniThrowNullPointerException(env, NULL); } else { mUtfChars = env->GetStringUTFChars(s, NULL); } } ~ScopedUtfChars() { if (mUtfChars) { mEnv->ReleaseStringUTFChars(mString, mUtfChars); } } const char* c_str() const { return mUtfChars; } size_t size() const { return strlen(mUtfChars); } // Element access. const char& operator[](size_t n) const { return mUtfChars[n]; } private: JNIEnv* mEnv; jstring mString; const char* mUtfChars; // Disallow copy and assignment. ScopedUtfChars(const ScopedUtfChars&); void operator=(const ScopedUtfChars&); }; #endif // SCOPED_UTF_CHARS_H_included