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

feat(stdlib): add fold function #1192

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

jakedipity
Copy link

@jakedipity jakedipity commented Dec 17, 2024

Summary

Adds a new fold function to reduce objects and arrays into a single value based on a closure and initial value.

Change Type

  • Bug fix
  • New feature
  • Non-functional (chore, refactoring, docs)
  • Performance

Is this a breaking change?

  • Yes
  • No

How did you test this PR?

Test examples in the fold function definition, existing function testing macros don't support functions with closures.

Does this PR include user facing changes?

  • Yes. Please add a changelog fragment based on
    our guidelines.
  • No. A maintainer will apply the "no-changelog" label to this PR.

Checklist

  • Our CONTRIBUTING.md is a good starting place.
  • If this PR introduces changes to LICENSE-3rdparty.csv, please
    run dd-rust-license-tool write and commit the changes. More details here.
  • For new VRL functions, please also create a sibling PR in Vector to document the new function.

References

Adds a new fold function to reduce objects and arrays into a single
value based on a closure and initial value.

Signed-off-by: Jacob Hull <[email protected]>
@pront pront self-assigned this Jan 2, 2025
@pront
Copy link
Member

pront commented Jan 2, 2025

Hi @jakedipity, thank you for this contribution!

I ran the CI checks and there are some failing tests. For fast local iterations you can use:

 ./scripts/checks.sh clippy tests vrl_tests

@pront
Copy link
Member

pront commented Jan 3, 2025

Also, please add a changelog. Feel free to ping me here when it's ready for another review.

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