Implement UArray.contains(element) workaround for JS

This commit is contained in:
Abduqodiri Qurbonzoda
2019-02-20 17:53:45 +03:00
committed by Ilya Gorbunov
parent c1b523ddef
commit ae47130c8e
5 changed files with 35 additions and 5 deletions
@@ -37,7 +37,13 @@ internal constructor(@PublishedApi internal val storage: LongArray) : Collection
override fun nextULong() = if (index < array.size) array[index++].toULong() else throw NoSuchElementException(index.toString())
}
override fun contains(element: ULong): Boolean = storage.contains(element.toLong())
override fun contains(element: ULong): Boolean {
// TODO: Eliminate this check after KT-30016 gets fixed.
// Currently JS BE does not generate special bridge method for this method.
if ((element as Any?) !is ULong) return false
return storage.contains(element.toLong())
}
override fun containsAll(elements: Collection<ULong>): Boolean {
if ((elements as Collection<Any?>).any { it as? ULong == null }) return false