Merge branch 'pull-136' into 2.x
This commit is contained in:
commit
755d3d2de5
4 changed files with 26 additions and 2 deletions
|
@ -8,6 +8,14 @@ module Puppet::Parser::Functions
|
||||||
raise(Puppet::ParseError, "max(): Wrong number of arguments " +
|
raise(Puppet::ParseError, "max(): Wrong number of arguments " +
|
||||||
"need at least one") if args.size == 0
|
"need at least one") if args.size == 0
|
||||||
|
|
||||||
return args.max
|
# Sometimes we get numbers as numerics and sometimes as strings.
|
||||||
|
# We try to compare them as numbers when possible
|
||||||
|
return args.max do |a,b|
|
||||||
|
if a.to_s =~ /\A-?\d+(.\d+)?\z/ and b.to_s =~ /\A-?\d+(.\d+)?\z/ then
|
||||||
|
a.to_f <=> b.to_f
|
||||||
|
else
|
||||||
|
a.to_s <=> b.to_s
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -8,6 +8,14 @@ module Puppet::Parser::Functions
|
||||||
raise(Puppet::ParseError, "min(): Wrong number of arguments " +
|
raise(Puppet::ParseError, "min(): Wrong number of arguments " +
|
||||||
"need at least one") if args.size == 0
|
"need at least one") if args.size == 0
|
||||||
|
|
||||||
return args.min
|
# Sometimes we get numbers as numerics and sometimes as strings.
|
||||||
|
# We try to compare them as numbers when possible
|
||||||
|
return args.min do |a,b|
|
||||||
|
if a.to_s =~ /\A^-?\d+(.\d+)?\z/ and b.to_s =~ /\A-?\d+(.\d+)?\z/ then
|
||||||
|
a.to_f <=> b.to_f
|
||||||
|
else
|
||||||
|
a.to_s <=> b.to_s
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -20,4 +20,8 @@ describe "the max function" do
|
||||||
it "should be able to compare numbers" do
|
it "should be able to compare numbers" do
|
||||||
scope.function_max([6,8,4]).should(eq(8))
|
scope.function_max([6,8,4]).should(eq(8))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should be able to compare a number with a stringified number" do
|
||||||
|
scope.function_max([1,"2"]).should(eq("2"))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -20,4 +20,8 @@ describe "the min function" do
|
||||||
it "should be able to compare numbers" do
|
it "should be able to compare numbers" do
|
||||||
scope.function_min([6,8,4]).should(eq(4))
|
scope.function_min([6,8,4]).should(eq(4))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it "should be able to compare a number with a stringified number" do
|
||||||
|
scope.function_min([1,"2"]).should(eq(1))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue