]> gitweb.fluxo.info Git - puppet-stdlib.git/commitdiff
Changing name of the function from include to includes as it clashes with
authorKrzysztof Wilczynski <krzysztof.wilczynski@linux.com>
Wed, 27 Apr 2011 22:26:41 +0000 (23:26 +0100)
committerKrzysztof Wilczynski <krzysztof.wilczynski@linux.com>
Wed, 27 Apr 2011 22:26:41 +0000 (23:26 +0100)
a core function from Puppet::Parser.  I had no idea that you can over-write
some of the that way. Oops.

Signed-off-by: Krzysztof Wilczynski <krzysztof.wilczynski@linux.com>
includes.rb [new file with mode: 0644]

diff --git a/includes.rb b/includes.rb
new file mode 100644 (file)
index 0000000..6207bf7
--- /dev/null
@@ -0,0 +1,32 @@
+#
+# include.rb
+#
+
+# TODO(Krzysztof Wilczynski): We need to add support for regular expression ...
+
+module Puppet::Parser::Functions
+  newfunction(:includes, :type => :rvalue, :doc => <<-EOS
+    EOS
+  ) do |arguments|
+
+    raise(Puppet::ParseError, "includes(): Wrong number of arguments " +
+      "given (#{arguments.size} for 2)") if arguments.size < 2
+
+    array = arguments[0]
+
+    if not array.is_a?(Array)
+      raise(Puppet::ParseError, 'includes(): Requires an array to work with')
+    end
+
+    item = arguments[1]
+
+    raise(Puppet::ParseError, 'includes(): You must provide item ' +
+      'to search for within given array') if item.empty?
+
+    result = array.include?(item)
+
+    return result
+  end
+end
+
+# vim: set ts=2 sw=2 et :