/* * Copyright 2010-2019 JetBrains s.r.o. and Kotlin Programming Language contributors. * Use of this source code is governed by the Apache 2.0 license that can be found in the license/LICENSE.txt file. */ // Auto-generated file. DO NOT EDIT! package kotlin @SinceKotlin("1.3") @ExperimentalUnsignedTypes public inline class UIntArray @Suppress("NON_PUBLIC_PRIMARY_CONSTRUCTOR_OF_INLINE_CLASS") @PublishedApi internal constructor(@PublishedApi internal val storage: IntArray) : Collection { /** Creates a new array of the specified [size], with all elements initialized to zero. */ public constructor(size: Int) : this(IntArray(size)) /** * Returns the array element at the given [index]. This method can be called using the index operator. * * If the [index] is out of bounds of this array, throws an [IndexOutOfBoundsException] except in Kotlin/JS * where the behavior is unspecified. */ public operator fun get(index: Int): UInt = storage[index].toUInt() /** * Sets the element at the given [index] to the given [value]. This method can be called using the index operator. * * If the [index] is out of bounds of this array, throws an [IndexOutOfBoundsException] except in Kotlin/JS * where the behavior is unspecified. */ public operator fun set(index: Int, value: UInt) { storage[index] = value.toInt() } /** Returns the number of elements in the array. */ public override val size: Int get() = storage.size /** Creates an iterator over the elements of the array. */ public override operator fun iterator(): UIntIterator = Iterator(storage) private class Iterator(private val array: IntArray) : UIntIterator() { private var index = 0 override fun hasNext() = index < array.size override fun nextUInt() = if (index < array.size) array[index++].toUInt() else throw NoSuchElementException(index.toString()) } override fun contains(element: UInt): 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 UInt) return false return storage.contains(element.toInt()) } override fun containsAll(elements: Collection): Boolean { return (elements as Collection<*>).all { it is UInt && storage.contains(it.toInt()) } } override fun isEmpty(): Boolean = this.storage.size == 0 } /** * Creates a new array of the specified [size], where each element is calculated by calling the specified * [init] function. * * The function [init] is called for each array element sequentially starting from the first one. * It should return the value for an array element given its index. */ @SinceKotlin("1.3") @ExperimentalUnsignedTypes @kotlin.internal.InlineOnly public inline fun UIntArray(size: Int, init: (Int) -> UInt): UIntArray { return UIntArray(IntArray(size) { index -> init(index).toInt() }) } @SinceKotlin("1.3") @ExperimentalUnsignedTypes @kotlin.internal.InlineOnly public inline fun uintArrayOf(vararg elements: UInt): UIntArray = elements