gochan/README.md
2021-02-08 17:38:55 -06:00

77 lines
2.5 KiB
Markdown

# Introduction
This is an idiomatic, minimally-opinionated `Channel` type for JavaScript that's
inspired by [Go's channels](https://golang.org/ref/spec#Channel_types). It
works in browsers and in Node.js. If you know how to use an `Array` then you
already know most of how to use a `Channel`.
## Why
Go's use of channels for concurrency is amazing and with JavaScript's
async/await feature we have the basis for it as well. All that's missing is a
solid `Channel` type. There are existing libraries but I wanted an idiomatic
`Channel` type that's simple and minimally-opinionated.
This document assumes you're familiar with Go's channels and why you'd want to
use them. For explanatory background, see my [blog
article](https://www.nodeguy.com/channels-for-javascript/) on the subject.
## Installation
```shell
$ npm install @nodeguy/channel
```
## Basic Use
Create a channel with `Channel()`.
To send a value to a channel use `push`. To receive a value from a channel use
`shift`. Always precede the method calls with `await`. Close the channel when
there are no more values to push.
```JavaScript
const assert = require(`assert`);
const Channel = require(`@nodeguy/channel`);
const channel = Channel();
const send = async () => {
await channel.push(42);
await channel.close();
};
const receive = async () => {
assert.equal(await channel.shift(), 42);
assert.equal(await channel.shift(), undefined);
};
await Promise.all([send(), receive()]);
```
The `push` and `shift` methods are usually called in different async functions.
They represent the two different ends of the channel and act to synchronize the
behavior of the async functions.
# API
The API is in the [API.md](API.md) file.
# Similar Projects
- [Channel](https://github.com/gozala/channel)
- [cochan](https://github.com/skozin/cochan)
- [js-csp](https://github.com/ubolonton/js-csp)
- [node-csp](https://github.com/olahol/node-csp)
# Copyright
Copyright 2017 [David Braun](https://www.NodeGuy.com/)
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
these files except in compliance with the License. You may obtain a copy of the
License at `http://www.apache.org/licenses/LICENSE-2.0`. Unless required by
applicable law or agreed to in writing, software distributed under the License
is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the specific language
governing permissions and limitations under the License.