magic-string-ast
Version:
magic-string with AST shortcut.
69 lines (51 loc) • 1.96 kB
Markdown
[![npm version][npm-version-src]][npm-version-href]
[![npm downloads][npm-downloads-src]][npm-downloads-href]
[![JSR][jsr-badge-src]][jsr-badge-href]
[![Unit Test][unit-test-src]][unit-test-href]
[](https://github.com/rich-harris/magic-string) with AST shortcut.
```bash
npm i magic-string-ast
npx jsr add -D @sxzz/magic-string-ast
```
```ts
import { MagicStringAST } from 'magic-string-ast'
const offset = 0
const node = {
// AST node with `start` and `end` properties
start: 6,
end: 7,
// ...
}
const s = new MagicStringAST('const a = 1')
s.sliceNode(node, { offset }) // 'a'
s.removeNode(node)
s.moveNode(node, 0)
s.overwriteNode(node, 'foo')
// support source-map, inspired by muggle-string.
s.replaceRange(5, 5, '(', expression, ')') // appendLeft
s.replaceRange(5, 8, '(', expression, ')') // overwrite
s.replaceRange(5, 8) // remove
```
For more APIs, see [docs](https://jsr.io/@sxzz/magic-string-ast/doc) and [magic-string](https://github.com/rich-harris/magic-string#usage).
<p align="center">
<a href="https://cdn.jsdelivr.net/gh/sxzz/sponsors/sponsors.svg">
<img src='https://cdn.jsdelivr.net/gh/sxzz/sponsors/sponsors.svg'/>
</a>
</p>
[](./LICENSE) License © 2023-PRESENT [Kevin Deng](https://github.com/sxzz)
<!-- Badges -->
[]: https://img.shields.io/npm/v/magic-string-ast.svg
[]: https://npmjs.com/package/magic-string-ast
[]: https://img.shields.io/npm/dm/magic-string-ast
[]: https://www.npmcharts.com/compare/magic-string-ast?interval=30
[]: https://jsr.io/badges/@sxzz/magic-string-ast
[]: https://jsr.io/@sxzz/magic-string-ast
[]: https://github.com/sxzz/magic-string-ast/actions/workflows/unit-test.yml/badge.svg
[]: https://github.com/sxzz/magic-string-ast/actions/workflows/unit-test.yml