https://github.com/legovaer/jsonnet-docblock-parser
Simple, powerfull jsonnet docblock parser that returns a JSON representation to work with
https://github.com/legovaer/jsonnet-docblock-parser
Last synced: 2 months ago
JSON representation
Simple, powerfull jsonnet docblock parser that returns a JSON representation to work with
- Host: GitHub
- URL: https://github.com/legovaer/jsonnet-docblock-parser
- Owner: legovaer
- License: mit
- Created: 2020-03-05T21:21:51.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2020-08-03T08:36:26.000Z (over 4 years ago)
- Last Synced: 2024-12-04T16:08:02.703Z (3 months ago)
- Language: Python
- Size: 23.4 KB
- Stars: 10
- Watchers: 4
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Jsonnet Docblock Parser
JDP is a simple, powerfull jsonnet docblock parser that returns a JSON representation to work with.
[data:image/s3,"s3://crabby-images/aaf6f/aaf6f587473c7d7cfe4458c13a0ea2673d17a7b4" alt="Build Status"](https://travis-ci.com/legovaer/jsonnet-docblock-parser)
[data:image/s3,"s3://crabby-images/cf363/cf3639664ed30d1b7aaf45132e42fe47f36670b3" alt="PyPI status"](https://pypi.python.org/pypi/jsonnet_docblock_parser/)
[data:image/s3,"s3://crabby-images/0e897/0e8977072ed0aaf628db1d685c7881aa9caaa092" alt="PyPI version shields.io"](https://pypi.python.org/pypi/jsonnet_docblock_parser/)
[data:image/s3,"s3://crabby-images/a9994/a9994ee3244a882120fdf576052a6035c6b58c7e" alt="PyPI license"](https://pypi.python.org/pypi/jsonnet_docblock_parser/)
[data:image/s3,"s3://crabby-images/8e909/8e909a93d2e480cba10a826f5293b324038c7aac" alt="PyPI pyversions"](https://pypi.python.org/pypi/jsonnet_docblock_parser/)This parser will extract docblocks from your `.jsonnet` or `.libsonnet` files. This package
includes a generator that allows you to output the parsed information into JSON format.The parser assumes that the documentation inside these files is written in a syntax that is
similar to JavaScript, Java and many C++ scripts:```
{
/**
* Returns whether the string a is prefixed by the string b.
*
* @param a The input string.
* @param b The prefix.
* @return true if string a is prefixed by the string b or false otherwise.
*/
startsWith(a, b):
if std.length(a) < std.length(b) then
false
else
std.substr(a, 0, std.length(b)) == b,
}
```## Installation
You can install the tool via pip:
```bash
pip install jsonnet-docblock-parser
```## Module Usage
```python
#!/usr/bin/env python
# encoding: utf-8from jsonnet_docblock_parser import parseFile, Generator
# Load a jsonnet or libsonnet file.
TEST_FILE = "some.jsonnet"# Parse the file.
docblocks = parseFile(TEST_FILE)# Load the generator.
generator = Generator()# Parse Json based on the results.
json = generator.parse_json(results)# Print the json
print(json)
```## CLI Usage
```bash
jdp --file some.jsonnet
```## Development
### Testing
```bash
pytest
```### PyLint
```bash
pylint jsonnet_docblock_parser
```### Deploying to PyPi
```bash
python3 setup.py sdist
twine upload dist/*
```## License
The MIT License (MIT). Please see [License File](LICENSE.md) for more information.