Sha256: 374bb65321eb11dcb1f4a2dab02d3c5f5dd4221ecde5c36c6bb420e3b2706632

Contents?: true

Size: 1.91 KB

Versions: 84

Compression:

Stored size: 1.91 KB

Contents

# Capitalizes the first character of a String, or the first character of every String in an Iterable value (such as an Array).
#
# This function is compatible with the stdlib function with the same name.
#
# The function does the following:
# * For a `String`, a string with its first character in upper case version is returned. 
#   This is done using Ruby system locale which handles some, but not all
#   special international up-casing rules (for example German double-s ß is capitalized to "Ss").
# * For an `Iterable[Variant[String, Numeric]]` (for example an `Array`) each value is capitalized and the conversion is not recursive.
# * If the value is `Numeric` it is simply returned (this is for backwards compatibility).
# * An error is raised for all other data types.
#
# Please note: This function relies directly on Ruby's String implementation and as such may not be entirely UTF8 compatible.
# To ensure best compatibility please use this function with Ruby 2.4.0 or greater - https://bugs.ruby-lang.org/issues/10085.
#
# @example Capitalizing a String
# ```puppet
# 'hello'.capitalize()
# upcase('hello')
# ```
# Would both result in `"Hello"`
#
# @example Capitalizing strings in an Array
# ```puppet
# ['abc', 'bcd'].capitalize()
# capitalize(['abc', 'bcd'])
# ```
# Would both result in `['Abc', 'Bcd']`
#
Puppet::Functions.create_function(:capitalize) do

  dispatch :on_numeric do
    param 'Numeric', :arg
  end

  dispatch :on_string do
    param 'String', :arg
  end

  dispatch :on_iterable do
    param 'Iterable[Variant[String, Numeric]]', :arg
  end

  # unit function - since the old implementation skipped Numeric values
  def on_numeric(n)
    n
  end

  def on_string(s)
    s.capitalize
  end

  def on_iterable(a)
    a.map {|x| do_capitalize(x) }
  end

  def do_capitalize(x)
    # x can only be a String or Numeric because type constraints have been automatically applied
    x.is_a?(String) ? x.capitalize : x
  end
end

Version data entries

84 entries across 84 versions & 1 rubygems

Version Path
puppet-7.16.0 lib/puppet/functions/capitalize.rb
puppet-7.16.0-x86-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.16.0-x64-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.16.0-universal-darwin lib/puppet/functions/capitalize.rb
puppet-7.15.0 lib/puppet/functions/capitalize.rb
puppet-7.15.0-x86-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.15.0-x64-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.15.0-universal-darwin lib/puppet/functions/capitalize.rb
puppet-6.26.0 lib/puppet/functions/capitalize.rb
puppet-6.26.0-x86-mingw32 lib/puppet/functions/capitalize.rb
puppet-6.26.0-x64-mingw32 lib/puppet/functions/capitalize.rb
puppet-6.26.0-universal-darwin lib/puppet/functions/capitalize.rb
puppet-7.14.0 lib/puppet/functions/capitalize.rb
puppet-7.14.0-x86-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.14.0-x64-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.14.0-universal-darwin lib/puppet/functions/capitalize.rb
puppet-7.13.1 lib/puppet/functions/capitalize.rb
puppet-7.13.1-x86-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.13.1-x64-mingw32 lib/puppet/functions/capitalize.rb
puppet-7.13.1-universal-darwin lib/puppet/functions/capitalize.rb