Update stdlib
[mirror/dsa-puppet.git] / 3rdparty / modules / stdlib / lib / puppet / parser / functions / convert_base.rb
1 module Puppet::Parser::Functions
2
3   newfunction(:convert_base, :type => :rvalue, :arity => 2, :doc => <<-'ENDHEREDOC') do |args|
4
5     Converts a given integer or base 10 string representing an integer to a specified base, as a string.
6
7     Usage:
8
9       $binary_repr = convert_base(5, 2)  # $binary_repr is now set to "101"
10       $hex_repr = convert_base("254", "16")  # $hex_repr is now set to "fe"
11
12     ENDHEREDOC
13
14     raise Puppet::ParseError, ("convert_base(): First argument must be either a string or an integer") unless (args[0].is_a?(Integer) or args[0].is_a?(String))
15     raise Puppet::ParseError, ("convert_base(): Second argument must be either a string or an integer") unless (args[1].is_a?(Integer) or args[1].is_a?(String))
16
17     if args[0].is_a?(String)
18       raise Puppet::ParseError, ("convert_base(): First argument must be an integer or a string corresponding to an integer in base 10") unless args[0] =~ /^[0-9]+$/
19     end
20
21     if args[1].is_a?(String)
22       raise Puppet::ParseError, ("convert_base(): First argument must be an integer or a string corresponding to an integer in base 10") unless args[1] =~ /^[0-9]+$/
23     end
24
25     number_to_convert = args[0]
26     new_base = args[1]
27
28     number_to_convert = number_to_convert.to_i()
29     new_base = new_base.to_i()
30
31     raise Puppet::ParseError, ("convert_base(): base must be at least 2 and must not be greater than 36") unless new_base >= 2 and new_base <= 36
32
33     return number_to_convert.to_s(new_base)
34   end
35 end