mirror of
				https://github.com/InsanusMokrassar/krontab.git
				synced 2025-10-25 16:40:06 +00:00 
			
		
		
		
	| @@ -1,5 +1,14 @@ | ||||
| # Changelog | ||||
|  | ||||
| ## 0.7.2 | ||||
|  | ||||
| * Versions | ||||
|   * `Coroutines`: `1.6.1` | ||||
|   * `Klock`: `2.7.0` | ||||
| * Deprecate `do*Local` due to their redundancy (use `do*` instead) | ||||
| * Add support of milliseconds as optional parameter after month (fix of [#31](https://github.com/InsanusMokrassar/krontab/issues/31)) | ||||
| * Add support of filters for `Flow`s with `DateTime` (fix of [#30](https://github.com/InsanusMokrassar/krontab/issues/30)) | ||||
|  | ||||
| ## 0.7.1 | ||||
|  | ||||
| * Versions | ||||
|   | ||||
| @@ -9,22 +9,22 @@ android.enableJetifier=false | ||||
|  | ||||
|  | ||||
| kotlin_version=1.6.10 | ||||
| kotlin_coroutines_version=1.6.0 | ||||
| kotlin_coroutines_version=1.6.1 | ||||
|  | ||||
| dokka_version=1.6.10 | ||||
|  | ||||
| klockVersion=2.5.2 | ||||
| klockVersion=2.7.0 | ||||
|  | ||||
| ## Github reease | ||||
|  | ||||
| github_release_plugin_version=2.2.12 | ||||
| github_release_plugin_version=2.3.7 | ||||
|  | ||||
| ## Android | ||||
|  | ||||
| android_minSdkVersion=19 | ||||
| android_compileSdkVersion=32 | ||||
| android_buildToolsVersion=32.0.0 | ||||
| dexcount_version=3.0.0 | ||||
| dexcount_version=3.0.1 | ||||
| junit_version=4.12 | ||||
| test_ext_junit_version=1.1.2 | ||||
| espresso_core=3.3.0 | ||||
| @@ -33,5 +33,5 @@ androidx_work_version=2.7.1 | ||||
|  | ||||
| ## Common | ||||
|  | ||||
| version=0.7.1 | ||||
| android_code_version=12 | ||||
| version=0.7.2 | ||||
| android_code_version=13 | ||||
|   | ||||
| @@ -3,9 +3,9 @@ | ||||
|  | ||||
|  | ||||
| "@discoveryjs/json-ext@^0.5.0": | ||||
|   version "0.5.6" | ||||
|   resolved "https://registry.yarnpkg.com/@discoveryjs/json-ext/-/json-ext-0.5.6.tgz#d5e0706cf8c6acd8c6032f8d54070af261bbbb2f" | ||||
|   integrity sha512-ws57AidsDvREKrZKYffXddNkyaF14iHNHm8VQnZH6t99E8gczjNN0GpvcGny0imC80yQ0tHz1xVUKk/KFQSUyA== | ||||
|   version "0.5.7" | ||||
|   resolved "https://registry.yarnpkg.com/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz#1d572bfbbe14b7704e0ba0f39b74815b84870d70" | ||||
|   integrity sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw== | ||||
|  | ||||
| "@types/component-emitter@^1.2.10": | ||||
|   version "1.2.11" | ||||
| @@ -49,14 +49,14 @@ | ||||
|   integrity sha512-C6N5s2ZFtuZRj54k2/zyRhNDjJwwcViAM3Nbm8zjBpbqAdZ00mr0CFxvSKeO8Y/e03WVFLpQMdHYVfUd6SB+Hw== | ||||
|  | ||||
| "@types/json-schema@*", "@types/json-schema@^7.0.8": | ||||
|   version "7.0.9" | ||||
|   resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.9.tgz#97edc9037ea0c38585320b28964dde3b39e4660d" | ||||
|   integrity sha512-qcUXuemtEu+E5wZSJHNxUXeCZhAfXKQ41D+duX+VYPde7xyEVZci+/oXKJL13tnRs9lR2pr4fod59GT6/X1/yQ== | ||||
|   version "7.0.11" | ||||
|   resolved "https://registry.yarnpkg.com/@types/json-schema/-/json-schema-7.0.11.tgz#d421b6c527a3037f7c84433fd2c4229e016863d3" | ||||
|   integrity sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ== | ||||
|  | ||||
| "@types/node@*", "@types/node@>=10.0.0": | ||||
|   version "17.0.21" | ||||
|   resolved "https://registry.yarnpkg.com/@types/node/-/node-17.0.21.tgz#864b987c0c68d07b4345845c3e63b75edd143644" | ||||
|   integrity sha512-DBZCJbhII3r90XbQxI8Y9IjjiiOGlZ0Hr32omXIZvwwZ7p4DMMXGrKXVyPfuoBOri9XNtL0UK69jYIBIsRX3QQ== | ||||
|   version "17.0.30" | ||||
|   resolved "https://registry.yarnpkg.com/@types/node/-/node-17.0.30.tgz#2c6e8512acac70815e8176aa30c38025067880ef" | ||||
|   integrity sha512-oNBIZjIqyHYP8VCNAV9uEytXVeXG2oR0w9lgAXro20eugRQfY002qr3CUl6BAe+Yf/z3CRjPdz27Pu6WWtuSRw== | ||||
|  | ||||
| "@ungap/promise-all-settled@1.1.2": | ||||
|   version "1.1.2" | ||||
| @@ -212,9 +212,9 @@ | ||||
|   integrity sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ== | ||||
|  | ||||
| abab@^2.0.5: | ||||
|   version "2.0.5" | ||||
|   resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" | ||||
|   integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q== | ||||
|   version "2.0.6" | ||||
|   resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.6.tgz#41b80f2c871d19686216b82309231cfd3cb3d291" | ||||
|   integrity sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA== | ||||
|  | ||||
| accepts@~1.3.4: | ||||
|   version "1.3.8" | ||||
| @@ -230,9 +230,9 @@ acorn-import-assertions@^1.7.6: | ||||
|   integrity sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw== | ||||
|  | ||||
| acorn@^8.4.1, acorn@^8.5.0: | ||||
|   version "8.7.0" | ||||
|   resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf" | ||||
|   integrity sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ== | ||||
|   version "8.7.1" | ||||
|   resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.1.tgz#0197122c843d1bf6d0a5e83220a788f278f63c30" | ||||
|   integrity sha512-Xx54uLJQZ19lKygFXOWsscKUbsBZW0CPykPhVQdhIeIwrbPmJzqeASDInc8nKBnp/JT6igTs82qPXz069H8I/A== | ||||
|  | ||||
| ajv-keywords@^3.5.2: | ||||
|   version "3.5.2" | ||||
| @@ -300,20 +300,22 @@ binary-extensions@^2.0.0: | ||||
|   integrity sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA== | ||||
|  | ||||
| body-parser@^1.19.0: | ||||
|   version "1.19.2" | ||||
|   resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.2.tgz#4714ccd9c157d44797b8b5607d72c0b89952f26e" | ||||
|   integrity sha512-SAAwOxgoCKMGs9uUAUFHygfLAyaniaoun6I8mFY9pRAJL9+Kec34aU+oIjDhTycub1jozEfEwx1W1IuOYxVSFw== | ||||
|   version "1.20.0" | ||||
|   resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.20.0.tgz#3de69bd89011c11573d7bfee6a64f11b6bd27cc5" | ||||
|   integrity sha512-DfJ+q6EPcGKZD1QWUjSpqp+Q7bDQTsQIF4zfUAtZ6qk+H/3/QRhg9CEp39ss+/T2vw0+HaidC0ecJj/DRLIaKg== | ||||
|   dependencies: | ||||
|     bytes "3.1.2" | ||||
|     content-type "~1.0.4" | ||||
|     debug "2.6.9" | ||||
|     depd "~1.1.2" | ||||
|     http-errors "1.8.1" | ||||
|     depd "2.0.0" | ||||
|     destroy "1.2.0" | ||||
|     http-errors "2.0.0" | ||||
|     iconv-lite "0.4.24" | ||||
|     on-finished "~2.3.0" | ||||
|     qs "6.9.7" | ||||
|     raw-body "2.4.3" | ||||
|     on-finished "2.4.1" | ||||
|     qs "6.10.3" | ||||
|     raw-body "2.5.1" | ||||
|     type-is "~1.6.18" | ||||
|     unpipe "1.0.0" | ||||
|  | ||||
| brace-expansion@^1.1.7: | ||||
|   version "1.1.11" | ||||
| @@ -336,14 +338,14 @@ browser-stdout@1.3.1: | ||||
|   integrity sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw== | ||||
|  | ||||
| browserslist@^4.14.5: | ||||
|   version "4.19.3" | ||||
|   resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.19.3.tgz#29b7caad327ecf2859485f696f9604214bedd383" | ||||
|   integrity sha512-XK3X4xtKJ+Txj8G5c30B4gsm71s69lqXlkYui4s6EkKxuv49qjYlY6oVd+IFJ73d4YymtM3+djvvt/R/iJwwDg== | ||||
|   version "4.20.3" | ||||
|   resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.20.3.tgz#eb7572f49ec430e054f56d52ff0ebe9be915f8bf" | ||||
|   integrity sha512-NBhymBQl1zM0Y5dQT/O+xiLP9/rzOIQdKM/eMJBAq7yBgaB6krIYLGejrwVYnSHZdqjscB1SPuAjHwxjvN6Wdg== | ||||
|   dependencies: | ||||
|     caniuse-lite "^1.0.30001312" | ||||
|     electron-to-chromium "^1.4.71" | ||||
|     caniuse-lite "^1.0.30001332" | ||||
|     electron-to-chromium "^1.4.118" | ||||
|     escalade "^3.1.1" | ||||
|     node-releases "^2.0.2" | ||||
|     node-releases "^2.0.3" | ||||
|     picocolors "^1.0.0" | ||||
|  | ||||
| buffer-from@^1.0.0: | ||||
| @@ -356,15 +358,23 @@ bytes@3.1.2: | ||||
|   resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" | ||||
|   integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== | ||||
|  | ||||
| call-bind@^1.0.0: | ||||
|   version "1.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/call-bind/-/call-bind-1.0.2.tgz#b1d4e89e688119c3c9a903ad30abb2f6a919be3c" | ||||
|   integrity sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA== | ||||
|   dependencies: | ||||
|     function-bind "^1.1.1" | ||||
|     get-intrinsic "^1.0.2" | ||||
|  | ||||
| camelcase@^6.0.0: | ||||
|   version "6.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.3.0.tgz#5685b95eb209ac9c0c177467778c9c84df58ba9a" | ||||
|   integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== | ||||
|  | ||||
| caniuse-lite@^1.0.30001312: | ||||
|   version "1.0.30001312" | ||||
|   resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001312.tgz#e11eba4b87e24d22697dae05455d5aea28550d5f" | ||||
|   integrity sha512-Wiz1Psk2MEK0pX3rUzWaunLTZzqS2JYZFzNKqAiJGiuxIjRPLgV6+VDPOg6lQOUxmDwhTlh198JsTTi8Hzw6aQ== | ||||
| caniuse-lite@^1.0.30001332: | ||||
|   version "1.0.30001334" | ||||
|   resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001334.tgz#892e9965b35285033fc2b8a8eff499fe02f13d8b" | ||||
|   integrity sha512-kbaCEBRRVSoeNs74sCuq92MJyGrMtjWVfhltoHUCW4t4pXFvGjUBrfo47weBRViHkiV3eBYyIsfl956NtHGazw== | ||||
|  | ||||
| chalk@^4.1.0: | ||||
|   version "4.1.2" | ||||
| @@ -511,10 +521,10 @@ custom-event@~1.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/custom-event/-/custom-event-1.0.1.tgz#5d02a46850adf1b4a317946a3928fccb5bfd0425" | ||||
|   integrity sha1-XQKkaFCt8bSjF5RqOSj8y1v9BCU= | ||||
|  | ||||
| date-format@^4.0.3: | ||||
|   version "4.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/date-format/-/date-format-4.0.3.tgz#f63de5dc08dc02efd8ef32bf2a6918e486f35873" | ||||
|   integrity sha512-7P3FyqDcfeznLZp2b+OMitV9Sz2lUnsT87WaTat9nVwqsBkTzPG3lPLNwW3en6F4pHUiWzr6vb8CLhjdK9bcxQ== | ||||
| date-format@^4.0.9: | ||||
|   version "4.0.9" | ||||
|   resolved "https://registry.yarnpkg.com/date-format/-/date-format-4.0.9.tgz#4788015ac56dedebe83b03bc361f00c1ddcf1923" | ||||
|   integrity sha512-+8J+BOUpSrlKLQLeF8xJJVTxS8QfRSuJgwxSVvslzgO3E6khbI0F5mMEPf5mTYhCCm4h99knYP6H3W9n3BQFrg== | ||||
|  | ||||
| debug@2.6.9: | ||||
|   version "2.6.9" | ||||
| @@ -530,10 +540,10 @@ debug@4.3.2: | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| debug@^4.1.1, debug@^4.3.3, debug@~4.3.1: | ||||
|   version "4.3.3" | ||||
|   resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" | ||||
|   integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q== | ||||
| debug@^4.3.4, debug@~4.3.1: | ||||
|   version "4.3.4" | ||||
|   resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.4.tgz#1319f6579357f2338d3337d2cdd4914bb5dcc865" | ||||
|   integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== | ||||
|   dependencies: | ||||
|     ms "2.1.2" | ||||
|  | ||||
| @@ -542,10 +552,15 @@ decamelize@^4.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-4.0.0.tgz#aa472d7bf660eb15f3494efd531cab7f2a709837" | ||||
|   integrity sha512-9iE1PgSik9HeIIw2JO94IidnE3eBoQrFJ3w7sFuzSX4DpmZ3v5sZpUiV5Swcf6mQEF+Y0ru8Neo+p+nyh2J+hQ== | ||||
|  | ||||
| depd@~1.1.2: | ||||
|   version "1.1.2" | ||||
|   resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" | ||||
|   integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= | ||||
| depd@2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/depd/-/depd-2.0.0.tgz#b696163cc757560d09cf22cc8fad1571b79e76df" | ||||
|   integrity sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw== | ||||
|  | ||||
| destroy@1.2.0: | ||||
|   version "1.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.2.0.tgz#4803735509ad8be552934c67df614f94e66fa015" | ||||
|   integrity sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg== | ||||
|  | ||||
| di@^0.0.1: | ||||
|   version "0.0.1" | ||||
| @@ -572,10 +587,10 @@ ee-first@1.1.1: | ||||
|   resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" | ||||
|   integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= | ||||
|  | ||||
| electron-to-chromium@^1.4.71: | ||||
|   version "1.4.73" | ||||
|   resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.73.tgz#422f6f514315bcace9615903e4a9b6b9fa283137" | ||||
|   integrity sha512-RlCffXkE/LliqfA5m29+dVDPB2r72y2D2egMMfIy3Le8ODrxjuZNVo4NIC2yPL01N4xb4nZQLwzi6Z5tGIGLnA== | ||||
| electron-to-chromium@^1.4.118: | ||||
|   version "1.4.127" | ||||
|   resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.127.tgz#4ef19d5d920abe2676d938f4170729b44f7f423a" | ||||
|   integrity sha512-nhD6S8nKI0O2MueC6blNOEZio+/PWppE/pevnf3LOlQA/fKPCrDp2Ao4wx4LFwmIkJpVdFdn2763YWLy9ENIZg== | ||||
|  | ||||
| emoji-regex@^8.0.0: | ||||
|   version "8.0.0" | ||||
| @@ -608,9 +623,9 @@ engine.io@~4.1.0: | ||||
|     ws "~7.4.2" | ||||
|  | ||||
| enhanced-resolve@^5.8.3: | ||||
|   version "5.9.1" | ||||
|   resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.9.1.tgz#e898cea44d9199fd92137496cff5691b910fb43e" | ||||
|   integrity sha512-jdyZMwCQ5Oj4c5+BTnkxPgDZO/BJzh/ADDmKebayyzNwjVX1AFCeGkOfxNx0mHi2+8BKC5VxUYiw3TIvoT7vhw== | ||||
|   version "5.9.3" | ||||
|   resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-5.9.3.tgz#44a342c012cbc473254af5cc6ae20ebd0aae5d88" | ||||
|   integrity sha512-Bq9VSor+kjvW3f9/MiiR4eE3XYgOl7/rS8lnSxbRbF3kS0B2r+Y9w5krBWxZgDxASVZbdYrn5wT4j/Wb0J9qow== | ||||
|   dependencies: | ||||
|     graceful-fs "^4.2.4" | ||||
|     tapable "^2.2.0" | ||||
| @@ -756,7 +771,7 @@ flat@^5.0.2: | ||||
|   resolved "https://registry.yarnpkg.com/flat/-/flat-5.0.2.tgz#8ca6fe332069ffa9d324c327198c598259ceb241" | ||||
|   integrity sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ== | ||||
|  | ||||
| flatted@^3.2.4: | ||||
| flatted@^3.2.5: | ||||
|   version "3.2.5" | ||||
|   resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.5.tgz#76c8584f4fc843db64702a6bd04ab7a8bd666da3" | ||||
|   integrity sha512-WIWGi2L3DyTUvUrwRKgGi9TwxQMUEqPOPQBVi71R96jZXJdFskXEmf54BoZaS1kknGODoIGASGEzBUYdyMCBJg== | ||||
| @@ -771,10 +786,10 @@ format-util@1.0.5: | ||||
|   resolved "https://registry.yarnpkg.com/format-util/-/format-util-1.0.5.tgz#1ffb450c8a03e7bccffe40643180918cc297d271" | ||||
|   integrity sha512-varLbTj0e0yVyRpqQhuWV+8hlePAgaoFRhNFj50BNjEIrw1/DphHSObtqwskVCPWNgzwPoQrZAbfa/SBiicNeg== | ||||
|  | ||||
| fs-extra@^10.0.0: | ||||
|   version "10.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.0.1.tgz#27de43b4320e833f6867cc044bfce29fdf0ef3b8" | ||||
|   integrity sha512-NbdoVMZso2Lsrn/QwLXOy6rm0ufY2zEOKCDzJR/0kBsb0E6qed0P3iYK+Ath3BfvXEeu4JhEtXLgILx5psUfag== | ||||
| fs-extra@^10.1.0: | ||||
|   version "10.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-10.1.0.tgz#02873cfbc4084dde127eaa5f9905eef2325d1abf" | ||||
|   integrity sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ== | ||||
|   dependencies: | ||||
|     graceful-fs "^4.2.0" | ||||
|     jsonfile "^6.0.1" | ||||
| @@ -800,6 +815,15 @@ get-caller-file@^2.0.5: | ||||
|   resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" | ||||
|   integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== | ||||
|  | ||||
| get-intrinsic@^1.0.2: | ||||
|   version "1.1.1" | ||||
|   resolved "https://registry.yarnpkg.com/get-intrinsic/-/get-intrinsic-1.1.1.tgz#15f59f376f855c446963948f0d24cd3637b4abc6" | ||||
|   integrity sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q== | ||||
|   dependencies: | ||||
|     function-bind "^1.1.1" | ||||
|     has "^1.0.3" | ||||
|     has-symbols "^1.0.1" | ||||
|  | ||||
| get-stream@^6.0.0: | ||||
|   version "6.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" | ||||
| @@ -842,9 +866,9 @@ glob@^7.1.3, glob@^7.1.7: | ||||
|     path-is-absolute "^1.0.0" | ||||
|  | ||||
| graceful-fs@^4.1.2, graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.4, graceful-fs@^4.2.6: | ||||
|   version "4.2.9" | ||||
|   resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.9.tgz#041b05df45755e587a24942279b9d113146e1c96" | ||||
|   integrity sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ== | ||||
|   version "4.2.10" | ||||
|   resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.10.tgz#147d3a006da4ca3ce14728c7aefc287c367d7a6c" | ||||
|   integrity sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA== | ||||
|  | ||||
| growl@1.10.5: | ||||
|   version "1.10.5" | ||||
| @@ -856,6 +880,11 @@ has-flag@^4.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" | ||||
|   integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== | ||||
|  | ||||
| has-symbols@^1.0.1: | ||||
|   version "1.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/has-symbols/-/has-symbols-1.0.3.tgz#bb7b2c4349251dce87b125f7bdf874aa7c8b39f8" | ||||
|   integrity sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A== | ||||
|  | ||||
| has@^1.0.3: | ||||
|   version "1.0.3" | ||||
|   resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796" | ||||
| @@ -868,15 +897,15 @@ he@1.2.0: | ||||
|   resolved "https://registry.yarnpkg.com/he/-/he-1.2.0.tgz#84ae65fa7eafb165fddb61566ae14baf05664f0f" | ||||
|   integrity sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw== | ||||
|  | ||||
| http-errors@1.8.1: | ||||
|   version "1.8.1" | ||||
|   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.8.1.tgz#7c3f28577cbc8a207388455dbd62295ed07bd68c" | ||||
|   integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== | ||||
| http-errors@2.0.0: | ||||
|   version "2.0.0" | ||||
|   resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-2.0.0.tgz#b7774a1486ef73cf7667ac9ae0858c012c57b9d3" | ||||
|   integrity sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ== | ||||
|   dependencies: | ||||
|     depd "~1.1.2" | ||||
|     depd "2.0.0" | ||||
|     inherits "2.0.4" | ||||
|     setprototypeof "1.2.0" | ||||
|     statuses ">= 1.5.0 < 2" | ||||
|     statuses "2.0.1" | ||||
|     toidentifier "1.0.1" | ||||
|  | ||||
| http-proxy@^1.18.1: | ||||
| @@ -941,9 +970,9 @@ is-binary-path@~2.1.0: | ||||
|     binary-extensions "^2.0.0" | ||||
|  | ||||
| is-core-module@^2.8.1: | ||||
|   version "2.8.1" | ||||
|   resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.8.1.tgz#f59fdfca701d5879d0a6b100a40aa1560ce27211" | ||||
|   integrity sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA== | ||||
|   version "2.9.0" | ||||
|   resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.9.0.tgz#e1c34429cd51c6dd9e09e0799e396e27b19a9c69" | ||||
|   integrity sha512-+5FPy5PnwmO3lvfMb0AsoPaBG+5KHUI0wYFXOtYPnVVVspTFUuMZNfNaNVRt3FZadstu2c8x23vykRW/NBoU6A== | ||||
|   dependencies: | ||||
|     has "^1.0.3" | ||||
|  | ||||
| @@ -992,9 +1021,9 @@ is-unicode-supported@^0.1.0: | ||||
|   integrity sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw== | ||||
|  | ||||
| isbinaryfile@^4.0.8: | ||||
|   version "4.0.8" | ||||
|   resolved "https://registry.yarnpkg.com/isbinaryfile/-/isbinaryfile-4.0.8.tgz#5d34b94865bd4946633ecc78a026fc76c5b11fcf" | ||||
|   integrity sha512-53h6XFniq77YdW+spoRrebh0mnmTxRPTlcuIArO57lmMdq4uBKFKaeTjnb92oYWrSn/LVL+LT+Hap2tFQj8V+w== | ||||
|   version "4.0.10" | ||||
|   resolved "https://registry.yarnpkg.com/isbinaryfile/-/isbinaryfile-4.0.10.tgz#0c5b5e30c2557a2f06febd37b7322946aaee42b3" | ||||
|   integrity sha512-iHrqe5shvBUcFbmZq9zOQHBoeOhZJu6RQGrDpBgenUm/Am+F3JM2MgQj+rK3Z601fzrL5gLZWtAPH2OBaSVcyw== | ||||
|  | ||||
| isexe@^2.0.0: | ||||
|   version "2.0.0" | ||||
| @@ -1106,9 +1135,9 @@ kind-of@^6.0.2: | ||||
|   integrity sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw== | ||||
|  | ||||
| loader-runner@^4.2.0: | ||||
|   version "4.2.0" | ||||
|   resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.2.0.tgz#d7022380d66d14c5fb1d496b89864ebcfd478384" | ||||
|   integrity sha512-92+huvxMvYlMzMt0iIOukcwYBFpkYJdpl2xsZ7LrlayO7E8SOv+JJUEK17B/dJIHAOLMfh2dZZ/Y18WgmGtYNw== | ||||
|   version "4.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-4.3.0.tgz#c1b4a163b99f614830353b16755e7149ac2314e1" | ||||
|   integrity sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg== | ||||
|  | ||||
| locate-path@^5.0.0: | ||||
|   version "5.0.0" | ||||
| @@ -1124,6 +1153,11 @@ locate-path@^6.0.0: | ||||
|   dependencies: | ||||
|     p-locate "^5.0.0" | ||||
|  | ||||
| lodash.sortby@^4.7.0: | ||||
|   version "4.7.0" | ||||
|   resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438" | ||||
|   integrity sha1-7dFMgk4sycHgsKG0K7UhBRakJDg= | ||||
|  | ||||
| lodash@^4.17.15, lodash@^4.17.21: | ||||
|   version "4.17.21" | ||||
|   resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" | ||||
| @@ -1138,15 +1172,15 @@ log-symbols@4.1.0: | ||||
|     is-unicode-supported "^0.1.0" | ||||
|  | ||||
| log4js@^6.3.0: | ||||
|   version "6.4.1" | ||||
|   resolved "https://registry.yarnpkg.com/log4js/-/log4js-6.4.1.tgz#9d3a8bf2c31c1e213fe3fc398a6053f7a2bc53e8" | ||||
|   integrity sha512-iUiYnXqAmNKiIZ1XSAitQ4TmNs8CdZYTAWINARF3LjnsLN8tY5m0vRwd6uuWj/yNY0YHxeZodnbmxKFUOM2rMg== | ||||
|   version "6.4.6" | ||||
|   resolved "https://registry.yarnpkg.com/log4js/-/log4js-6.4.6.tgz#1878aa3f09973298ecb441345fe9dd714e355c15" | ||||
|   integrity sha512-1XMtRBZszmVZqPAOOWczH+Q94AI42mtNWjvjA5RduKTSWjEc56uOBbyM1CJnfN4Ym0wSd8cQ43zOojlSHgRDAw== | ||||
|   dependencies: | ||||
|     date-format "^4.0.3" | ||||
|     debug "^4.3.3" | ||||
|     flatted "^3.2.4" | ||||
|     date-format "^4.0.9" | ||||
|     debug "^4.3.4" | ||||
|     flatted "^3.2.5" | ||||
|     rfdc "^1.3.0" | ||||
|     streamroller "^3.0.2" | ||||
|     streamroller "^3.0.8" | ||||
|  | ||||
| media-typer@0.3.0: | ||||
|   version "0.3.0" | ||||
| @@ -1158,17 +1192,17 @@ merge-stream@^2.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" | ||||
|   integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== | ||||
|  | ||||
| mime-db@1.51.0: | ||||
|   version "1.51.0" | ||||
|   resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.51.0.tgz#d9ff62451859b18342d960850dc3cfb77e63fb0c" | ||||
|   integrity sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g== | ||||
| mime-db@1.52.0: | ||||
|   version "1.52.0" | ||||
|   resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" | ||||
|   integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== | ||||
|  | ||||
| mime-types@^2.1.27, mime-types@~2.1.24, mime-types@~2.1.34: | ||||
|   version "2.1.34" | ||||
|   resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.34.tgz#5a712f9ec1503511a945803640fafe09d3793c24" | ||||
|   integrity sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A== | ||||
|   version "2.1.35" | ||||
|   resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" | ||||
|   integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== | ||||
|   dependencies: | ||||
|     mime-db "1.51.0" | ||||
|     mime-db "1.52.0" | ||||
|  | ||||
| mime@^2.5.2: | ||||
|   version "2.6.0" | ||||
| @@ -1195,9 +1229,9 @@ minimatch@^3.0.4: | ||||
|     brace-expansion "^1.1.7" | ||||
|  | ||||
| minimist@^1.2.3: | ||||
|   version "1.2.5" | ||||
|   resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" | ||||
|   integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== | ||||
|   version "1.2.6" | ||||
|   resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.6.tgz#8637a5b759ea0d6e98702cfb3a9283323c93af44" | ||||
|   integrity sha512-Jsjnk4bw3YJqYzbdyBiNsPWHPfO++UGG749Cxs6peCu5Xg4nrena6OVxOYxrQTqww0Jmwt+Ref8rggumkTLz9Q== | ||||
|  | ||||
| mocha@9.1.2: | ||||
|   version "9.1.2" | ||||
| @@ -1259,10 +1293,10 @@ neo-async@^2.6.2: | ||||
|   resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.6.2.tgz#b4aafb93e3aeb2d8174ca53cf163ab7d7308305f" | ||||
|   integrity sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw== | ||||
|  | ||||
| node-releases@^2.0.2: | ||||
|   version "2.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.2.tgz#7139fe71e2f4f11b47d4d2986aaf8c48699e0c01" | ||||
|   integrity sha512-XxYDdcQ6eKqp/YjI+tb2C5WM2LgjnZrfYg4vgQt49EK268b6gYCHsBLrK2qvJo4FmCtqmKezb0WZFK4fkrZNsg== | ||||
| node-releases@^2.0.3: | ||||
|   version "2.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.4.tgz#f38252370c43854dc48aa431c766c6c398f40476" | ||||
|   integrity sha512-gbMzqQtTtDz/00jQzZ21PQzdI9PyLYqUSvD0p3naOhX4odFji0ZxYdnVwPTxmSwkmxhcFImpozceidSG+AgoPQ== | ||||
|  | ||||
| normalize-path@^3.0.0, normalize-path@~3.0.0: | ||||
|   version "3.0.0" | ||||
| @@ -1281,6 +1315,18 @@ object-assign@^4: | ||||
|   resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" | ||||
|   integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= | ||||
|  | ||||
| object-inspect@^1.9.0: | ||||
|   version "1.12.0" | ||||
|   resolved "https://registry.yarnpkg.com/object-inspect/-/object-inspect-1.12.0.tgz#6e2c120e868fd1fd18cb4f18c31741d0d6e776f0" | ||||
|   integrity sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g== | ||||
|  | ||||
| on-finished@2.4.1: | ||||
|   version "2.4.1" | ||||
|   resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.4.1.tgz#58c8c44116e54845ad57f14ab10b03533184ac3f" | ||||
|   integrity sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg== | ||||
|   dependencies: | ||||
|     ee-first "1.1.1" | ||||
|  | ||||
| on-finished@~2.3.0: | ||||
|   version "2.3.0" | ||||
|   resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" | ||||
| @@ -1387,10 +1433,12 @@ qjobs@^1.2.0: | ||||
|   resolved "https://registry.yarnpkg.com/qjobs/-/qjobs-1.2.0.tgz#c45e9c61800bd087ef88d7e256423bdd49e5d071" | ||||
|   integrity sha512-8YOJEHtxpySA3fFDyCRxA+UUV+fA+rTWnuWvylOK/NCjhY+b4ocCtmu8TtsWb+mYeU+GCHf/S66KZF/AsteKHg== | ||||
|  | ||||
| qs@6.9.7: | ||||
|   version "6.9.7" | ||||
|   resolved "https://registry.yarnpkg.com/qs/-/qs-6.9.7.tgz#4610846871485e1e048f44ae3b94033f0e675afe" | ||||
|   integrity sha512-IhMFgUmuNpyRfxA90umL7ByLlgRXu6tIfKPpF5TmcfRLlLCckfP/g3IQmju6jjpu+Hh8rA+2p6A27ZSPOOHdKw== | ||||
| qs@6.10.3: | ||||
|   version "6.10.3" | ||||
|   resolved "https://registry.yarnpkg.com/qs/-/qs-6.10.3.tgz#d6cde1b2ffca87b5aa57889816c5f81535e22e8e" | ||||
|   integrity sha512-wr7M2E0OFRfIfJZjKGieI8lBKb7fRCH4Fv5KNPEs7gJ8jadvotdsS08PzOKR7opXhZ/Xkjtt3WF9g38drmyRqQ== | ||||
|   dependencies: | ||||
|     side-channel "^1.0.4" | ||||
|  | ||||
| randombytes@^2.1.0: | ||||
|   version "2.1.0" | ||||
| @@ -1404,13 +1452,13 @@ range-parser@^1.2.1: | ||||
|   resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" | ||||
|   integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== | ||||
|  | ||||
| raw-body@2.4.3: | ||||
|   version "2.4.3" | ||||
|   resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.3.tgz#8f80305d11c2a0a545c2d9d89d7a0286fcead43c" | ||||
|   integrity sha512-UlTNLIcu0uzb4D2f4WltY6cVjLi+/jEN4lgEUj3E04tpMDpUlkBo/eSn6zou9hum2VMNpCCUone0O0WeJim07g== | ||||
| raw-body@2.5.1: | ||||
|   version "2.5.1" | ||||
|   resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.5.1.tgz#fe1b1628b181b700215e5fd42389f98b71392857" | ||||
|   integrity sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig== | ||||
|   dependencies: | ||||
|     bytes "3.1.2" | ||||
|     http-errors "1.8.1" | ||||
|     http-errors "2.0.0" | ||||
|     iconv-lite "0.4.24" | ||||
|     unpipe "1.0.0" | ||||
|  | ||||
| @@ -1521,6 +1569,15 @@ shebang-regex@^3.0.0: | ||||
|   resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" | ||||
|   integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== | ||||
|  | ||||
| side-channel@^1.0.4: | ||||
|   version "1.0.4" | ||||
|   resolved "https://registry.yarnpkg.com/side-channel/-/side-channel-1.0.4.tgz#efce5c8fdc104ee751b25c58d4290011fa5ea2cf" | ||||
|   integrity sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw== | ||||
|   dependencies: | ||||
|     call-bind "^1.0.0" | ||||
|     get-intrinsic "^1.0.2" | ||||
|     object-inspect "^1.9.0" | ||||
|  | ||||
| signal-exit@^3.0.3: | ||||
|   version "3.0.7" | ||||
|   resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9" | ||||
| @@ -1590,24 +1647,31 @@ source-map@^0.6.0, source-map@^0.6.1: | ||||
|   resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" | ||||
|   integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== | ||||
|  | ||||
| source-map@~0.7.2: | ||||
|   version "0.7.3" | ||||
|   resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.3.tgz#5302f8169031735226544092e64981f751750383" | ||||
|   integrity sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ== | ||||
| source-map@~0.8.0-beta.0: | ||||
|   version "0.8.0-beta.0" | ||||
|   resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.8.0-beta.0.tgz#d4c1bb42c3f7ee925f005927ba10709e0d1d1f11" | ||||
|   integrity sha512-2ymg6oRBpebeZi9UUNsgQ89bhx01TcTkmNTGnNO88imTmbSgy4nfujrgVEFKWpMTEGA11EDkTt7mqObTPdigIA== | ||||
|   dependencies: | ||||
|     whatwg-url "^7.0.0" | ||||
|  | ||||
| "statuses@>= 1.5.0 < 2", statuses@~1.5.0: | ||||
| statuses@2.0.1: | ||||
|   version "2.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/statuses/-/statuses-2.0.1.tgz#55cb000ccf1d48728bd23c685a063998cf1a1b63" | ||||
|   integrity sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ== | ||||
|  | ||||
| statuses@~1.5.0: | ||||
|   version "1.5.0" | ||||
|   resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" | ||||
|   integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= | ||||
|  | ||||
| streamroller@^3.0.2: | ||||
|   version "3.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/streamroller/-/streamroller-3.0.2.tgz#30418d0eee3d6c93ec897f892ed098e3a81e68b7" | ||||
|   integrity sha512-ur6y5S5dopOaRXBuRIZ1u6GC5bcEXHRZKgfBjfCglMhmIf+roVCECjvkEYzNQOXIN2/JPnkMPW/8B3CZoKaEPA== | ||||
| streamroller@^3.0.8: | ||||
|   version "3.0.8" | ||||
|   resolved "https://registry.yarnpkg.com/streamroller/-/streamroller-3.0.8.tgz#84b190e4080ee311ca1ebe0444e30ac8eedd028d" | ||||
|   integrity sha512-VI+ni3czbFZrd1MrlybxykWZ8sMDCMtTU7YJyhgb9M5X6d1DDxLdJr+gSnmRpXPMnIWxWKMaAE8K0WumBp3lDg== | ||||
|   dependencies: | ||||
|     date-format "^4.0.3" | ||||
|     debug "^4.1.1" | ||||
|     fs-extra "^10.0.0" | ||||
|     date-format "^4.0.9" | ||||
|     debug "^4.3.4" | ||||
|     fs-extra "^10.1.0" | ||||
|  | ||||
| string-width@^4.1.0, string-width@^4.2.0: | ||||
|   version "4.2.3" | ||||
| @@ -1671,13 +1735,13 @@ terser-webpack-plugin@^5.1.3: | ||||
|     terser "^5.7.2" | ||||
|  | ||||
| terser@^5.7.2: | ||||
|   version "5.11.0" | ||||
|   resolved "https://registry.yarnpkg.com/terser/-/terser-5.11.0.tgz#2da5506c02e12cd8799947f30ce9c5b760be000f" | ||||
|   integrity sha512-uCA9DLanzzWSsN1UirKwylhhRz3aKPInlfmpGfw8VN6jHsAtu8HJtIpeeHHK23rxnE/cDc+yvmq5wqkIC6Kn0A== | ||||
|   version "5.13.1" | ||||
|   resolved "https://registry.yarnpkg.com/terser/-/terser-5.13.1.tgz#66332cdc5a01b04a224c9fad449fc1a18eaa1799" | ||||
|   integrity sha512-hn4WKOfwnwbYfe48NgrQjqNOH9jzLqRcIfbYytOXCOv46LBfWr9bDS17MQqOi+BWGD0sJK3Sj5NC/gJjiojaoA== | ||||
|   dependencies: | ||||
|     acorn "^8.5.0" | ||||
|     commander "^2.20.0" | ||||
|     source-map "~0.7.2" | ||||
|     source-map "~0.8.0-beta.0" | ||||
|     source-map-support "~0.5.20" | ||||
|  | ||||
| tmp@^0.2.1: | ||||
| @@ -1699,6 +1763,13 @@ toidentifier@1.0.1: | ||||
|   resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" | ||||
|   integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== | ||||
|  | ||||
| tr46@^1.0.1: | ||||
|   version "1.0.1" | ||||
|   resolved "https://registry.yarnpkg.com/tr46/-/tr46-1.0.1.tgz#a8b13fd6bfd2489519674ccde55ba3693b706d09" | ||||
|   integrity sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk= | ||||
|   dependencies: | ||||
|     punycode "^2.1.0" | ||||
|  | ||||
| type-is@~1.6.18: | ||||
|   version "1.6.18" | ||||
|   resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" | ||||
| @@ -1757,6 +1828,11 @@ watchpack@^2.2.0: | ||||
|     glob-to-regexp "^0.4.1" | ||||
|     graceful-fs "^4.1.2" | ||||
|  | ||||
| webidl-conversions@^4.0.2: | ||||
|   version "4.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-4.0.2.tgz#a855980b1f0b6b359ba1d5d9fb39ae941faa63ad" | ||||
|   integrity sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg== | ||||
|  | ||||
| webpack-cli@4.9.0: | ||||
|   version "4.9.0" | ||||
|   resolved "https://registry.yarnpkg.com/webpack-cli/-/webpack-cli-4.9.0.tgz#dc43e6e0f80dd52e89cbf73d5294bcd7ad6eb343" | ||||
| @@ -1826,6 +1902,15 @@ webpack@5.57.1: | ||||
|     watchpack "^2.2.0" | ||||
|     webpack-sources "^3.2.0" | ||||
|  | ||||
| whatwg-url@^7.0.0: | ||||
|   version "7.1.0" | ||||
|   resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-7.1.0.tgz#c2c492f1eca612988efd3d2266be1b9fc6170d06" | ||||
|   integrity sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg== | ||||
|   dependencies: | ||||
|     lodash.sortby "^4.7.0" | ||||
|     tr46 "^1.0.1" | ||||
|     webidl-conversions "^4.0.2" | ||||
|  | ||||
| which@2.0.2, which@^2.0.1: | ||||
|   version "2.0.2" | ||||
|   resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import kotlinx.coroutines.delay | ||||
| import kotlinx.coroutines.isActive | ||||
| import kotlin.coroutines.coroutineContext | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Execute [block] once at the [KronScheduler.next] time and return result of [block] calculation. | ||||
|  * | ||||
| @@ -13,13 +14,23 @@ import kotlin.coroutines.coroutineContext | ||||
|  * | ||||
|  * WARNING!!! In case if [KronScheduler.next] of [this] instance will return null, [block] will be called immediately | ||||
|  */ | ||||
| suspend inline fun <T> KronScheduler.doOnceLocal(noinline block: suspend (DateTime) -> T): T { | ||||
| suspend inline fun <T> KronScheduler.doOnce(noinline block: suspend (DateTime) -> T): T { | ||||
|     val time = nextOrNow().also { | ||||
|         delay((it - DateTime.now()).millisecondsLong) | ||||
|     } | ||||
|     return block(time) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Execute [block] once at the [KronScheduler.next] time and return result of [block] calculation. | ||||
|  * | ||||
|  * WARNING!!! If you want to launch it in parallel, you must do this explicitly. | ||||
|  * | ||||
|  * WARNING!!! In case if [KronScheduler.next] of [this] instance will return null, [block] will be called immediately | ||||
|  */ | ||||
| @Deprecated("Replaceable", ReplaceWith("doOnce", "dev.inmo.krontab.doOnce")) | ||||
| suspend inline fun <T> KronScheduler.doOnceLocal(noinline block: suspend (DateTime) -> T): T = doOnce(block) | ||||
|  | ||||
| /** | ||||
|  * Execute [block] once at the [KronScheduler.next] time and return result of [block] calculation. | ||||
|  * | ||||
| @@ -37,25 +48,16 @@ suspend inline fun <T> KronScheduler.doOnceTz(noinline block: suspend (DateTimeT | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Execute [block] once at the [KronScheduler.next] time and return result of [block] calculation. | ||||
|  * | ||||
|  * WARNING!!! If you want to launch it in parallel, you must do this explicitly. | ||||
|  * | ||||
|  * WARNING!!! In case if [KronScheduler.next] of [this] instance will return null, [block] will be called immediately | ||||
|  */ | ||||
| suspend inline fun <T> KronScheduler.doOnce(noinline block: suspend () -> T): T = doOnceLocal { _ -> block() } | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doOnceLocal] on it | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doOnce] on it | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun <T> doOnce( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTime) -> T | ||||
| ) = buildSchedule(scheduleConfig).doOnceLocal(block) | ||||
| ) = buildSchedule(scheduleConfig).doOnce(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doOnceLocal] on it | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doOnce] on it | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun <T> doOnceTz( | ||||
| @@ -63,24 +65,20 @@ suspend inline fun <T> doOnceTz( | ||||
|     noinline block: suspend (DateTimeTz) -> T | ||||
| ) = buildSchedule(scheduleConfig).doOnceTz(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doOnceLocal] on it | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun <T> doOnce( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend () -> T | ||||
| ) = doOnce(scheduleConfig) { _ -> block() } | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doWhileLocal(noinline block: suspend (DateTime) -> Boolean) { | ||||
| suspend inline fun KronScheduler.doWhile(noinline block: suspend (DateTime) -> Boolean) { | ||||
|     do { | ||||
|         delay(1L) | ||||
|     } while (doOnceLocal(block)) | ||||
|     } while (doOnce(block)) | ||||
| } | ||||
| /** | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
|  */ | ||||
| @Deprecated("Replaceable", ReplaceWith("doWhile", "dev.inmo.krontab.doWhile")) | ||||
| suspend inline fun KronScheduler.doWhileLocal(noinline block: suspend (DateTime) -> Boolean) = doWhile(block) | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
| @@ -92,19 +90,25 @@ suspend inline fun KronScheduler.doWhileTz(noinline block: suspend (DateTimeTz) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] while it will return true as a result of its calculation | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doWhile] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doWhile(noinline block: suspend () -> Boolean) = doWhileLocal { block() } | ||||
| suspend inline fun doWhile( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTime) -> Boolean | ||||
| ) = buildSchedule(scheduleConfig).doWhile(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doWhile] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| @Deprecated("Replaceable", ReplaceWith("doWhile", "dev.inmo.krontab.doWhile")) | ||||
| suspend inline fun doWhileLocal( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTime) -> Boolean | ||||
| ) = buildSchedule(scheduleConfig).doWhileLocal(block) | ||||
| ) = doWhile(scheduleConfig, block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doWhile] with [block] | ||||
| @@ -116,24 +120,19 @@ suspend inline fun doWhileTz( | ||||
|     noinline block: suspend (DateTimeTz) -> Boolean | ||||
| ) = buildSchedule(scheduleConfig).doWhileTz(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doWhile] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun doWhile( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend () -> Boolean | ||||
| ) = doWhileLocal(scheduleConfig) { block() } | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] without any checking of result | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doInfinityLocal(noinline block: suspend (DateTime) -> Unit) = doWhileLocal { | ||||
| suspend inline fun KronScheduler.doInfinity(noinline block: suspend (DateTime) -> Unit) = doWhile { | ||||
|     block(it) | ||||
|     coroutineContext.isActive | ||||
| } | ||||
| /** | ||||
|  * Will execute [block] without any checking of result | ||||
|  */ | ||||
| @Deprecated("Replaceable", ReplaceWith("doInfinity", "dev.inmo.krontab.doInfinity")) | ||||
| suspend inline fun KronScheduler.doInfinityLocal(noinline block: suspend (DateTime) -> Unit) = doInfinity(block) | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] without any checking of result | ||||
| @@ -144,22 +143,25 @@ suspend inline fun KronScheduler.doInfinityTz(noinline block: suspend (DateTimeT | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Will execute [block] without any checking of result | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doInfinity] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun KronScheduler.doInfinity(noinline block: suspend () -> Unit) = doWhile { | ||||
|     block() | ||||
|     coroutineContext.isActive | ||||
| } | ||||
| suspend inline fun doInfinity( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTime) -> Unit | ||||
| ) = buildSchedule(scheduleConfig).doInfinity(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doInfinity] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| @Deprecated("Replaceable", ReplaceWith("doInfinity", "dev.inmo.krontab.doInfinity")) | ||||
| suspend inline fun doInfinityLocal( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTime) -> Unit | ||||
| ) = buildSchedule(scheduleConfig).doInfinityLocal(block) | ||||
| ) = doInfinity(scheduleConfig, block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doInfinity] with [block] | ||||
| @@ -170,13 +172,3 @@ suspend inline fun doInfinityTz( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend (DateTimeTz) -> Unit | ||||
| ) = buildSchedule(scheduleConfig).doInfinityTz(block) | ||||
|  | ||||
| /** | ||||
|  * Will [buildSchedule] using [scheduleConfig] and call [doInfinity] with [block] | ||||
|  * | ||||
|  * @see buildSchedule | ||||
|  */ | ||||
| suspend inline fun doInfinity( | ||||
|     scheduleConfig: String, | ||||
|     noinline block: suspend () -> Unit | ||||
| ) = buildSchedule(scheduleConfig).doInfinity(block) | ||||
|   | ||||
| @@ -16,6 +16,13 @@ val AnyTimeScheduler: KronScheduler by lazy { | ||||
|     CronDateTimeScheduler(anyCronDateTime) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * [KronScheduler.next] will always return [com.soywiz.klock.DateTime.now] + one millisecond | ||||
|  */ | ||||
| val EveryMillisecondScheduler: KronScheduler by lazy { | ||||
|     buildSchedule { milliseconds { 0 every 1 } } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * [KronScheduler.next] will always return [com.soywiz.klock.DateTime.now] + one second | ||||
|  */ | ||||
|   | ||||
| @@ -14,14 +14,15 @@ typealias KrontabTemplate = String | ||||
| /** | ||||
|  * Parse [incoming] string and adapt according to next format: "* * * * *" where order of things: | ||||
|  * | ||||
|  * * seconds | ||||
|  * * minutes | ||||
|  * * hours | ||||
|  * * dayOfMonth | ||||
|  * * month | ||||
|  * * (optional) year | ||||
|  * * (optional) (can be placed anywhere after month) (must be marked with `o` at the end, for example: 60o == +01:00) offset | ||||
|  * * (optional) (can be placed anywhere after month) dayOfWeek | ||||
|  * * **seconds** | ||||
|  * * **minutes** | ||||
|  * * **hours** | ||||
|  * * **dayOfMonth** | ||||
|  * * **month** | ||||
|  * * **year** (optional) | ||||
|  * * **offset** (optional) (can be placed anywhere after month) (must be marked with `o` at the end, for example: 60o == +01:00) | ||||
|  * * **dayOfWeek** (optional) (can be placed anywhere after month) | ||||
|  * * **milliseconds** (optional) (can be placed anywhere after month) (must be marked with `ms` at the end, for example: 500ms; 100-200ms) | ||||
|  * | ||||
|  * And each one (except of offsets) have next format: | ||||
|  * | ||||
| @@ -48,18 +49,21 @@ typealias KrontabTemplate = String | ||||
|  * * Months ranges can be found in [monthRange] | ||||
|  * * Years ranges can be found in [yearRange] (in fact - any [Int]) | ||||
|  * * WeekDay (timezone) ranges can be found in [dayOfWeekRange] | ||||
|  * * Milliseconds ranges can be found in [millisecondsRange] | ||||
|  * | ||||
|  * Examples: | ||||
|  * | ||||
|  * * "0/5 * * * *" for every five seconds triggering | ||||
|  * * "0/5,L * * * *" for every five seconds triggering and on 59 second | ||||
|  * * "0/15 30 * * *" for every 15th seconds in a half of each hour | ||||
|  * * "0/15 30 * * * 500ms" for every 15th seconds in a half of each hour when milliseconds equal to 500 | ||||
|  * * "1 2 3 F,4,L 5" for triggering in near first second of second minute of third hour of fourth day of may | ||||
|  * * "1 2 3 F,4,L 5 60o" for triggering in near first second of second minute of third hour of fourth day of may with timezone UTC+01:00 | ||||
|  * * "1 2 3 F,4,L 5 60o 0-2w" for triggering in near first second of second minute of third hour of fourth day of may in case if it will be in Sunday-Tuesday week days with timezone UTC+01:00 | ||||
|  * * "1 2 3 F,4,L 5 2021" for triggering in near first second of second minute of third hour of fourth day of may of 2021st year | ||||
|  * * "1 2 3 F,4,L 5 2021 60o" for triggering in near first second of second minute of third hour of fourth day of may of 2021st year with timezone UTC+01:00 | ||||
|  * * "1 2 3 F,4,L 5 2021 60o 0-2w" for triggering in near first second of second minute of third hour of fourth day of may of 2021st year if it will be in Sunday-Tuesday week days with timezone UTC+01:00 | ||||
|  * * "1 2 3 F,4,L 5 2021 60o 0-2w 500ms" for triggering in near first second of second minute of third hour of fourth day of may of 2021st year if it will be in Sunday-Tuesday week days with timezone UTC+01:00 when milliseconds will be equal to 500 | ||||
|  * | ||||
|  * @return In case when offset parameter is absent in [incoming] will be used [createSimpleScheduler] method and | ||||
|  * returned [CronDateTimeScheduler]. In case when offset parameter there is in [incoming] [KrontabTemplate] will be used | ||||
| @@ -73,18 +77,22 @@ fun createSimpleScheduler( | ||||
|     var offsetParsed: Int? = null | ||||
|     var dayOfWeekParsed: Array<Byte>? = null | ||||
|     var yearParsed: Array<Int>? = null | ||||
|     var millisecondsParsed: Array<Short>? = null | ||||
|     val (secondsSource, minutesSource, hoursSource, dayOfMonthSource, monthSource) = incoming.split(" ").also { | ||||
|         listOfNotNull( | ||||
|             it.getOrNull(5), | ||||
|             it.getOrNull(6), | ||||
|             it.getOrNull(7) | ||||
|             it.getOrNull(7), | ||||
|             it.getOrNull(8) | ||||
|         ).forEach { | ||||
|             val offsetFromString = parseOffset(it) | ||||
|             val dayOfWeekFromString = parseWeekDay(it) | ||||
|             val millisecondsFromString = parseMilliseconds(it) | ||||
|             offsetParsed = offsetParsed ?: offsetFromString | ||||
|             dayOfWeekParsed = dayOfWeekParsed ?: dayOfWeekFromString | ||||
|             millisecondsParsed = millisecondsParsed ?: millisecondsFromString | ||||
|             when { | ||||
|                 dayOfWeekFromString != null || offsetFromString != null -> return@forEach | ||||
|                 dayOfWeekFromString != null || offsetFromString != null || millisecondsFromString != null -> return@forEach | ||||
|                 yearParsed == null -> { | ||||
|                     yearParsed = parseYears(it) | ||||
|                 } | ||||
| @@ -100,10 +108,25 @@ fun createSimpleScheduler( | ||||
|  | ||||
|     return offsetParsed ?.let { offset -> | ||||
|         createKronSchedulerWithOffset( | ||||
|             secondsParsed, minutesParsed, hoursParsed, dayOfMonthParsed, monthParsed, yearParsed, dayOfWeekParsed, TimezoneOffset(offset.minutes) | ||||
|             secondsParsed, | ||||
|             minutesParsed, | ||||
|             hoursParsed, | ||||
|             dayOfMonthParsed, | ||||
|             monthParsed, | ||||
|             yearParsed, | ||||
|             dayOfWeekParsed, | ||||
|             TimezoneOffset(offset.minutes), | ||||
|             millisecondsParsed ?: millisecondsArrayDefault | ||||
|         ) | ||||
|     } ?: createKronScheduler( | ||||
|         secondsParsed, minutesParsed, hoursParsed, dayOfMonthParsed, monthParsed, yearParsed, dayOfWeekParsed | ||||
|         secondsParsed, | ||||
|         minutesParsed, | ||||
|         hoursParsed, | ||||
|         dayOfMonthParsed, | ||||
|         monthParsed, | ||||
|         yearParsed, | ||||
|         dayOfWeekParsed, | ||||
|         millisecondsParsed ?: millisecondsArrayDefault | ||||
|     ) | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import com.soywiz.klock.TimezoneOffset | ||||
| import com.soywiz.klock.minutes | ||||
| import dev.inmo.krontab.KronScheduler | ||||
| import dev.inmo.krontab.KronSchedulerTz | ||||
| import dev.inmo.krontab.internal.* | ||||
| import dev.inmo.krontab.internal.createKronScheduler | ||||
| import dev.inmo.krontab.internal.createKronSchedulerWithOffset | ||||
| import dev.inmo.krontab.utils.Minutes | ||||
| @@ -45,7 +46,8 @@ class SchedulerBuilder( | ||||
|     private var month: Array<Byte>? = null, | ||||
|     private var year: Array<Int>? = null, | ||||
|     private var dayOfWeek: Array<Byte>? = null, | ||||
|     private val offset: Minutes? = null | ||||
|     private val offset: Minutes? = null, | ||||
|     private var milliseconds: Array<Short>? = null | ||||
| ) { | ||||
|     private fun <I, T : TimeBuilder<I>> callAndReturn( | ||||
|         initial: Array<I>?, | ||||
| @@ -63,6 +65,17 @@ class SchedulerBuilder( | ||||
|         } ?: builderValue | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Starts an milliseconds block | ||||
|      */ | ||||
|     fun milliseconds(block: MillisecondsBuilder.() -> Unit) { | ||||
|         milliseconds = callAndReturn( | ||||
|             milliseconds, | ||||
|             MillisecondsBuilder(), | ||||
|             block | ||||
|         ) ?.toTypedArray() | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Starts an seconds block | ||||
|      */ | ||||
| @@ -147,6 +160,16 @@ class SchedulerBuilder( | ||||
|      * @see dev.inmo.krontab.internal.createKronScheduler | ||||
|      */ | ||||
|     fun build(): KronScheduler = offset ?.let { | ||||
|         createKronSchedulerWithOffset(seconds, minutes, hours, dayOfMonth, month, year, dayOfWeek, TimezoneOffset(it.minutes)) | ||||
|     } ?: createKronScheduler(seconds, minutes, hours, dayOfMonth, month, year, dayOfWeek) | ||||
|         createKronSchedulerWithOffset( | ||||
|             seconds, | ||||
|             minutes, | ||||
|             hours, | ||||
|             dayOfMonth, | ||||
|             month, | ||||
|             year, | ||||
|             dayOfWeek, | ||||
|             TimezoneOffset(it.minutes), | ||||
|             milliseconds ?: millisecondsArrayDefault | ||||
|         ) | ||||
|     } ?: createKronScheduler(seconds, minutes, hours, dayOfMonth, month, year, dayOfWeek, milliseconds ?: millisecondsArrayDefault) | ||||
| } | ||||
|   | ||||
| @@ -122,6 +122,7 @@ sealed class TimeBuilder<T : Number> ( | ||||
|     internal fun build() = result ?.map(converter) | ||||
| } | ||||
|  | ||||
| class MillisecondsBuilder : TimeBuilder<Short>(millisecondsRange, intToShortConverter) | ||||
| class SecondsBuilder : TimeBuilder<Byte>(secondsRange, intToByteConverter) | ||||
| class MinutesBuilder : TimeBuilder<Byte>(minutesRange, intToByteConverter) | ||||
| class HoursBuilder : TimeBuilder<Byte>(hoursRange, intToByteConverter) | ||||
|   | ||||
| @@ -20,7 +20,8 @@ internal data class CronDateTime( | ||||
|     val daysOfMonth: Array<Byte>? = null, | ||||
|     val hours: Array<Byte>? = null, | ||||
|     val minutes: Array<Byte>? = null, | ||||
|     val seconds: Array<Byte>? = null | ||||
|     val seconds: Array<Byte>? = null, | ||||
|     val milliseconds: Array<Short>? = millisecondsArrayDefault | ||||
| ) { | ||||
|     init { | ||||
|         check(daysOfWeek ?.all { it in dayOfWeekRange } ?: true) | ||||
| @@ -30,12 +31,13 @@ internal data class CronDateTime( | ||||
|         check(hours?.all { it in hoursRange } ?: true) | ||||
|         check(minutes?.all { it in minutesRange } ?: true) | ||||
|         check(seconds?.all { it in secondsRange } ?: true) | ||||
|         check(milliseconds?.all { it in millisecondsRange } ?: true) | ||||
|     } | ||||
|  | ||||
|     internal val calculators = listOf( | ||||
|         years ?.let { NearDateTimeCalculatorYears(it) }, | ||||
|         daysOfWeek ?.let { NearDateTimeCalculatorWeekDays(it) }, | ||||
|         NearDateTimeCalculatorMillis(arrayOf(0)), | ||||
|         milliseconds ?.let { NearDateTimeCalculatorMillis(it) }, | ||||
|         seconds ?.let { NearDateTimeCalculatorSeconds(it) }, | ||||
|         minutes ?.let { NearDateTimeCalculatorMinutes(it) }, | ||||
|         hours ?.let { NearDateTimeCalculatorHours(it) }, | ||||
| @@ -65,9 +67,10 @@ internal fun createCronDateTime( | ||||
|     dayOfMonth: Array<Byte>? = null, | ||||
|     month: Array<Byte>? = null, | ||||
|     years: Array<Int>? = null, | ||||
|     weekDays: Array<Byte>? = null | ||||
|     weekDays: Array<Byte>? = null, | ||||
|     milliseconds: Array<Short>? = millisecondsArrayDefault | ||||
| ): CronDateTime { | ||||
|     return CronDateTime(weekDays, years, month, dayOfMonth, hours, minutes, seconds) | ||||
|     return CronDateTime(weekDays, years, month, dayOfMonth, hours, minutes, seconds, milliseconds) | ||||
| } | ||||
|  | ||||
| /** | ||||
| @@ -80,8 +83,20 @@ internal fun createKronScheduler( | ||||
|     dayOfMonth: Array<Byte>? = null, | ||||
|     month: Array<Byte>? = null, | ||||
|     years: Array<Int>? = null, | ||||
|     weekDays: Array<Byte>? = null | ||||
| ): KronScheduler = CronDateTimeScheduler(createCronDateTime(seconds, minutes, hours, dayOfMonth, month, years, weekDays)) | ||||
|     weekDays: Array<Byte>? = null, | ||||
|     milliseconds: Array<Short>? = millisecondsArrayDefault | ||||
| ): KronScheduler = CronDateTimeScheduler( | ||||
|     createCronDateTime( | ||||
|         seconds, | ||||
|         minutes, | ||||
|         hours, | ||||
|         dayOfMonth, | ||||
|         month, | ||||
|         years, | ||||
|         weekDays, | ||||
|         milliseconds | ||||
|     ) | ||||
| ) | ||||
| /** | ||||
|  * @return [KronScheduler] (in fact [CronDateTimeScheduler]) based on incoming data | ||||
|  */ | ||||
| @@ -93,8 +108,21 @@ internal fun createKronSchedulerWithOffset( | ||||
|     month: Array<Byte>? = null, | ||||
|     years: Array<Int>? = null, | ||||
|     weekDays: Array<Byte>? = null, | ||||
|     offset: TimezoneOffset | ||||
| ): KronScheduler = CronDateTimeSchedulerTz(createCronDateTime(seconds, minutes, hours, dayOfMonth, month, years, weekDays), offset) | ||||
|     offset: TimezoneOffset, | ||||
|     milliseconds: Array<Short>? = millisecondsArrayDefault | ||||
| ): KronScheduler = CronDateTimeSchedulerTz( | ||||
|     createCronDateTime( | ||||
|         seconds, | ||||
|         minutes, | ||||
|         hours, | ||||
|         dayOfMonth, | ||||
|         month, | ||||
|         years, | ||||
|         weekDays, | ||||
|         milliseconds | ||||
|     ), | ||||
|     offset | ||||
| ) | ||||
|  | ||||
| internal fun List<CronDateTime>.merge() = CronDateTime( | ||||
|     flatMap { it.daysOfWeek ?.toList() ?: emptyList() }.distinct().toTypedArray().takeIf { it.isNotEmpty() }, | ||||
| @@ -104,4 +132,5 @@ internal fun List<CronDateTime>.merge() = CronDateTime( | ||||
|     flatMap { it.hours ?.toList() ?: emptyList() }.distinct().toTypedArray().takeIf { it.isNotEmpty() }, | ||||
|     flatMap { it.minutes ?.toList() ?: emptyList() }.distinct().toTypedArray().takeIf { it.isNotEmpty() }, | ||||
|     flatMap { it.seconds ?.toList() ?: emptyList() }.distinct().toTypedArray().takeIf { it.isNotEmpty() }, | ||||
|     flatMap { it.milliseconds ?.toList() ?: listOf(0) }.distinct().toTypedArray().takeIf { it.isNotEmpty() }, | ||||
| ) | ||||
|   | ||||
| @@ -7,6 +7,7 @@ import dev.inmo.krontab.KronScheduler | ||||
|  * Cron-oriented realisation of [KronScheduler] | ||||
|  * | ||||
|  * @see dev.inmo.krontab.AnyTimeScheduler | ||||
|  * @see dev.inmo.krontab.EveryMillisecondScheduler | ||||
|  * @see dev.inmo.krontab.EverySecondScheduler | ||||
|  * @see dev.inmo.krontab.EveryMinuteScheduler | ||||
|  * @see dev.inmo.krontab.EveryHourScheduler | ||||
|   | ||||
| @@ -0,0 +1,4 @@ | ||||
| package dev.inmo.krontab.internal | ||||
|  | ||||
| internal const val millisecondsDefault: Short = 0 | ||||
| internal val millisecondsArrayDefault: Array<Short> = arrayOf(millisecondsDefault) | ||||
| @@ -3,6 +3,7 @@ package dev.inmo.krontab.internal | ||||
| typealias Converter<T> = (Int) -> T | ||||
|  | ||||
| internal val intToByteConverter: Converter<Byte> = { it: Int -> it.toByte() } | ||||
| internal val intToShortConverter: Converter<Short> = { it: Int -> it.toShort() } | ||||
| internal val intToIntConverter: Converter<Int> = { it: Int -> it } | ||||
| private fun <T> createSimpleScheduler(from: String, dataRange: IntRange, dataConverter: Converter<T>): List<T>? { | ||||
|     val things = from.split(",") | ||||
| @@ -44,6 +45,7 @@ internal fun parseDaysOfMonth(from: String) = createSimpleScheduler(from, dayOfM | ||||
| internal fun parseHours(from: String) = createSimpleScheduler(from, hoursRange, intToByteConverter) ?.toTypedArray() | ||||
| internal fun parseMinutes(from: String) = createSimpleScheduler(from, minutesRange, intToByteConverter) ?.toTypedArray() | ||||
| internal fun parseSeconds(from: String) = createSimpleScheduler(from, secondsRange, intToByteConverter) ?.toTypedArray() | ||||
| internal fun parseMilliseconds(from: String?) = from ?.let { if (it.endsWith("ms")) createSimpleScheduler(from.removeSuffix("ms"), millisecondsRange, intToShortConverter) ?.toTypedArray() else null } | ||||
|  | ||||
| internal fun <T> Array<T>.fillWith( | ||||
|     whereToPut: MutableList<CronDateTime>, | ||||
|   | ||||
| @@ -7,3 +7,4 @@ internal val dayOfMonthRange = 0 .. 30 | ||||
| internal val hoursRange = 0 .. 23 | ||||
| internal val minutesRange = 0 .. 59 | ||||
| internal val secondsRange = minutesRange | ||||
| internal val millisecondsRange = 0 .. 999 | ||||
|   | ||||
| @@ -6,6 +6,7 @@ import dev.inmo.krontab.* | ||||
| import kotlinx.coroutines.FlowPreview | ||||
| import kotlinx.coroutines.flow.Flow | ||||
| import kotlinx.coroutines.flow.channelFlow | ||||
| import kotlinx.coroutines.isActive | ||||
|  | ||||
| /** | ||||
|  * This [Flow] will trigger emitting each near time which will be returned from [this] [KronScheduler] with attention to | ||||
| @@ -25,11 +26,11 @@ fun KronScheduler.asTzFlow(): Flow<DateTimeTz> = channelFlow { | ||||
|  * This method is a map for [asTzFlow] and will works the same but return flow with [DateTime]s | ||||
|  * | ||||
|  * @see channelFlow | ||||
|  * @see KronScheduler.doInfinityLocal | ||||
|  * @see KronScheduler.doInfinity | ||||
|  */ | ||||
| @FlowPreview | ||||
| fun KronScheduler.asFlow(): Flow<DateTime> = channelFlow { | ||||
|     doInfinityLocal { | ||||
|     doInfinity { | ||||
|         send(it) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -0,0 +1,34 @@ | ||||
| package dev.inmo.krontab.utils.flows | ||||
|  | ||||
| import com.soywiz.klock.* | ||||
| import kotlinx.coroutines.flow.Flow | ||||
| import kotlinx.coroutines.flow.filter | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterSeconds(vararg seconds: Int) = filter { it.seconds in seconds } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterMinutes(vararg minutes: Int) = filter { it.minutes in minutes } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterHours(vararg hours: Int) = filter { it.hours in hours } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterDaysOfMonths(vararg daysOfMonths: Int) = filter { it.dayOfMonth in daysOfMonths } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterMonths(vararg months: Month) = filter { it.month in months } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterMonths0(vararg months: Int) = filter { it.month0 in months } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterMonths1(vararg months: Int) = filter { it.month1 in months } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterYears(year: Year) = filter { it.year == year } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterYears(vararg years: Int) = filter { it.yearInt in years } | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterWeekDays(vararg weekDays: DayOfWeek) = filter { it.dayOfWeek in weekDays } | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.filterWeekDays(vararg weekDays: Int) = filter { it.dayOfWeekInt in weekDays } | ||||
							
								
								
									
										25
									
								
								src/commonMain/kotlin/dev/inmo/krontab/utils/flows/When.kt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								src/commonMain/kotlin/dev/inmo/krontab/utils/flows/When.kt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| package dev.inmo.krontab.utils.flows | ||||
|  | ||||
| import com.soywiz.klock.* | ||||
| import kotlinx.coroutines.flow.Flow | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfMinutes() = filterSeconds(0) | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfHours() = filterMinutes(0).onlyStartsOfMinutes() | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfDays() = filterHours(0).onlyStartsOfHours() | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfMondays() = filterWeekDays(DayOfWeek.Monday).onlyStartsOfDays() | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfSundays() = filterWeekDays(DayOfWeek.Sunday).onlyStartsOfDays() | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfMonths() = filterDaysOfMonths(1).onlyStartsOfDays() | ||||
|  | ||||
| @Suppress("NOTHING_TO_INLINE") | ||||
| inline fun Flow<DateTime>.onlyStartsOfYears() = filterMonths(Month.January).onlyStartsOfMonths() | ||||
| @@ -6,8 +6,8 @@ import dev.inmo.krontab.buildSchedule | ||||
| import kotlinx.coroutines.* | ||||
| import kotlinx.coroutines.flow.collect | ||||
| import kotlinx.coroutines.flow.takeWhile | ||||
| import kotlin.test.Test | ||||
| import kotlin.test.assertEquals | ||||
| import kotlin.math.floor | ||||
| import kotlin.test.* | ||||
|  | ||||
| @ExperimentalCoroutinesApi | ||||
| @FlowPreview | ||||
| @@ -29,6 +29,23 @@ class StringParseTest { | ||||
|             assertEquals(mustBeCollected, collected) | ||||
|         } | ||||
|     } | ||||
|     @Test | ||||
|     fun testThatFlowIsCorrectlyWorkEverySecondWhenMillisIsHalfOfSecondBuiltOnString() { | ||||
|         val kronScheduler = buildSchedule("*/1 * * * * 500ms") | ||||
|  | ||||
|         val flow = kronScheduler.asFlow() | ||||
|  | ||||
|         runTest { | ||||
|             val mustBeCollected = 10 | ||||
|             var collected = 0 | ||||
|             flow.takeWhile { | ||||
|                 collected < mustBeCollected | ||||
|             }.collect { | ||||
|                 collected++ | ||||
|             } | ||||
|             assertEquals(mustBeCollected, collected) | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @Test | ||||
|     fun testThatFlowIsCorrectlyWorkEverySecondWithMuchOfEmittersBuiltOnString() { | ||||
| @@ -74,6 +91,29 @@ class StringParseTest { | ||||
|             flow.takeWhile { ranges.isNotEmpty() }.collect { | ||||
|                 ranges.remove(it.seconds) | ||||
|                 collected++ | ||||
|                 assertTrue(collected <= expectedCollects) | ||||
|             } | ||||
|             assertEquals(expectedCollects, collected) | ||||
|         } | ||||
|     } | ||||
|     @Test | ||||
|     fun testNextIsCorrectlyWorkEverySeveralMillisecondsRangeBuiltOnString() { | ||||
|         val rangesEnds = listOf(0, 200, 500, 750) | ||||
|         val kronScheduler = buildSchedule("* * * * * ${rangesEnds.joinToString(",") { "$it" }}ms") | ||||
|  | ||||
|         runTest { | ||||
|             val ranges = rangesEnds.toMutableList() | ||||
|             val expectedCollects = ranges.size | ||||
|             var collected = 0 | ||||
|  | ||||
|             var currentTime = DateTime.now() | ||||
|             while (ranges.isNotEmpty()) { | ||||
|                 val nextTrigger = kronScheduler.next(currentTime) ?: error("Strangely unable to get next time") | ||||
|  | ||||
|                 ranges.remove(nextTrigger.milliseconds) | ||||
|                 collected++ | ||||
|  | ||||
|                 currentTime = nextTrigger + 1.milliseconds | ||||
|             } | ||||
|             assertEquals(expectedCollects, collected) | ||||
|         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user