Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/keith-hall/sublimeyamlpath
Sublime Text plugin and Python package to determine the YAML (and JSON) Path of a particular position in a document, compatible with `yq`/`jq`. Shows the path in the ST status bar, like breadcrumb navigation.
https://github.com/keith-hall/sublimeyamlpath
jq json sublime-text yaml
Last synced: about 2 months ago
JSON representation
Sublime Text plugin and Python package to determine the YAML (and JSON) Path of a particular position in a document, compatible with `yq`/`jq`. Shows the path in the ST status bar, like breadcrumb navigation.
- Host: GitHub
- URL: https://github.com/keith-hall/sublimeyamlpath
- Owner: keith-hall
- License: mit
- Created: 2024-10-12T16:44:11.000Z (4 months ago)
- Default Branch: master
- Last Pushed: 2024-11-12T03:04:42.000Z (3 months ago)
- Last Synced: 2024-12-09T12:58:18.616Z (about 2 months ago)
- Topics: jq, json, sublime-text, yaml
- Language: Python
- Homepage:
- Size: 22.5 KB
- Stars: 1
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# YAML Path
A Python package and Sublime Text plugin which uses `ruamel.yaml` to parse YAML and JSON documents and lookup the "breadcrumb path" at a given position, which if used as a `yq`/`jq` query, should return the same item.
The Sublime Text plugin shows the path of the current selection/caret position in the status bar, so you can easily tell which part of the document you are in. There is also a command palette entry to copy the path to the clipboard. And to view the parse error in case the content is not valid.
It even works with multiple selections and inside YAML or JSON codefences embedded in Markdown documents.
## Status
Originally written for my own personal use, but happily accepting Pull Requests to fix any bugs or add more features.
Known limitations:
- currently only drills down to line level. This can be improved if it would be useful.
- doesn't handle JSONC very well - because it is using a YAML parser, `//` isn't a valid comment in YAML...
- currently no way to enable only for YAML files, and leave JSON to be handled by a separate plugin for example## How it works
When a selection change event is fired by Sublime Text, YAMLPath checks to see if the selection start and end has the same scope. (It will if it is an empty selection of course!) If it is a JSON or YAML scope, it finds the surrounding context - either the whole document or the Markdown code fence for example, and checks the cache to see if it has an already parsed document for that region.
If it doesn't, it will use the ruamel.yaml Python package to parse it and get the locations of all the nodes. This is then cached until the "view" is closed or edited etc.
Then, it recursively looks through the parse tree for the node which comes immediately before the selection position. It knows not to recurse the 1st child node if the selection is after the 2nd child node position for example.
Based on that hierarchy/stack of breadcrumbs, it generates the "YAML path" and shows it in the status bar.
When the view is edited, it debounces the events, so that it only reparses the YAML after 200 ms has elapsed since the last edit, to keep the UI smooth.## Testing
To run the unit tests:
```sh
python3 -m venv .venv
source .venv/bin/activate
pip3 install poetry
poetry install --no-root
poetry run python3 -m yaml_path.tests.test_yaml_path
```## Other Features
Not strictly related to paths, there is a command implemented (without bloating the core functionality/performance or anything) for converting JSON into human readable YAML.
This was specifically made for converting structured logs with unreadable stack traces, JSON dumped to a string and thus escaped in a JSON string etc. into something easily understandable by a human.
Currently it is a one-way conversion, but it would be possible to also implement a YAML -> JSON converter and support "round-tripping" by adding some YAML tags to the output when it is converted from JSON. When this gets implemented, some unit tests covering this will also be added.