Skip to content

Commit

Permalink
Fix priority of JSONPath lexer rules. (#39)
Browse files Browse the repository at this point in the history
  • Loading branch information
jg-rp authored Oct 8, 2023
1 parent 2ad5520 commit 6f9e3be
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 3 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
# Python JSONPath Change Log

## Version 0.10.1

**Hot fix**

- Fixed priority of JSONPath lexer rules. Previously, standard short tokens (like `*` and `?`) had a higher priority than environment-controlled tokens (like `JSONPathEnvironment.keys_selector_token`), making it impossible to incorporate short token characters into longer environment-controlled tokens.

## Version 0.10.0

**Breaking Changes**
Expand Down
2 changes: 1 addition & 1 deletion jsonpath/__about__.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# SPDX-FileCopyrightText: 2023-present James Prior <[email protected]>
#
# SPDX-License-Identifier: MIT
__version__ = "0.10.0"
__version__ = "0.10.1"
4 changes: 2 additions & 2 deletions jsonpath/lex.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,9 +108,7 @@ def compile_rules(self) -> Pattern[str]:
(TOKEN_DOUBLE_QUOTE_STRING, self.double_quote_pattern),
(TOKEN_SINGLE_QUOTE_STRING, self.single_quote_pattern),
(TOKEN_RE_PATTERN, self.re_pattern),
(TOKEN_WILD, r"\*"),
(TOKEN_LIST_SLICE, self.slice_list_pattern),
(TOKEN_FILTER, r"\?"),
(TOKEN_FUNCTION, self.function_pattern),
(TOKEN_DOT_PROPERTY, self.dot_property_pattern),
(TOKEN_FLOAT, r"-?\d+\.\d*(?:e[+-]?\d+)?"),
Expand All @@ -125,6 +123,8 @@ def compile_rules(self) -> Pattern[str]:
(TOKEN_INTERSECTION, re.escape(self.env.intersection_token)),
(TOKEN_FILTER_CONTEXT, re.escape(self.env.filter_context_token)),
(TOKEN_KEYS, re.escape(self.env.keys_selector_token)),
(TOKEN_WILD, r"\*"),
(TOKEN_FILTER, r"\?"),
(TOKEN_IN, r"in"),
(TOKEN_TRUE, r"[Tt]rue"),
(TOKEN_FALSE, r"[Ff]alse"),
Expand Down
12 changes: 12 additions & 0 deletions tests/test_env.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,3 +158,15 @@ def test_no_unicode_escape() -> None:
env = JSONPathEnvironment(unicode_escape=False)
assert env.findall(selector, document) == []
assert env.findall(selector, {"\\uD834\\uDD1E": "B"}) == ["B"]


def test_custom_keys_selector_token() -> None:
"""Test that we can change the non-standard keys selector."""

class MyJSONPathEnvironment(JSONPathEnvironment):
keys_selector_token = "*~"

env = MyJSONPathEnvironment()
data = {"foo": {"a": 1, "b": 2, "c": 3}}
assert env.findall("$.foo.*~", data) == ["a", "b", "c"]
assert env.findall("$.foo.*", data) == [1, 2, 3]

0 comments on commit 6f9e3be

Please sign in to comment.