From 40c4f8108e6d986070a665f0ffa7578a0e133983 Mon Sep 17 00:00:00 2001 From: Lucas Pickering Date: Sat, 27 Jul 2024 22:01:19 -0400 Subject: [PATCH] feat: Add `regex` feature flag This hides the regex functions (`match` and `search`) behind a feature flag `regex`, which is enabled by default. This allows consumers to completely eliminate regex as a dependency if they choose. Also added some docs on feature flags. --- serde_json_path/Cargo.toml | 5 +++-- serde_json_path/src/lib.rs | 8 ++++++++ .../src/parser/selector/function/registry.rs | 14 +++++++++----- 3 files changed, 20 insertions(+), 7 deletions(-) diff --git a/serde_json_path/Cargo.toml b/serde_json_path/Cargo.toml index cd3cb71..efc966e 100644 --- a/serde_json_path/Cargo.toml +++ b/serde_json_path/Cargo.toml @@ -11,7 +11,8 @@ readme = "README.md" keywords = ["json", "jsonpath", "json_path", "serde", "serde_json"] [features] -default = ["functions"] +default = ["functions", "regex"] +regex = ["dep:regex"] trace = ["dep:tracing", "serde_json_path_core/trace"] functions = ["serde_json_path_core/functions"] @@ -19,7 +20,7 @@ functions = ["serde_json_path_core/functions"] inventory = { version = "0.3.4" } nom = "7.1.3" once_cell = { version = "1.17.1" } -regex = "1.7.1" +regex = { version="1.7.1", optional = true } serde = { version = "1.0", features = ["derive"] } serde_json = "1.0" serde_json_path_core = { path = "../serde_json_path_core", version = "0.1.6" } diff --git a/serde_json_path/src/lib.rs b/serde_json_path/src/lib.rs index b4a0f98..dcad14d 100644 --- a/serde_json_path/src/lib.rs +++ b/serde_json_path/src/lib.rs @@ -311,6 +311,14 @@ //! # Ok(()) //! # } //! ``` +//! +//! ## Feature Flags +//! +//! The following feature flags are supported: +//! +//! - `tracing` - Enable internal tracing via [tracing] +//! - `functions` - Enable user-defined functions +//! - `regex` - Enable the `match` and `search` functions #![warn( clippy::all, diff --git a/serde_json_path/src/parser/selector/function/registry.rs b/serde_json_path/src/parser/selector/function/registry.rs index 1a9e88d..a5644b1 100644 --- a/serde_json_path/src/parser/selector/function/registry.rs +++ b/serde_json_path/src/parser/selector/function/registry.rs @@ -1,7 +1,6 @@ use std::collections::HashMap; use once_cell::sync::Lazy; -use regex::Regex; use serde_json::Value; use serde_json_path_core::spec::functions::{Function, LogicalType, NodesType, ValueType}; @@ -20,8 +19,11 @@ pub(crate) static REGISTRY: Lazy> = Laz let mut m = HashMap::new(); m.insert("length", &LENGTH_FUNC); m.insert("count", &COUNT_FUNC); - m.insert("match", &MATCH_FUNC); - m.insert("search", &SEARCH_FUNC); + #[cfg(feature = "regex")] + { + m.insert("match", &MATCH_FUNC); + m.insert("search", &SEARCH_FUNC); + } m.insert("value", &VALUE_FUNC); m }); @@ -50,11 +52,12 @@ fn count(nodes: NodesType) -> ValueType { nodes.len().into() } +#[cfg(feature = "regex")] #[serde_json_path_macros::register(name = "match", target = MATCH_FUNC)] fn match_func(value: ValueType, rgx: ValueType) -> LogicalType { match (value.as_value(), rgx.as_value()) { (Some(Value::String(s)), Some(Value::String(r))) => { - Regex::new(format!("(?R)^({r})$").as_str()) + regex::Regex::new(format!("(?R)^({r})$").as_str()) .map(|r| r.is_match(s)) .map(Into::into) .unwrap_or_default() @@ -63,11 +66,12 @@ fn match_func(value: ValueType, rgx: ValueType) -> LogicalType { } } +#[cfg(feature = "regex")] #[serde_json_path_macros::register(target = SEARCH_FUNC)] fn search(value: ValueType, rgx: ValueType) -> LogicalType { match (value.as_value(), rgx.as_value()) { (Some(Value::String(s)), Some(Value::String(r))) => { - Regex::new(format!("(?R)({r})").as_str()) + regex::Regex::new(format!("(?R)({r})").as_str()) .map(|r| r.is_match(s)) .map(Into::into) .unwrap_or_default()