diff -r f5050f1da672 -r 04becd199f91 javauis/javalegacyutils/src/ArrayUtils.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/javauis/javalegacyutils/src/ArrayUtils.cpp Tue Apr 27 16:30:29 2010 +0300 @@ -0,0 +1,118 @@ +/* +* Copyright (c) 2002-2004 Nokia Corporation and/or its subsidiary(-ies). +* All rights reserved. +* This component and the accompanying materials are made available +* under the terms of "Eclipse Public License v1.0" +* which accompanies this distribution, and is available +* at the URL "http://www.eclipse.org/legal/epl-v10.html". +* +* Initial Contributors: +* Nokia Corporation - initial contribution. +* +* Contributors: +* +* Description: +* +*/ + + +#include "jutils.h" + + + +enum TJavaArrayPanic +{ + EBadOffsetIntoJavaArray, + EWritingOverEndOfJavaArray, + EBadOffsetIntoJavaArrayForRead, + EReadingOverEndOfJavaArray, +}; + + + +/** + * Accesses the Java array and copies its data into the native descriptor. + * @param aJni The JNI environment. + * @param aJavaBuffer The Java buffer to copy data from. + * @param aOffset Start of data in Java buffer to copy. This is assumed to be valid. + * @param aLength Amount of data to copy. This is assumed to be valid. + * @param aNativeBuffer Target for data. This is assumed to be long enough. + * @returns An error code. + */ +TInt ArrayUtils::CopyToNative(JNIEnv& aJni, jbyteArray aJavaBuffer, + TInt aOffset, TInt aLength, TDes8& aNativeBuffer) +{ + __ASSERT_DEBUG(aOffset <= aJni.GetArrayLength(aJavaBuffer), + User::Panic(_L("ArrayUtils"), EBadOffsetIntoJavaArrayForRead)); + __ASSERT_DEBUG(aLength <= aJni.GetArrayLength(aJavaBuffer) - aOffset, + User::Panic(_L("ArrayUtils"), EReadingOverEndOfJavaArray)); + + aNativeBuffer.SetLength(aLength); + TUint8* nativeBufferPtr = const_cast(aNativeBuffer.Ptr()); + jbyte* jNativeBufferPtr = reinterpret_cast(nativeBufferPtr); + aJni.GetByteArrayRegion(aJavaBuffer, aOffset, aLength, jNativeBufferPtr); + return KErrNone; +} + + + +/** + * Copies data from the native to the Java array. + * @return The number of bytes copied. + */ +EXPORT_C TInt ArrayUtils::CopyToJava(JNIEnv& aJni, const TDesC8& aNativeBuffer, + jbyteArray aJavaBuffer, TInt aOffset, TInt aLength) +{ + __ASSERT_DEBUG(aOffset <= aJni.GetArrayLength(aJavaBuffer), + User::Panic(_L("ArrayUtils"), EBadOffsetIntoJavaArray)); + __ASSERT_DEBUG(aLength <= aJni.GetArrayLength(aJavaBuffer) - aOffset, + User::Panic(_L("ArrayUtils"), EWritingOverEndOfJavaArray)); + + TInt nativeBufferLength = aNativeBuffer.Length(); + TInt length = (nativeBufferLength < aLength) ? nativeBufferLength : aLength; + TUint8* nativeBufferPtr = const_cast(aNativeBuffer.Ptr()); + jbyte* jNativeBufferPtr = reinterpret_cast(nativeBufferPtr); + aJni.SetByteArrayRegion(aJavaBuffer, aOffset, length, jNativeBufferPtr); + return length; +} + + + +/** + * Creates a Java array of strings from a native array of descriptors allocated + * on the heap. + * @param aJni The JNI environment. + * @param aNativeArray The array of descriptors. + * @return The newly created Java array of String objects, or NULL on error. + */ +jobjectArray ArrayUtils::CopyToNewJavaStringArray(JNIEnv& aJni, + const RPointerArray& aNativeArray) +{ + jclass stringClass = aJni.FindClass("java/lang/String"); + if (stringClass == NULL) + { + return NULL; + } + + TInt count = aNativeArray.Count(); + jobjectArray result = aJni.NewObjectArray(count, stringClass, NULL); + if (result == NULL) + { + return NULL; + } + + for (int ii = 0; ii< count; ii++) + { + jstring javaString = CreateJavaString(aJni, *aNativeArray[ii]); + if (javaString == NULL) + { + aJni.DeleteLocalRef(result); + return NULL; + } + + aJni.SetObjectArrayElement(result, ii, javaString); + aJni.DeleteLocalRef(javaString); + } + + return result; +}