# process groups for gleam
Simple wrapper around [erlang process groups] in gleam.
This library mainly wraps [erlang process groups], so go to its documentation for details.
[data:image/s3,"s3://crabby-images/b57d1/b57d1c76024b461a2db3fe03789ec6058704b4c9" alt="Package Version"](https://hex.pm/packages/processgroups)
[data:image/s3,"s3://crabby-images/7c557/7c557a32f08e49c79944cb17a8d1b101a5ccade0" alt="Hex Docs"](https://hexdocs.pm/processgroups/)
## Usage
Add this library to your Gleam project
```sh
gleam add processgroups
```
And use it in your project
```gleam
import io
import processgroups as pg
import gleam/erlang/process
// some type we use to distinguish process groups
// could also be strings
type ProcessGroups {
ExampleProcessGroup
}
pub fn main() {
// start process groups
pg.start_link()
// put ourself into a process group
pg.join(ExampleProcessGroup, process.self())
// list processes in the group
io.debug(pg.get_members(ExampleProcessGroup))
// output: [<our-process-id>]
// leave the group
pg.leave(ExampleProcessGroup, process.self())
// list processes in the group
io.debug(pg.get_members(ExampleProcessGroup))
// output: []
// monitor a process group
let #(group_monitor, current_processes) = pg.monitor(ExampleProcessGroup)
io.debug(current_processes)
// output: []
// join to create monitoring event
pg.join(ExampleProcessGroup, process.self())
// get the created event
let assert Ok(pg.ProcessJoined(ExampleProcessGroup, new_pids)) = pg.selecting_process_group_monitor(
process.new_selector(),
group_monitor,
fn(pid) {pid}
) |> process.select(100)
}
```
Further documentation can be found at <https://hexdocs.pm/processgroups>.
## Development
```sh
gleam run # Run the project
gleam test # Run the tests
gleam shell # Run an Erlang shell
```
[erlang process groups]: https://www.erlang.org/doc/man/pg.html