Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tidwall/jsonc
Parse json with comments and trailing commas.
https://github.com/tidwall/jsonc
Last synced: 2 months ago
JSON representation
Parse json with comments and trailing commas.
- Host: GitHub
- URL: https://github.com/tidwall/jsonc
- Owner: tidwall
- License: mit
- Created: 2021-05-14T01:16:42.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2021-05-14T15:05:35.000Z (over 3 years ago)
- Last Synced: 2024-08-03T17:19:33.757Z (5 months ago)
- Language: Go
- Size: 6.84 KB
- Stars: 87
- Watchers: 5
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- go-awesome - jsonc - supports comments and commas (Open source library / JSON)
README
# jsonc
[![GoDoc](https://img.shields.io/badge/api-reference-blue.svg?style=flat-square)](https://pkg.go.dev/github.com/tidwall/jsonc)
jsonc is a Go package that converts the jsonc format to standard json.
The jsonc format is like standard json but allows for comments and trailing
commas, such as:```js
{/* Dev Machine */
"dbInfo": {
"host": "localhost",
"port": 5432,
"username": "josh",
"password": "pass123", // please use a hashed password
},/* Only SMTP Allowed */
"emailInfo": {
"email": "[email protected]", // use full email address
"password": "pass123",
"smtp": "smpt.example.com",
}}
```There's a provided function `jsonc.ToJSON`, which does the conversion.
The resulting JSON will always be the same length as the input and it will
include all of the same line breaks at matching offsets. This is to ensure
the result can be later processed by a external parser and that that
parser will report messages or errors with the correct offsets.## Getting Started
### Installing
To start using jsonc, install Go and run `go get`:
```sh
$ go get -u github.com/tidwall/jsonc
```This will retrieve the library.
### Example
The following example uses a JSON document that has comments and trailing
commas and converts it just prior to unmarshalling with the standard Go
JSON library.```go
data := `
{
/* Dev Machine */
"dbInfo": {
"host": "localhost",
"port": 5432, // use full email address
"username": "josh",
"password": "pass123", // use a hashed password
},
/* Only SMTP Allowed */
"emailInfo": {
"email": "[email protected]",
"password": "pass123",
"smtp": "smpt.example.com",
}
}
`err := json.Unmarshal(jsonc.ToJSON(data), &config)
```
### Performance
It's fast and can convert GB/s of jsonc to json.
## Contact
Josh Baker [@tidwall](http://twitter.com/tidwall)
## License
jsonc source code is available under the MIT [License](/LICENSE).