Sha256: db8776327e0b88e1d18048f4b439bc24250d5011ffc9dde6b57e3e686ec8b3f4
Contents?: true
Size: 1.45 KB
Versions: 5
Compression:
Stored size: 1.45 KB
Contents
require 'puppet/parser/ast/lambda' Puppet::Parser::Functions::newfunction( :select, :type => :rvalue, :arity => 2, :doc => <<-'ENDHEREDOC') do |args| Applies a parameterized block to each element in a sequence of entries from the first argument and returns an array with the entires for which the block evaluates to true. This function takes two mandatory arguments: the first should be an Array or a Hash, and the second a parameterized block as produced by the puppet syntax: $a.select |$x| { ... } When the first argument is an Array, the block is called with each entry in turn. When the first argument is a hash the entry is an array with `[key, value]`. The returned filtered object is of the same type as the receiver. *Examples* # selects all that end with berry $a = ["raspberry", "blueberry", "orange"] $a.select |$x| { $x =~ /berry$/ } Since 3.2 ENDHEREDOC receiver = args[0] pblock = args[1] raise ArgumentError, ("select(): wrong argument type (#{pblock.class}; must be a parameterized block.") unless pblock.is_a? Puppet::Parser::AST::Lambda case receiver when Array receiver.select {|x| pblock.call(self, x) } when Hash result = receiver.select {|x, y| pblock.call(self, [x, y]) } # Ruby 1.8.7 returns Array result = Hash[result] unless result.is_a? Hash result else raise ArgumentError, ("select(): wrong argument type (#{receiver.class}; must be an Array or a Hash.") end end
Version data entries
5 entries across 5 versions & 1 rubygems