Skip to content

Commit

Permalink
correct docs
Browse files Browse the repository at this point in the history
  • Loading branch information
besok committed Nov 3, 2023
1 parent d360b4f commit 9b4b33f
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 13 deletions.
52 changes: 45 additions & 7 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -223,11 +223,11 @@ Given the json
| `$..book[?(@.author ~= /.*REES/i)]` | All books matching regex (ignore case) |
| `$..*` | Give me every thing |

## The library
### The library

The library intends to provide the basic functionality for ability to find the slices of data using the syntax, saying
above. The dependency can be found as following:
``` jsonpath-rust = 0.3.0```
``` jsonpath-rust = *```

The basic example is the following one:

Expand Down Expand Up @@ -255,7 +255,7 @@ fn main() {
let finder = JsonPathFinder::from_str(r#"{"first":{"second":[{"active":1},{"passive":1}]}}"#, "$.first.second[?(@.active)]").unwrap();
let slice_of_data: Vec<&Value> = finder.find_slice();
let js = json!({"active":1});
assert_eq!(slice_of_data, vec![JsonPathValue::Slice(&js)]);
assert_eq!(slice_of_data, vec![JsonPathValue::Slice(&js,"$.first.second[0]".to_string())]);
}
```

Expand All @@ -282,7 +282,7 @@ fn test() {

let v = finder.find_slice();
let js = json!("Sayings of the Century");
assert_eq!(v, vec![JsonPathValue::Slice(&js)]);
assert_eq!(v, vec![JsonPathValue::Slice(&js,"$.book[0].title".to_string())]);
}

```
Expand Down Expand Up @@ -345,7 +345,45 @@ fn test() {
}
```

### The structure
The library can return a path describing the value instead of the value itself.
To do that, the method `find_as_path` can be used:

```rust
use jsonpath_rust::JsonPathFinder;
use serde_json::{json, Value, JsonPathValue};

fn main() {
let finder = JsonPathFinder::from_str(r#"{"first":{"second":[{"active":1},{"passive":1}]}}"#, "$.first.second[?(@.active)]").unwrap();
let slice_of_data: Value = finder.find_as_path();
assert_eq!(slice_of_data, Value::Array(vec!["$.first.second[0]".to_string()]));
}
```

or it can be taken from the `JsonPathValue` instance:
```rust
use serde_json::{json, Value};
use crate::jsonpath_rust::{JsonPathFinder, JsonPathQuery, JsonPathInst, JsonPathValue};
use std::str::FromStr;

fn test() {
let json: Box<Value> = serde_json::from_str("{}").unwrap();
let path: Box<JsonPathInst> = Box::from(JsonPathInst::from_str("$..book[?(@.author size 10)].title").unwrap());
let finder = JsonPathFinder::new(json, path);

let v = finder.find_slice();
let js = json!("Sayings of the Century");

// Slice has a path of its value as well
assert_eq!(v, vec![JsonPathValue::Slice(&js,"$.book[0].title".to_string())]);
}
```

** If the value has been modified during the search, there is no way to find a path of a new value.
It can happen if we try to find a length() of array, for in stance.**



## The structure

```rust
pub enum JsonPath {
Expand Down Expand Up @@ -380,11 +418,11 @@ pub enum JsonPathIndex {

```

### How to contribute
## How to contribute

TBD

### How to update version
## How to update version
- update files
- add tag `git tag -a v<Version> -m "message"`
- git push origin <tag_name>
23 changes: 17 additions & 6 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -80,16 +80,17 @@
//! - `[?(<expression>)]`the logical expression to filter elements in the list.It is used with arrays preliminary.
//!
//! # Examples
//!```
//!```rust
//! use serde_json::{json,Value};
//! use jsonpath_rust::jp_v;
//! use self::jsonpath_rust::JsonPathFinder;
//! use self::jsonpath_rust::JsonPathValue;
//!
//! fn test(){
//! let finder = JsonPathFinder::from_str(r#"{"first":{"second":[{"active":1},{"passive":1}]}}"#, "$.first.second[?(@.active)]").unwrap();
//! let slice_of_data:Vec<JsonPathValue<Value>> = finder.find_slice();
//! let js = json!({"active":1});
//! assert_eq!(slice_of_data, jp_v![&js,]);
//! let js = json!({"active":2});
//! assert_eq!(slice_of_data, jp_v![&js;"$.first.second[0]",]);
//! }
//! ```
//! or even simpler:
Expand Down Expand Up @@ -155,7 +156,7 @@ extern crate pest;
///
/// let v = finder.find_slice();
/// let js = json!("Sayings of the Century");
/// assert_eq!(v, jp_v![&js,]);
/// assert_eq!(v, jp_v![&js;"",]);
/// }
///
/// ```
Expand Down Expand Up @@ -248,7 +249,7 @@ impl JsonPathQuery for Value {
///
/// let v = finder.find_slice();
/// let js = json!("Sayings of the Century");
/// assert_eq!(v, jp_v![&js,]);
/// assert_eq!(v, jp_v![&js;"",]);
/// }
/// ```
#[macro_export]
Expand Down Expand Up @@ -286,6 +287,8 @@ macro_rules! jp_v {
};

}

/// Represents the path of the found json data
type JsPathStr = String;

pub(crate) fn jsp_idx(prefix: &str, idx: usize) -> String {
Expand Down Expand Up @@ -393,6 +396,14 @@ impl<'a, Data> JsonPathValue<'a, Data> {
})
.collect()
}

/// moves a pointer (from slice) out or provides a default value when the value was generated
pub fn slice_or(self, default: &'a Data) -> &'a Data {
match self {
Slice(r, _) => r,
NewValue(_) | NoValue => default,
}
}
}

/// The base structure stitching the json instance and jsonpath instance
Expand Down Expand Up @@ -473,7 +484,7 @@ impl JsonPathFinder {
}
/// finds a path of the values.
/// If the values has been obtained by moving the data out of the initial json the path is absent.
pub fn find_path(&self) -> Value {
pub fn find_as_path(&self) -> Value {
Value::Array(
self.find_slice()
.into_iter()
Expand Down

0 comments on commit 9b4b33f

Please sign in to comment.