Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rhysd/fixjson
JSON Fixer for Humans using (relaxed) JSON5
https://github.com/rhysd/fixjson
fixer formatter json
Last synced: 3 days ago
JSON representation
JSON Fixer for Humans using (relaxed) JSON5
- Host: GitHub
- URL: https://github.com/rhysd/fixjson
- Owner: rhysd
- License: mit
- Created: 2018-01-11T11:13:56.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2023-10-17T01:05:04.000Z (over 1 year ago)
- Last Synced: 2025-02-14T03:43:50.441Z (5 days ago)
- Topics: fixer, formatter, json
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/fixjson
- Size: 199 KB
- Stars: 130
- Watchers: 4
- Forks: 6
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
JSON fixer for Humans
=====================
[![npm version][]][fixjson]
[![ci-badge][]][ci][fixjson][] is a JSON file fixer/formatter for humans using (relaxed) JSON5.
fixjson provides:
- Pretty-printing JSON5 input
- ES5 syntax is available to write up JSON
- Fixes various failures while humans writing JSON
- Fixes trailing commas objects or arrays
- Fixes missing commas for elements of objects or arrays
- Adds quotes to keys in objects
- Newlines in strings
- Hex numbers
- Fixes single quotes to double quotesfixjson reads an input in [relaxed JSON5][forked json5] format and outputs it in JSON format. Indent
width is automatically detected.This CLI tool aims to be used with editor extensions.
- [vim-fixjson][] (dedicated Vim plugin)
- [ALE][] (Vim plugin)
- [neoformat][] (Vim plugin)
- [vim-autoformat][] (Vim plugin)## Screenshots of Fixes
When moving a line to another line, you no longer need to care about a trailing comma:
data:image/s3,"s3://crabby-images/0be6c/0be6cd7945b6e9b21b3c9f4c17da2f7e49bbdd6e" alt="modify keys"
And you also don't need to care about a trailing comma of a previous line when adding a new element
to an object or an array:data:image/s3,"s3://crabby-images/247da/247dabdb675d71963fce965fb04a4b18fd92c8f0" alt="add key"
When adding a new key-value to an object, quotes of the key are fixed. And single quotes for strings
are also fixed to double quotes:data:image/s3,"s3://crabby-images/a38ab/a38abb60a4baff581f517460a87fceb3dacf26bb" alt="key quotes"
JSON string does not allow multi-line string. `\n` is required to embed multi-line string to JSON.
fixjson automatically fixes newlines in strings. This is useful when copy&paste some string to JSON
file:data:image/s3,"s3://crabby-images/e861a/e861ad2c97be914ea41dbf2e0177a44ee1405ede" alt="newlines in string"
JSON only accepts decimal digits for numbers. fixjson automatically converts `0x` hex numbers to
decimal numbers. You no longer need to convert hex numbers manually:data:image/s3,"s3://crabby-images/b920e/b920e20ce6331e75238bc09a45e8d1ae7818a48e" alt="hex numbebr"
And of course it pretty-prints the JSON code, with automatic indent detection:
data:image/s3,"s3://crabby-images/a3c0d/a3c0d10b46c5c484fc42dadfdc95cfc8ff5be78b" alt="pretty printing"
## Installation
```sh
$ npm install -g fixjson
```It installs `fixjson` command globally.
## Usage
```sh
fixjson [--write|--indent|--minify|--stdin-filename] [paths...]
```If paths are given, glob such as `dir/**/*.json` is available. If the path is a directory, it formats
all JSON files in the directory. If no path is given, it reads from STDIN.If `--write` (or `-w`) option is provided, it overwrites files.
If `--indent {num}` (or `-i {num}`) is not provided, it detects indent spaces.
Please see `fixjson --help` for more details.
## License
Distributed under the MIT License. Please see [LICENSE](LICENSE).
[fixjson]: https://www.npmjs.com/package/fixjson
[vim-fixjson]: https://github.com/rhysd/vim-fixjson
[forked json5]: https://github.com/rhysd/json5
[npm version]: https://badge.fury.io/js/fixjson.svg
[ci-badge]: https://github.com/rhysd/fixjson/workflows/CI/badge.svg?branch=ga&event=push
[ci]: https://github.com/rhysd/fixjson/actions?query=workflow%3ACI
[neoformat]: https://github.com/sbdchd/neoformat
[vim-autoformat]: https://github.com/Chiel92/vim-autoformat
[ALE]: https://github.com/w0rp/ale