diff options
author | Elliott Hughes <enh@google.com> | 2009-12-08 15:41:35 -0800 |
---|---|---|
committer | Elliott Hughes <enh@google.com> | 2009-12-08 15:49:01 -0800 |
commit | d385bfc328b9d85901eec969a55afb28125f2b51 (patch) | |
tree | 674e8fe777e6e36a2222301cbcc1f27bd0094650 /include | |
parent | b5b999c3400cb43fb785fc2acd42029ed7851f42 (diff) | |
download | libcore-d385bfc328b9d85901eec969a55afb28125f2b51.zip libcore-d385bfc328b9d85901eec969a55afb28125f2b51.tar.gz libcore-d385bfc328b9d85901eec969a55afb28125f2b51.tar.bz2 |
Improve the FileNotFoundExceptions thrown by OSFileSystem.open.
When I improved the internals of java.io.File, I failed to keep
OSFileSystem.open (which uses the internals of java.io.File) in
sync, leading to misleading error reporting. java.io.File's
internals now include a trailing NUL, which is useful for the
native code but confuses Java if it tries to decode the byte[]
as a UTF-8 sequence.
This patch fixes the bug and also improves OSFileSystem.open's
error reporting to include the reason for the failure.
Bug: 2313271
Diffstat (limited to 'include')
-rw-r--r-- | include/ScopedByteArray.h | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/include/ScopedByteArray.h b/include/ScopedByteArray.h new file mode 100644 index 0000000..bcbee99 --- /dev/null +++ b/include/ScopedByteArray.h @@ -0,0 +1,53 @@ +/* + * Copyright (C) 2009 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_BYTE_ARRAY_H_included +#define SCOPED_BYTE_ARRAY_H_included + +#include "JNIHelp.h" + +// A smart pointer that provides read-only access to a Java byte[]. +class ScopedByteArray { +public: + ScopedByteArray(JNIEnv* env, jbyteArray byteArray) + : mEnv(env), mByteArray(byteArray), mBytes(NULL) + { + mBytes = env->GetByteArrayElements(mByteArray, NULL); + } + + ~ScopedByteArray() { + if (mBytes) { + mEnv->ReleaseByteArrayElements(mByteArray, mBytes, JNI_ABORT); + } + } + + const jbyte* bytes() const { + return mBytes; + } + + // Element access. + const char& operator[](size_t n) const { + const char* array = reinterpret_cast<const char*>(mBytes); + return array[n]; + } + +private: + JNIEnv* mEnv; + jbyteArray mByteArray; + jbyte* mBytes; +}; + +#endif // SCOPED_BYTE_ARRAY_H_included |