Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/un-ts/sh-syntax
A WASM shell parser and formatter with bash support, based on `mvdan/sh`
https://github.com/un-ts/sh-syntax
go golang shell shell-script shellscript tinygo wasm
Last synced: 4 months ago
JSON representation
A WASM shell parser and formatter with bash support, based on `mvdan/sh`
- Host: GitHub
- URL: https://github.com/un-ts/sh-syntax
- Owner: un-ts
- License: mit
- Created: 2022-04-01T01:23:01.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-10-27T06:21:00.000Z (4 months ago)
- Last Synced: 2024-10-29T22:34:15.192Z (4 months ago)
- Topics: go, golang, shell, shell-script, shellscript, tinygo, wasm
- Language: TypeScript
- Homepage:
- Size: 4.29 MB
- Stars: 15
- Watchers: 1
- Forks: 4
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# sh-syntax
[data:image/s3,"s3://crabby-images/2f2a8/2f2a8e0d36a8211b91d07799afe6b8b5658b25ae" alt="GitHub Actions"](https://github.com/un-ts/sh-syntax/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/a443c/a443c324ca143bd39f9fa54f6bbfbc06801af587" alt="Codecov"](https://codecov.io/gh/un-ts/sh-syntax)
[data:image/s3,"s3://crabby-images/783ba/783badd7f5f05dc1e8c615cd720b8f668095f72e" alt="Language grade: JavaScript"](https://lgtm.com/projects/g/un-ts/sh-syntax/context:javascript)
[data:image/s3,"s3://crabby-images/35436/35436f3c94656b624dc10630fecd034194476e0c" alt="type-coverage"](https://github.com/plantain-00/type-coverage)
[data:image/s3,"s3://crabby-images/1145a/1145acd033b7ad93737e361c32376a23620186a5" alt="npm"](https://www.npmjs.com/package/sh-syntax)
[data:image/s3,"s3://crabby-images/28207/2820768f416ccee6f390dc394a422810224f432f" alt="GitHub Release"](https://github.com/un-ts/sh-syntax/releases)[data:image/s3,"s3://crabby-images/33024/330245df9cf7f4a14c3603a1aac1c22d7fcf2cd9" alt="Conventional Commits"](https://conventionalcommits.org)
[data:image/s3,"s3://crabby-images/4f9fb/4f9fb7bddef4aee10d3581e5e06a32347ce7dfcd" alt="Renovate enabled"](https://renovatebot.com)
[data:image/s3,"s3://crabby-images/432d6/432d695915e1b608030587a7ba48baa6280c643d" alt="JavaScript Style Guide"](https://standardjs.com)
[data:image/s3,"s3://crabby-images/66d2a/66d2aa6f1e0afe66f640aa4ac2de0141d66555dc" alt="Code Style: Prettier"](https://github.com/prettier/prettier)
[data:image/s3,"s3://crabby-images/12617/126172d20221c4cf1a332c8493b375c9dbcdc185" alt="changesets"](https://github.com/changesets/changesets)A WASM shell parser and formatter with bash support, based on [mvdan/sh](https://github.com/mvdan/sh)
## TOC
- [Usage](#usage)
- [Install](#install)
- [API](#api)
- [Sponsors](#sponsors)
- [Backers](#backers)
- [Changelog](#changelog)
- [License](#license)## Usage
### Install
```sh
# yarn
yarn add sh-syntax# npm
npm i sh-syntax
```### API
```js
// node
import { parse, print } from 'sh-syntax'const text = "echo 'Hello World!'"
const ast = await parse(text)
const newText = await print(ast, {
// `originalText` is required for now, hope we will find better solution later
originalText: text,
})
``````js
// browser
import { getProcessor } from 'sh-syntax'const processor = getProcessor(() =>
fetch('sh-syntax/main.wasm').then(res => res.arrayBuffer()),
)const parse = (text, options) => processor(text, options)
const print = (textOrAst, options) => {
if (typeof textOrAst === 'string') {
return processor(textOrAst, {
...options,
print: true,
})
}
return processor(textOrAst, options)
}// just like node again
const text = "echo 'Hello World!'"
const ast = await parse(text)
const newText = await print(ast, { originalText: text })
```## Sponsors
| 1stG | RxTS | UnTS |
| ---------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------- |
| [data:image/s3,"s3://crabby-images/adc9b/adc9b275256c64dbe5465f478e033a0ea1b2e128" alt="1stG Open Collective backers and sponsors"](https://opencollective.com/1stG) | [data:image/s3,"s3://crabby-images/b87e5/b87e51754fa34c1228625c9959f2bc3aeb2afee6" alt="RxTS Open Collective backers and sponsors"](https://opencollective.com/rxts) | [data:image/s3,"s3://crabby-images/6a2db/6a2db9c093038461f071c151993d546e5f946694" alt="UnTS Open Collective backers and sponsors"](https://opencollective.com/unts) |## Backers
| 1stG | RxTS | UnTS |
| -------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------- |
| [data:image/s3,"s3://crabby-images/89c3f/89c3fef0a65c570e0d29fcd693d5e9f30caffdea" alt="1stG Open Collective backers and sponsors"](https://opencollective.com/1stG) | [data:image/s3,"s3://crabby-images/a2070/a207047efa76b17ecc32da45dd663515c8508cd4" alt="RxTS Open Collective backers and sponsors"](https://opencollective.com/rxts) | [data:image/s3,"s3://crabby-images/43262/43262bb44d28eb519f997f97c61eddda02304783" alt="UnTS Open Collective backers and sponsors"](https://opencollective.com/unts) |## Changelog
Detailed changes for each release are documented in [CHANGELOG.md](./CHANGELOG.md).
## License
[MIT][] © [JounQin][]@[1stG.me][]
[1stg.me]: https://www.1stg.me
[jounqin]: https://GitHub.com/JounQin
[mit]: http://opensource.org/licenses/MIT