Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/geut/jsdast
JSDoc Abstract Syntax Tree
https://github.com/geut/jsdast
ast jsdoc tsdoc unist
Last synced: 3 months ago
JSON representation
JSDoc Abstract Syntax Tree
- Host: GitHub
- URL: https://github.com/geut/jsdast
- Owner: geut
- License: mit
- Created: 2020-12-16T11:57:50.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-06-11T23:25:08.000Z (over 3 years ago)
- Last Synced: 2024-10-24T00:24:54.950Z (3 months ago)
- Topics: ast, jsdoc, tsdoc, unist
- Language: JavaScript
- Homepage:
- Size: 983 KB
- Stars: 21
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# jsdast
Syntax tree JSDoc based on Unist spec[![Build Status](https://travis-ci.com/geut/jsdast.svg?token=yjuaa2ubUupz6ACajDgF&branch=main)](https://travis-ci.com/geut/jsdast)
[![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)
[![standard-readme compliant](https://img.shields.io/badge/readme%20style-standard-brightgreen.svg?style=flat-square)](https://github.com/RichardLitt/standard-readme)[![Made by GEUT][geut-badge]][geut-url]
## Install
```
$ npm install @geut/jsdast
```## Usage
```javascript
const unified = require('unified')
const { parser } = require('@geut/jsdast')const tree = unified().use(parser).parse(`
/**
* @param {number} a
* @param {number} b
* @returns {number}
*/
function sum(a, b) {
return a + b
}
`)console.log(JSON.stringify(tree, null, 2))
/*
{
"type": "Root",
"children": [
{
"type": "Module",
"name": "Index",
"doc": {
"description": "",
"tags": []
},
"children": [
{
"type": "FunctionDeclaration",
"name": "sum",
"doc": {
"tags": [
{
"tagName": "returns",
"fullText": "@returns {number}",
"typeExpression": "number"
}
]
},
"isExported": false,
"isDefaultExport": false,
"valueType": "number",
"isGenerator": false,
"isAsync": false,
"children": [
{
"type": "Parameter",
"name": "a",
"doc": {
"tags": []
},
"isRestParameter": false,
"valueType": "number",
"isOptional": false
},
{
"type": "Parameter",
"name": "b",
"doc": {
"tags": []
},
"isRestParameter": false,
"valueType": "number",
"isOptional": false
}
]
}
]
}
]
}
*/
```## Issues
:bug: If you found an issue we encourage you to report it on [github](https://github.com/geut/jsdast/issues). Please specify your OS and the actions to reproduce it.
## Contributing
:busts_in_silhouette: Ideas and contributions to the project are welcome. You must follow this [guideline](https://github.com/geut/jsdast/blob/main/CONTRIBUTING.md).
## License
MIT © A [**GEUT**](http://geutstudio.com/) project
[geut-url]: https://geutstudio.com
[geut-badge]: https://img.shields.io/badge/Made%20By-GEUT-4f5186?style=for-the-badge&link=https://geutstudio.com&labelColor=white&logo=