4f15bd4817
There is a problem with ranges and iterators. To work properly they must be resolved firstly, before operator rangeTo.
41 lines
1.6 KiB
Kotlin
Vendored
41 lines
1.6 KiB
Kotlin
Vendored
// this hack is used to ensure that iterator will be resolved first
|
|
@CompileTimeCalculation internal class IntProgressionIterator(first: Int, last: Int, val step: Int) : IntIterator()
|
|
@CompileTimeCalculation public class IntRange(start: Int, endInclusive: Int) : IntProgression(start, endInclusive, 1), ClosedRange<Int>
|
|
|
|
@CompileTimeCalculation
|
|
fun varargSum(quantityToSum: Int, vararg num: Int): Int {
|
|
var sum = 0
|
|
for (i in 0..(quantityToSum - 1)) {
|
|
if (i >= num.size) return sum
|
|
sum += num[i]
|
|
}
|
|
return sum
|
|
}
|
|
|
|
@CompileTimeCalculation
|
|
fun sumWithVarargAtFirst(vararg num: Int, quantityToSum: Int = num.size) = varargSum(quantityToSum, *num)
|
|
|
|
@CompileTimeCalculation
|
|
fun concatenation(vararg str: String): String {
|
|
var result = ""
|
|
for (s in str) result += s
|
|
return result
|
|
}
|
|
|
|
@CompileTimeCalculation
|
|
fun customArrayConcatenation(vararg array: Any?): String {
|
|
var result = ""
|
|
for (elem in array) result += elem.toString() + " "
|
|
return result
|
|
}
|
|
|
|
const val a1 = <!EVALUATED: `6`!>varargSum(3, 1, 2, 3)<!>
|
|
const val a2 = <!EVALUATED: `3`!>varargSum(num = *intArrayOf(1, 2, 3), quantityToSum = 2)<!>
|
|
const val a3 = <!EVALUATED: `21`!>varargSum(6, *intArrayOf(1, 2), 3, *intArrayOf(4, 5, 6))<!>
|
|
|
|
const val b1 = <!EVALUATED: `6`!>sumWithVarargAtFirst(1, 2, 3)<!>
|
|
const val b2 = <!EVALUATED: `6`!>sumWithVarargAtFirst(quantityToSum = 3, num = *intArrayOf(1, 2, 3))<!>
|
|
|
|
const val c1 = <!EVALUATED: `1 2 3`!>concatenation(*arrayOf("1", " "), "2", *arrayOf(" ", "3"))<!>
|
|
const val c2 = <!EVALUATED: `1 2.0 3 -1 -2.0 `!>customArrayConcatenation(*arrayOf(1, 2.0), "3", *arrayOf(-1, -2.0))<!>
|