All Downloads are FREE. Search and download functionalities are using the official Maven repository.

kotlin.reflect.jvm.internal.impl.utils.collections.kt Maven / Gradle / Ivy

/*
 * Copyright 2010-2015 JetBrains s.r.o.
 *
 * 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.
 */

package kotlin.reflect.jvm.internal.impl.utils

import java.util.LinkedHashMap
import java.util.ArrayList
import java.util.HashMap
import java.util.HashSet
import java.util.Collections
import java.util.LinkedHashSet

public fun  Stream.valuesToMap(key: (V) -> K): Map {
    val map = LinkedHashMap()
    for (v in this) {
        map[key(v)] = v
    }
    return map
}

public fun  Stream.keysToMap(value: (K) -> V): Map {
    val map = LinkedHashMap()
    for (k in this) {
        map[k] = value(k)
    }
    return map
}

public fun  Stream.keysToMapExceptNulls(value: (K) -> V?): Map {
    val map = LinkedHashMap()
    for (k in this) {
        val v = value(k)
        if (v != null) {
            map[k] = v
        }
    }
    return map
}

public fun  Iterable.valuesToMap(key: (V) -> K): Map {
    val map = LinkedHashMap()
    for (v in this) {
        map[key(v)] = v
    }
    return map
}

public fun  Iterable.keysToMap(value: (K) -> V): Map {
    val map = LinkedHashMap()
    for (k in this) {
        map[k] = value(k)
    }
    return map
}

public fun  Iterable.keysToMapExceptNulls(value: (K) -> V?): Map {
    val map = LinkedHashMap()
    for (k in this) {
        val v = value(k)
        if (v != null) {
            map[k] = v
        }
    }
    return map
}

public fun  Iterable.mapToIndex(): Map {
    val map = LinkedHashMap()
    for ((index, k) in this.withIndex()) {
        map[k] = index
    }
    return map
}

public fun > C.ifEmpty(body: () -> C): C = if (isEmpty()) body() else this

public fun  emptyOrSingletonList(item: T?): List = if (item == null) listOf() else listOf(item)

public fun  MutableCollection.addIfNotNull(t: T?) {
    if (t != null) add(t)
}

public fun  newHashMapWithExpectedSize(expectedSize: Int): HashMap {
    return HashMap(if (expectedSize < 3) 3 else expectedSize + expectedSize / 3 + 1)
}

public fun  newHashSetWithExpectedSize(expectedSize: Int): HashSet {
    return HashSet(if (expectedSize < 3) 3 else expectedSize + expectedSize / 3 + 1)
}

public fun  Collection.toReadOnlyList(): List =
        if (isEmpty()) Collections.emptyList() else ArrayList(this)

public fun  T?.singletonOrEmptyList(): List = if (this != null) Collections.singletonList(this) else Collections.emptyList()




© 2015 - 2025 Weber Informatics LLC | Privacy Policy