mirror of
https://github.com/janet-lang/janet
synced 2025-01-18 19:32:50 +00:00
Merge branch 'master' of github.com:janet-lang/janet
This commit is contained in:
commit
dd2595c53f
src
@ -533,23 +533,16 @@
|
|||||||
|
|
||||||
* :iterate -- repeatedly evaluate and bind to the expression while it is
|
* :iterate -- repeatedly evaluate and bind to the expression while it is
|
||||||
truthy.
|
truthy.
|
||||||
|
|
||||||
* :range -- loop over a range. The object should be a two-element tuple with
|
* :range -- loop over a range. The object should be a two-element tuple with
|
||||||
a start and end value, and an optional positive step. The range is half
|
a start and end value, and an optional positive step. The range is half
|
||||||
open, [start, end).
|
open, [start, end).
|
||||||
|
|
||||||
* :range-to -- same as :range, but the range is inclusive [start, end].
|
* :range-to -- same as :range, but the range is inclusive [start, end].
|
||||||
|
|
||||||
* :down -- loop over a range, stepping downwards. The object should be a
|
* :down -- loop over a range, stepping downwards. The object should be a
|
||||||
two-element tuple with a start and (exclusive) end value, and an optional
|
two-element tuple with a start and (exclusive) end value, and an optional
|
||||||
(positive!) step size.
|
(positive!) step size.
|
||||||
|
|
||||||
* :down-to -- same as :down, but the range is inclusive [start, end].
|
* :down-to -- same as :down, but the range is inclusive [start, end].
|
||||||
|
|
||||||
* :keys -- iterate over the keys in a data structure.
|
* :keys -- iterate over the keys in a data structure.
|
||||||
|
|
||||||
* :pairs -- iterate over the key-value pairs as tuples in a data structure.
|
* :pairs -- iterate over the key-value pairs as tuples in a data structure.
|
||||||
|
|
||||||
* :in -- iterate over the values in a data structure or fiber.
|
* :in -- iterate over the values in a data structure or fiber.
|
||||||
|
|
||||||
`loop` also accepts conditionals to refine the looping further. Conditionals are of
|
`loop` also accepts conditionals to refine the looping further. Conditionals are of
|
||||||
@ -560,13 +553,13 @@
|
|||||||
where `:modifier` is one of a set of keywords, and `argument` is keyword-dependent.
|
where `:modifier` is one of a set of keywords, and `argument` is keyword-dependent.
|
||||||
`:modifier` can be one of:
|
`:modifier` can be one of:
|
||||||
|
|
||||||
* `:while expression` - breaks from the loop if `expression` is falsey.
|
* `:while expression` - breaks from the loop if `expression` is falsey.
|
||||||
* `:until expression` - breaks from the loop if `expression` is truthy.
|
* `:until expression` - breaks from the loop if `expression` is truthy.
|
||||||
* `:let bindings` - defines bindings inside the loop as passed to the `let` macro.
|
* `:let bindings` - defines bindings inside the loop as passed to the `let` macro.
|
||||||
* `:before form` - evaluates a form for a side effect before the next inner loop.
|
* `:before form` - evaluates a form for a side effect before the next inner loop.
|
||||||
* `:after form` - same as `:before`, but the side effect happens after the next inner loop.
|
* `:after form` - same as `:before`, but the side effect happens after the next inner loop.
|
||||||
* `:repeat n` - repeats the next inner loop `n` times.
|
* `:repeat n` - repeats the next inner loop `n` times.
|
||||||
* `:when condition` - only evaluates the loop body when condition is true.
|
* `:when condition` - only evaluates the loop body when condition is true.
|
||||||
|
|
||||||
The `loop` macro always evaluates to nil.
|
The `loop` macro always evaluates to nil.
|
||||||
```
|
```
|
||||||
|
@ -599,7 +599,7 @@ static const JanetReg string_cfuns[] = {
|
|||||||
JDOC("(string/find-all patt str)\n\n"
|
JDOC("(string/find-all patt str)\n\n"
|
||||||
"Searches for all instances of pattern patt in string "
|
"Searches for all instances of pattern patt in string "
|
||||||
"str. Returns an array of all indices of found patterns. Overlapping "
|
"str. Returns an array of all indices of found patterns. Overlapping "
|
||||||
"instances of the pattern are counted individual, meaning a byte in string "
|
"instances of the pattern are counted individually, meaning a byte in str "
|
||||||
"may contribute to multiple found patterns.")
|
"may contribute to multiple found patterns.")
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -720,10 +720,10 @@ static const JanetReg threadlib_cfuns[] = {
|
|||||||
"Start a new thread that will start immediately. "
|
"Start a new thread that will start immediately. "
|
||||||
"If capacity is provided, that is how many messages can be stored in the thread's mailbox before blocking senders. "
|
"If capacity is provided, that is how many messages can be stored in the thread's mailbox before blocking senders. "
|
||||||
"The capacity must be between 1 and 65535 inclusive, and defaults to 10. "
|
"The capacity must be between 1 and 65535 inclusive, and defaults to 10. "
|
||||||
"Can optionally provide flags to the new thread - supported flags are:\n"
|
"Can optionally provide flags to the new thread - supported flags are:\n\n"
|
||||||
"\t:h - Start a heavyweight thread. This loads the core environment by default, so may use more memory initially. Messages may compress better, though.\n"
|
"* :h - Start a heavyweight thread. This loads the core environment by default, so may use more memory initially. Messages may compress better, though.\n\n"
|
||||||
"\t:a - Allow sending over registered abstract types to the new thread\n"
|
"* :a - Allow sending over registered abstract types to the new thread\n\n"
|
||||||
"\t:c - Send over cfunction information to the new thread.\n"
|
"* :c - Send over cfunction information to the new thread.\n\n"
|
||||||
"Returns a handle to the new thread.")
|
"Returns a handle to the new thread.")
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user