Skip to content

Commit

Permalink
README.md: add more explanation of the Collector methods
Browse files Browse the repository at this point in the history
  • Loading branch information
creachadair committed Sep 12, 2024
1 parent 56ad314 commit 7acdc74
Showing 1 changed file with 25 additions and 8 deletions.
33 changes: 25 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -317,26 +317,43 @@ c := taskgroup.Collect(func(v int) { sum += v })
```

The `Call`, `Run`, and `Report` methods of `c` wrap a function that yields a
value into a task. If the function reports an error, that error is returned
from the task as usual. Otherwise, its non-error value is given to the
accumulator callback. As in the above example, calls to the function are
serialized so that it is safe to access state without additional locking:
value into a task:

- `Call` takes a `func() (T, error)`, returning a value and an error.
- `Run` takes a `func() T`, returning only a value.

If the function reports an error, that error is returned from the task as
usual. Otherwise, its non-error value is given to the accumulator callback. As
in the above example, calls to the function are serialized so that it is safe
to access state without additional locking:

```go
// Report an error, no value for the collector.
var g taskgroup.Group
// ...

// Report an error, no value is sent to the collector.
g.Go(c.Call(func() (int, error) {
return -1, errors.New("bad")
}))

// Report the value 25 to the collector.
// No error, send the value 25 to the collector.
g.Go(c.Call(func() (int, error) {
return 25, nil
}))

// Report a random integer to the collector.
// Send a random integer to the collector.
g.Go(c.Run(func() int { return rand.Intn(1000) })
```

The `Report` method allows a task to report _multiple_ values to the collector
via a callback. Here, the function returns only an `error`, but it receives a
callback it may invoke any number of times to send values:

// Report multiple values to the collector.
```go
// Send the values 10, 20, and 30 to the collector.
//
// Note that even if the function reports an error, any values it sent to
// the collector before returning are still delivered.
g.Go(c.Report(func(report func(int)) error {
report(10)
report(20)
Expand Down

0 comments on commit 7acdc74

Please sign in to comment.