mirror of
				https://github.com/InsanusMokrassar/krontab.git
				synced 2025-10-26 09:00:09 +00:00 
			
		
		
		
	potential fix of #107
This commit is contained in:
		| @@ -2,6 +2,8 @@ | ||||
|  | ||||
| ## 2.3.0 | ||||
|  | ||||
| * `doWhile` now will guarantee that it will not call `doOnce` more than once for time | ||||
|  | ||||
| ## 2.2.9 | ||||
|  | ||||
| * `Version`: | ||||
|   | ||||
| @@ -71,9 +71,18 @@ suspend inline fun <T> doOnceTz( | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doWhile(block: (DateTime) -> Boolean) { | ||||
|     var latest: DateTime? = null | ||||
|     do { | ||||
|         delay(1L) | ||||
|     } while (doOnce(block)) | ||||
|         val result = doOnce { | ||||
|             if (latest != it) { | ||||
|                 latest = it | ||||
|                 block(it) | ||||
|             } else { | ||||
|                 null | ||||
|             } | ||||
|         } | ||||
|     } while (result == null || result) | ||||
| } | ||||
| /** | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
| @@ -85,9 +94,18 @@ suspend inline fun KronScheduler.doWhileLocal(block: (DateTime) -> Boolean) = do | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doWhileTz(noinline block: suspend (DateTimeTz) -> Boolean) { | ||||
|     var latest: DateTimeTz? = null | ||||
|     do { | ||||
|         delay(1L) | ||||
|     } while (doOnceTz(block)) | ||||
|         val result = doOnceTz { | ||||
|             if (latest != it) { | ||||
|                 latest = it | ||||
|                 block(it) | ||||
|             } else { | ||||
|                 null | ||||
|             } | ||||
|         } | ||||
|     } while (result == null || result) | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
		Reference in New Issue
	
	Block a user