Skip to main content

Crate liver_shot

Crate liver_shot 

Source
Expand description

A lightweight, no_std JSON value position extractor.

Returns a Span (start/end byte offsets) rather than a parsed value.

§Limitations

  • Object navigation only - arrays at the top level or as a path step return Error::is_unsupported_array.
  • Values are not validated — only their position is extracted.

§Examples

§Extract an object

let json = r#"{"a": {"b": "value", "c": [1, 2, 3]}}"#;

let span = liver_shot::find("a", json)?;
assert_eq!(r#"{"b": "value", "c": [1, 2, 3]}"#, span.get(json));

§Extract a nested object

let json = r#"{"a": {"b": {"c": "value"}}}"#;

let span = liver_shot::find("a.b", json)?;
assert_eq!(r#"{"c": "value"}"#, span.get(json));

§Extract an array

let json = r#"{"a": {"b": "value", "c": [1, 2, 3]}}"#;

let span = liver_shot::find("a.c", json)?;
assert_eq!("[1, 2, 3]", span.get(json));

§Reuse Span

let json = r#"{"a": {"b": "value", "c": [1, 2, 3]}}"#;

let a = liver_shot::find("a", json)?;
let b = a.find("b", json)?;
let c = a.find("c", json)?;

assert_eq!(r#"{"b": "value", "c": [1, 2, 3]}"#, a.get(json));
assert_eq!(r#""value""#, b.get(json));
assert_eq!("[1, 2, 3]", c.get(json));

Structs§

Error
Span

Functions§

find