summaryrefslogtreecommitdiff
path: root/lib/puppet/parser
diff options
context:
space:
mode:
authorSteve Huff <shuff@vecna.org>2013-03-29 12:03:33 -0400
committerSteve Huff <shuff@vecna.org>2013-03-29 12:54:37 -0400
commit4a5218a8af8c3ffaf9ea2348a3900b19d6a95416 (patch)
treea3d965b79112bfc025258831afb2467ecbb1c9bd /lib/puppet/parser
parente6916f83fd35989db4b86dfb10716c9198994389 (diff)
Reworked number-handling logic
No more coercing to String and regex matching. Instead, we now coerce to Integer at the beginning or raise an error if we cannot coerce to Integer. A consequence of this change is that the function will now accept blatantly non-numeric strings as input, and return false. This seems a bit goofy to me, but it's how String#to_i works. If we really don't like this, then I'm open to suggestions.
Diffstat (limited to 'lib/puppet/parser')
-rw-r--r--lib/puppet/parser/functions/num2bool.rb35
1 files changed, 11 insertions, 24 deletions
diff --git a/lib/puppet/parser/functions/num2bool.rb b/lib/puppet/parser/functions/num2bool.rb
index 638f693..15dd560 100644
--- a/lib/puppet/parser/functions/num2bool.rb
+++ b/lib/puppet/parser/functions/num2bool.rb
@@ -2,39 +2,26 @@
# num2bool.rb
#
-# TODO(Krzysztof Wilczynski): We probably need to approach numeric values differently ...
-
module Puppet::Parser::Functions
newfunction(:num2bool, :type => :rvalue, :doc => <<-EOS
-This function converts a number into a true boolean. Zero becomes false. Numbers
-higher then 0 become true.
+This function converts a number or a string representation of a number into a
+true boolean. Zero or anything non-numeric becomes false. Numbers higher then 0
+become true.
EOS
) do |arguments|
raise(Puppet::ParseError, "num2bool(): Wrong number of arguments " +
- "given (#{arguments.size} for 1)") if arguments.size < 1
-
- # Since we're matching against a regex, coerce to String
- number = arguments[0].to_s
-
- # Only numbers allowed ...
- unless number.match(/^\-?\d+$/)
- raise(Puppet::ParseError, 'num2bool(): Requires integer to work with')
- end
+ "given (#{arguments.size} for 1)") if arguments.size != 1
- result = case number
- when /^0$/
- false
- when /^\-?\d+$/
- # Numbers in Puppet are often string-encoded which is troublesome ...
- number = number.to_i
- # We yield true for any positive number and false otherwise ...
- number > 0 ? true : false
- else
- raise(Puppet::ParseError, 'num2bool(): Unknown numeric format given')
+ # we need to get an Integer out of this
+ begin
+ number = arguments[0].to_i
+ rescue NoMethodError
+ raise(Puppet::ParseError, 'num2bool(): Unable to parse number: ' + $!)
end
- return result
+ # Return true for any positive number and false otherwise
+ return number > 0 ? true : false
end
end