#json #jsonc #hjson #format #decode

fjson

A library for parsing and formatting json with C-style comments and trailing commas

5 unstable releases

0.3.1 Jan 19, 2023
0.3.0 Jan 15, 2023
0.2.1 Jan 7, 2023
0.2.0 Jan 7, 2023
0.1.0 Jan 6, 2023

#704 in Parser implementations

Download history 96/week @ 2023-08-01 44/week @ 2023-08-08 128/week @ 2023-08-15 95/week @ 2023-08-22 58/week @ 2023-08-29 121/week @ 2023-09-05 36/week @ 2023-09-12 35/week @ 2023-09-19 85/week @ 2023-09-26 62/week @ 2023-10-03 63/week @ 2023-10-10 15/week @ 2023-10-17 70/week @ 2023-10-24 11/week @ 2023-10-31 51/week @ 2023-11-07 34/week @ 2023-11-14

169 downloads per month
Used in metafmt

MIT license

82KB
2K SLoC

fjson

A Rust library for parsing and formatting JSON with C-style comments and trailing commas

Usage

Given the following input:

// This is a JSON value with comments and trailing commas
{

    /* The project name is fjson */
    "project": "fjson",
    "language": "Rust",
    "license": [
        "MIT",
    ],


  // This project is public.
    "public": true,
}

Format to JSONC

Format to pretty JSONC, intended for human viewing:

let output = fjson::to_jsonc(input).unwrap();
println!("{}", output);

Prints:

// This is a JSON value with comments and trailing commas
{
  /* The project name is fjson */
  "project": "fjson",
  "language": "Rust",
  "license": ["MIT"],

  // This project is public.
  "public": true
}

Format to valid, pretty JSON

Format to pretty JSON, intended for human viewing:

let output = fjson::to_json(input)?;
println!("{}", output);

Prints:

{
  "project": "fjson",
  "language": "Rust",
  "license": ["MIT"],
  "public": true
}

Format to valid, compact JSON

Format to compact JSON, intended for computer consumption:

let output = fjson::to_json_compact(input)?;
println!("{}", output);

Prints:

{"project":"fjson","language":"Rust","license":["MIT"],"public":true}

Deserialize with Serde

To parse JSON with C-style comments and trailing commas, but deserialize via serde, this can be accomplished with the following:

use serde::Deserialize;

#[derive(Debug, Deserialize)]
struct Project {
    project: String,
    language: String,
    license: Vec<String>,
    public: bool,
}

let output = fjson::to_json_compact(input)?;
let project: Project = serde_json::from_str(&output)?;
println!("{:#?}", project);

Dependencies

~67KB