forked from facebook/react-native
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Migrate NativeArray classes to Kotlin (facebook#44569)
Summary: Pull Request resolved: facebook#44569 # Changelog: [Internal] - This converts the vertical of NativeArray/ReadableNativeArray/WritableNativeArray classes to Kotlin. NOTE: the `getArray`, `getMap` and `getString` being annotated as `NonNull` in the Java code is a scam - there is no guarantee that native side will send non-null to the Java side, and in practice, indeed, in certain cases it doesn't. So I opted to make it nullable instead - this way it's at least explicit and is not a ticking bomb hidden to explode behind the false sense of security. Reviewed By: javache Differential Revision: D57327835
- Loading branch information
1 parent
52fc64c
commit d165515
Showing
12 changed files
with
184 additions
and
278 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
28 changes: 0 additions & 28 deletions
28
packages/react-native/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeArray.java
This file was deleted.
Oops, something went wrong.
25 changes: 25 additions & 0 deletions
25
packages/react-native/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeArray.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
/* | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
package com.facebook.react.bridge | ||
|
||
import com.facebook.jni.HybridData | ||
import com.facebook.proguard.annotations.DoNotStrip | ||
|
||
/** Base class for an array whose members are stored in native code (C++). */ | ||
@DoNotStrip | ||
public abstract class NativeArray | ||
protected constructor(@field:DoNotStrip private val mHybridData: HybridData?) : | ||
NativeArrayInterface { | ||
external override fun toString(): String | ||
|
||
private companion object { | ||
init { | ||
ReactBridge.staticInit() | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
174 changes: 0 additions & 174 deletions
174
...eact-native/ReactAndroid/src/main/java/com/facebook/react/bridge/ReadableNativeArray.java
This file was deleted.
Oops, something went wrong.
90 changes: 90 additions & 0 deletions
90
.../react-native/ReactAndroid/src/main/java/com/facebook/react/bridge/ReadableNativeArray.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
/* | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
package com.facebook.react.bridge | ||
|
||
import com.facebook.jni.HybridData | ||
import com.facebook.proguard.annotations.DoNotStripAny | ||
import java.util.Arrays | ||
|
||
/** | ||
* Implementation of a NativeArray that allows read-only access to its members. This will generally | ||
* be constructed and filled in native code so you shouldn't construct one yourself. | ||
*/ | ||
@DoNotStripAny | ||
public open class ReadableNativeArray protected constructor(hybridData: HybridData?) : | ||
NativeArray(hybridData), ReadableArray { | ||
|
||
private val localArray: Array<Any?> by | ||
lazy(LazyThreadSafetyMode.SYNCHRONIZED) { | ||
jniPassCounter++ | ||
importArray() | ||
} | ||
|
||
private external fun importArray(): Array<Any?> | ||
|
||
private val localTypeArray: Array<ReadableType> by | ||
lazy(LazyThreadSafetyMode.SYNCHRONIZED) { | ||
jniPassCounter++ | ||
importTypeArray() | ||
} | ||
|
||
private external fun importTypeArray(): Array<ReadableType> | ||
|
||
override fun size(): Int = localArray.size | ||
|
||
override fun isNull(index: Int): Boolean = localArray[index] == null | ||
|
||
override fun getBoolean(index: Int): Boolean = localArray[index] as Boolean | ||
|
||
override fun getDouble(index: Int): Double = localArray[index] as Double | ||
|
||
override fun getInt(index: Int): Int = getDouble(index).toInt() | ||
|
||
override fun getLong(index: Int): Long = localArray[index] as Long | ||
|
||
override fun getString(index: Int): String = localArray[index] as String | ||
|
||
override fun getArray(index: Int): ReadableNativeArray = localArray[index] as ReadableNativeArray | ||
|
||
override fun getMap(index: Int): ReadableNativeMap = localArray[index] as ReadableNativeMap | ||
|
||
override fun getType(index: Int): ReadableType = localTypeArray[index] | ||
|
||
override fun getDynamic(index: Int): Dynamic = DynamicFromArray.create(this, index) | ||
|
||
override fun hashCode(): Int = localArray.hashCode() | ||
|
||
override fun equals(other: Any?): Boolean = | ||
if (other !is ReadableNativeArray) false else Arrays.deepEquals(localArray, other.localArray) | ||
|
||
override fun toArrayList(): ArrayList<Any?> { | ||
val arrayList = ArrayList<Any?>() | ||
for (i in 0 until size()) { | ||
when (getType(i)) { | ||
ReadableType.Null -> arrayList.add(null) | ||
ReadableType.Boolean -> arrayList.add(getBoolean(i)) | ||
ReadableType.Number -> arrayList.add(getDouble(i)) | ||
ReadableType.String -> arrayList.add(getString(i)) | ||
ReadableType.Map -> arrayList.add(getMap(i).toHashMap()) | ||
ReadableType.Array -> arrayList.add(getArray(i).toArrayList()) | ||
else -> throw IllegalArgumentException("Could not convert object at index: $i.") | ||
} | ||
} | ||
return arrayList | ||
} | ||
|
||
private companion object { | ||
init { | ||
ReactBridge.staticInit() | ||
} | ||
|
||
private var jniPassCounter: Int = 0 | ||
|
||
@JvmStatic public fun getJNIPassCounter(): Int = jniPassCounter | ||
} | ||
} |
Oops, something went wrong.