1
0
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:
Calvin Rose 2021-01-06 17:27:50 -06:00
commit dd2595c53f
3 changed files with 12 additions and 19 deletions

View File

@ -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.
``` ```

View File

@ -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.")
}, },
{ {

View File

@ -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.")
}, },
{ {