summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff McCune <jeff@puppetlabs.com>2012-11-28 14:29:14 -0800
committerJeff McCune <jeff@puppetlabs.com>2012-11-28 14:29:14 -0800
commit16fe71867c997dd24a34aa088def7a1fa4cb5051 (patch)
treea45b9a25f0891f642bcd93bf6b145c94cfdbbfbc
parentbe6d45632511cfb04748c8bcbe1e8a4831f3755b (diff)
parent26819f96889cb8ed16853c18317e781e512343b5 (diff)
downloadpuppet-stdlib-16fe71867c997dd24a34aa088def7a1fa4cb5051.tar.gz
puppet-stdlib-16fe71867c997dd24a34aa088def7a1fa4cb5051.tar.bz2
Merge branch '2.x' into 3.x
* 2.x: Add reject() function
-rw-r--r--lib/puppet/parser/functions/reject.rb31
-rwxr-xr-xspec/unit/puppet/parser/functions/reject_spec.rb20
2 files changed, 51 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/reject.rb b/lib/puppet/parser/functions/reject.rb
new file mode 100644
index 0000000..1953ffc
--- /dev/null
+++ b/lib/puppet/parser/functions/reject.rb
@@ -0,0 +1,31 @@
+#
+# reject.rb
+#
+
+module Puppet::Parser::Functions
+ newfunction(:reject, :type => :rvalue, :doc => <<-EOS) do |args|
+This function searches through an array and rejects all elements that match
+the provided regular expression.
+
+*Examples:*
+
+ reject(['aaa','bbb','ccc','aaaddd'], 'aaa')
+
+Would return:
+
+ ['bbb','ccc']
+EOS
+
+ if (args.size != 2)
+ raise Puppet::ParseError,
+ "reject(): Wrong number of arguments given #{args.size} for 2"
+ end
+
+ ary = args[0]
+ pattern = Regexp.new(args[1])
+
+ ary.reject { |e| e =~ pattern }
+ end
+end
+
+# vim: set ts=2 sw=2 et :
diff --git a/spec/unit/puppet/parser/functions/reject_spec.rb b/spec/unit/puppet/parser/functions/reject_spec.rb
new file mode 100755
index 0000000..f2cb741
--- /dev/null
+++ b/spec/unit/puppet/parser/functions/reject_spec.rb
@@ -0,0 +1,20 @@
+#!/usr/bin/env ruby
+
+require 'spec_helper'
+
+describe "the reject function" do
+ let(:scope) { PuppetlabsSpec::PuppetInternals.scope }
+
+ it "should exist" do
+ Puppet::Parser::Functions.function("reject").should == "function_reject"
+ end
+
+ it "should raise a ParseError if there is less than 1 arguments" do
+ lambda { scope.function_reject([]) }.should( raise_error(Puppet::ParseError))
+ end
+
+ it "should reject contents from an array" do
+ result = scope.function_reject([["1111", "aaabbb","bbbccc","dddeee"], "bbb"])
+ result.should(eq(["1111", "dddeee"]))
+ end
+end