mirror of
				https://github.com/InsanusMokrassar/krontab.git
				synced 2025-10-26 09:00:09 +00:00 
			
		
		
		
	TimeBuilder docs
This commit is contained in:
		| @@ -3,27 +3,53 @@ package com.insanusmokrassar.krontab.builder | |||||||
| import com.insanusmokrassar.krontab.internal.* | import com.insanusmokrassar.krontab.internal.* | ||||||
| import com.insanusmokrassar.krontab.utils.clamp | import com.insanusmokrassar.krontab.utils.clamp | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * This class was created for incapsulation of builder work with specified [restrictionsRange]. For example, | ||||||
|  |  * [include] function of [TimeBuilder] will always [clamp] incoming data using its [restrictionsRange] | ||||||
|  |  */ | ||||||
| sealed class TimeBuilder ( | sealed class TimeBuilder ( | ||||||
|     private val restrictionsRange: IntRange |     private val restrictionsRange: IntRange | ||||||
| ) { | ) { | ||||||
|     private var result: Set<Int>? = null |     private var result: Set<Int>? = null | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * After calling of this function this builder will allow any value of current time | ||||||
|  |      */ | ||||||
|  |     @Suppress("unused") | ||||||
|     fun allowAll() { |     fun allowAll() { | ||||||
|         result = null |         result = null | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Will include all variations from this array inside of this timeline | ||||||
|  |      */ | ||||||
|  |     @Suppress("MemberVisibilityCanBePrivate") | ||||||
|     infix fun include(array: Array<Int>) { |     infix fun include(array: Array<Int>) { | ||||||
|         val clamped = array.map { it.clamp(restrictionsRange) } + (result ?: emptySet()) |         val clamped = array.map { it.clamp(restrictionsRange) } + (result ?: emptySet()) | ||||||
|         result = clamped.toSet() |         result = clamped.toSet() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Add one [value] to current timeline | ||||||
|  |      */ | ||||||
|  |     @Suppress("unused") | ||||||
|     infix fun at(value: Int) { |     infix fun at(value: Int) { | ||||||
|         result = (result ?: emptySet()) + value.clamp(restrictionsRange) |         result = (result ?: emptySet()) + value.clamp(restrictionsRange) | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Just wrapper for more obvious writing something like "[from] 2 [every] 5". For example, for [SecondsBuilder] it | ||||||
|  |      * will mean "[from] second second [every] 5 seconds", or "2, 7, 13, ..." | ||||||
|  |      */ | ||||||
|     @Suppress("NOTHING_TO_INLINE") |     @Suppress("NOTHING_TO_INLINE") | ||||||
|     inline fun from(value: Int) = value |     inline infix fun from(value: Int) = value | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Will create an sequence of times starting [from] [this] [every] [delay] times. For example, for [SecondsBuilder] it | ||||||
|  |      * will mean "[from] second second [every] 5 seconds", or "2, 7, 13, ..." | ||||||
|  |      * | ||||||
|  |      * @see [from] | ||||||
|  |      */ | ||||||
|     infix fun Int.every(delay: Int): Array<Int> { |     infix fun Int.every(delay: Int): Array<Int> { | ||||||
|         val progression = clamp(restrictionsRange) .. restrictionsRange.last step delay |         val progression = clamp(restrictionsRange) .. restrictionsRange.last step delay | ||||||
|         val result = progression.toSet().toTypedArray() |         val result = progression.toSet().toTypedArray() | ||||||
| @@ -32,8 +58,16 @@ sealed class TimeBuilder ( | |||||||
|  |  | ||||||
|         return result |         return result | ||||||
|     } |     } | ||||||
|     infix fun every(delay: Int): Array<Int> = 0 every delay |  | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Shortcut for "[from] 0 [every] [delay]" | ||||||
|  |      */ | ||||||
|  |     infix fun every(delay: Int): Array<Int> = this from 0 every delay | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Will fill up this timeline from [this] up to [endIncluding] | ||||||
|  |      */ | ||||||
|  |     @Suppress("MemberVisibilityCanBePrivate") | ||||||
|     infix fun Int.upTo(endIncluding: Int): Array<Int> { |     infix fun Int.upTo(endIncluding: Int): Array<Int> { | ||||||
|         val progression = clamp(restrictionsRange) .. endIncluding.clamp(restrictionsRange) |         val progression = clamp(restrictionsRange) .. endIncluding.clamp(restrictionsRange) | ||||||
|         val result = progression.toSet().toTypedArray() |         val result = progression.toSet().toTypedArray() | ||||||
| @@ -42,13 +76,17 @@ sealed class TimeBuilder ( | |||||||
|  |  | ||||||
|         return result |         return result | ||||||
|     } |     } | ||||||
|     infix fun upTo(endIncluding: Int): Array<Int> = 0 upTo endIncluding |     /** | ||||||
|  |      * Shortcut for "[from] 0 [upTo] [endIncluding]" | ||||||
|  |      */ | ||||||
|  |     @Suppress("unused") | ||||||
|  |     infix fun upTo(endIncluding: Int): Array<Int> = this from 0 upTo endIncluding | ||||||
|  |  | ||||||
|     internal fun build() = result ?.map { it.toByte() } ?.toTypedArray() |     internal fun build() = result ?.map { it.toByte() } ?.toTypedArray() | ||||||
| } | } | ||||||
|  |  | ||||||
| class SecondsBuilder : TimeBuilder(secondsRange) | class SecondsBuilder : TimeBuilder(secondsRange) | ||||||
| class MinutesBuilder : TimeBuilder(minutesRange) | class MinutesBuilder : TimeBuilder(minutesRange) | ||||||
| class HoursBuilder : TimeBuilder(com.insanusmokrassar.krontab.internal.hoursRange) | class HoursBuilder : TimeBuilder(hoursRange) | ||||||
| class DaysOfMonthBuilder : TimeBuilder(com.insanusmokrassar.krontab.internal.dayOfMonthRange) | class DaysOfMonthBuilder : TimeBuilder(dayOfMonthRange) | ||||||
| class MonthsBuilder : TimeBuilder(monthRange) | class MonthsBuilder : TimeBuilder(monthRange) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user