Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add deep search for filter taking in properties #1749

Open
wants to merge 10 commits into
base: main
Choose a base branch
from

Conversation

andershagbard
Copy link
Contributor

@andershagbard andershagbard commented Oct 16, 2023

This PR allows for backward compatibility deep search :woah:

Like so:

{{ input | where: 'some.nested.property', 'foo', deep: true }}
{{ input | where: 'some_nested_property', 'foo', deep: '_' }} # Custom separator

Added deep search for the following filters. This should be all Liquid filters which takes in a property argument:

  • map
  • sort
  • sort_natural
  • sum
  • uniq
  • where
  • compact

@andershagbard
Copy link
Contributor Author

@dylanahsmith I am not sure if you still work on Liquid, but I would love for someone in the Liquid team to take a look at this PR.

@andershagbard
Copy link
Contributor Author

@karreiro @benjaminsehl ping

Copy link
Contributor

@karreiro karreiro left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

👋 Hey @andershagbard,

Thank you for this PR. Could you please share your reasoning behind the deep parameter?

I feel like it was introduced with backward compatibility concerns; however, I believe it may bring a bit of complexity to the language and to language server implementations. I don't think it's required for backward compatibility, but I'm not sure if I'm missing something in that aspect.

Thanks again for this PR!

@andershagbard
Copy link
Contributor Author

It's to safeguard against the JSON field type, which can contain dots in it's properties. It's an edge case I guess.

{
  "foo.bar": true
}

Ref: #1436 (comment)

karreiro added a commit that referenced this pull request Jan 14, 2025
* Add reject filter #1573

* Add deep search for filter taking in properties #1749

* Update branch with main

* Add `find`, `find_index`, `has`, and `reject` filters to arrays

* Refactor: avoid usage of public_send

---------

Co-authored-by: Anders Søgaard <andershagbard@gmail.com>
Co-authored-by: Anders Søgaard <9662430+andershagbard@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants