Crates.io | structured-output |
lib.rs | structured-output |
version | 0.1.1 |
source | src |
created_at | 2023-05-10 15:18:14.797114 |
updated_at | 2023-05-10 15:29:54.873697 |
description | A library for structured CLI output that can be displayed as either printed lines or JSON. |
homepage | |
repository | https://github.com/jsoverson/structured-output |
max_upload_size | |
id | 861398 |
size | 4,771 |
StructuredOutput
is a Rust library that provides a struct for handling structured output with both a string and a JSON value.
To use this library in your Rust project, add the following to your Cargo.toml
file:
[dependencies]
structured_output = "0.1.0"
You can then create a new StructuredOutput
instance using the new
method, which takes a string and a JSON value as arguments:
let lines = "Hello world!";
let json = serde_json::json!({ "message": lines });
let output = StructuredOutput::new(lines, json.clone());
You can retrieve the string and JSON value separately using the lines
and json
methods:
assert_eq!(output.lines(), "Hello world!");
assert_eq!(output.json(), &json);
You can also get the JSON value as a JSON string or a pretty-printed JSON string using the to_json_string
and to_json_pretty
methods:
assert_eq!(output.to_json_string(), "{\"message\":\"Hello world!\"}");
assert_eq!(output.to_json_pretty(), "{\n \"message\": \"Hello world!\"\n}");
The StructuredOutput
implementation of the Display
trait defaults to the string value. You can print the string value directly with the println!
macro:
println!("{}", output);
This library is licensed under the Apache 2.0 License.