File: filter.rb

package info (click to toggle)
puppet-agent 8.10.0-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 27,404 kB
  • sloc: ruby: 286,820; sh: 492; xml: 116; makefile: 88; cs: 68
file content (81 lines) | stat: -rw-r--r-- 3,200 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# frozen_string_literal: true

Puppet::Parser::Functions.newfunction(
  :filter,
  :type => :rvalue,
  :arity => -3,
  :doc => <<~DOC
    Applies a [lambda](https://puppet.com/docs/puppet/latest/lang_lambdas.html)
    to every value in a data structure and returns an array or hash containing any elements
    for which the lambda evaluates to a truthy value (not `false` or `undef`).

    This function takes two mandatory arguments, in this order:

    1. An array or hash the function will iterate over.
    2. A lambda, which the function calls for each element in the first argument. It can
    request one or two parameters.

    **Example**: Using the `filter` function

    `$filtered_data = $data.filter |$parameter| { <PUPPET CODE BLOCK> }`

    or

    `$filtered_data = filter($data) |$parameter| { <PUPPET CODE BLOCK> }`

    When the first argument (`$data` in the above example) is an array, Puppet passes each
    value in turn to the lambda and returns an array containing the results.

    **Example**: Using the `filter` function with an array and a one-parameter lambda

    ~~~ puppet
    # For the array $data, return an array containing the values that end with "berry"
    $data = ["orange", "blueberry", "raspberry"]
    $filtered_data = $data.filter |$items| { $items =~ /berry$/ }
    # $filtered_data = [blueberry, raspberry]
    ~~~

    When the first argument is a hash, Puppet passes each key and value pair to the lambda
    as an array in the form `[key, value]` and returns a hash containing the results.

    **Example**: Using the `filter` function with a hash and a one-parameter lambda

    ~~~ puppet
    # For the hash $data, return a hash containing all values of keys that end with "berry"
    $data = { "orange" => 0, "blueberry" => 1, "raspberry" => 2 }
    $filtered_data = $data.filter |$items| { $items[0] =~ /berry$/ }
    # $filtered_data = {blueberry => 1, raspberry => 2}
    ~~~

    When the first argument is an array and the lambda has two parameters, Puppet passes the
    array's indexes (enumerated from 0) in the first parameter and its values in the second
    parameter.

    **Example**: Using the `filter` function with an array and a two-parameter lambda

    ~~~ puppet
    # For the array $data, return an array of all keys that both end with "berry" and have
    # an even-numbered index
    $data = ["orange", "blueberry", "raspberry"]
    $filtered_data = $data.filter |$indexes, $values| { $indexes % 2 == 0 and $values =~ /berry$/ }
    # $filtered_data = [raspberry]
    ~~~

    When the first argument is a hash, Puppet passes its keys to the first parameter and its
    values to the second parameter.

    **Example**: Using the `filter` function with a hash and a two-parameter lambda

    ~~~ puppet
    # For the hash $data, return a hash of all keys that both end with "berry" and have
    # values less than or equal to 1
    $data = { "orange" => 0, "blueberry" => 1, "raspberry" => 2 }
    $filtered_data = $data.filter |$keys, $values| { $keys =~ /berry$/ and $values <= 1 }
    # $filtered_data = {blueberry => 1}
    ~~~

    - Since 4.0.0
  DOC
) do |_args|
  Puppet::Parser::Functions::Error.is4x('filter')
end