summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeff McCune <jeff@puppetlabs.com>2012-11-28 14:29:32 -0800
committerJeff McCune <jeff@puppetlabs.com>2012-11-28 14:29:32 -0800
commit89fa98579c1c4c3e70cf3658d0ade76de1230045 (patch)
treed238e8de20f1c5e6cb2d8376256cea7441fb08b6
parente4aa3473249d1019de788bef893a1bca77bf9639 (diff)
parent16fe71867c997dd24a34aa088def7a1fa4cb5051 (diff)
downloadpuppet-stdlib-89fa98579c1c4c3e70cf3658d0ade76de1230045.tar.gz
puppet-stdlib-89fa98579c1c4c3e70cf3658d0ade76de1230045.tar.bz2
Merge branch '3.x' into 4.x
* 3.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