puppet 6.19.1-x64-mingw32 → 6.23.0-x64-mingw32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of puppet might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CODEOWNERS +2 -16
- data/Gemfile +3 -1
- data/Gemfile.lock +51 -40
- data/ext/osx/puppet.plist +2 -0
- data/ext/project_data.yaml +2 -2
- data/lib/puppet/application.rb +10 -6
- data/lib/puppet/application/agent.rb +12 -4
- data/lib/puppet/application/apply.rb +4 -2
- data/lib/puppet/application/device.rb +2 -0
- data/lib/puppet/application/filebucket.rb +2 -2
- data/lib/puppet/application/resource.rb +2 -1
- data/lib/puppet/application/script.rb +2 -0
- data/lib/puppet/application/ssl.rb +11 -0
- data/lib/puppet/application_support.rb +7 -0
- data/lib/puppet/configurer.rb +28 -18
- data/lib/puppet/configurer/downloader.rb +2 -1
- data/lib/puppet/defaults.rb +51 -23
- data/lib/puppet/environments.rb +54 -55
- data/lib/puppet/face/config.rb +10 -0
- data/lib/puppet/face/epp.rb +12 -2
- data/lib/puppet/face/facts.rb +158 -0
- data/lib/puppet/ffi/posix.rb +10 -0
- data/lib/puppet/ffi/posix/constants.rb +14 -0
- data/lib/puppet/ffi/posix/functions.rb +24 -0
- data/lib/puppet/file_serving/fileset.rb +14 -2
- data/lib/puppet/file_system/memory_file.rb +8 -1
- data/lib/puppet/file_system/windows.rb +2 -0
- data/lib/puppet/functions/all.rb +1 -1
- data/lib/puppet/functions/camelcase.rb +1 -1
- data/lib/puppet/functions/capitalize.rb +2 -2
- data/lib/puppet/functions/downcase.rb +2 -2
- data/lib/puppet/functions/epp.rb +1 -0
- data/lib/puppet/functions/get.rb +5 -5
- data/lib/puppet/functions/group_by.rb +13 -5
- data/lib/puppet/functions/inline_epp.rb +1 -0
- data/lib/puppet/functions/lest.rb +1 -1
- data/lib/puppet/functions/new.rb +100 -100
- data/lib/puppet/functions/partition.rb +12 -4
- data/lib/puppet/functions/require.rb +5 -5
- data/lib/puppet/functions/sort.rb +3 -3
- data/lib/puppet/functions/tree_each.rb +7 -9
- data/lib/puppet/functions/type.rb +4 -4
- data/lib/puppet/functions/upcase.rb +2 -2
- data/lib/puppet/http/resolver/server_list.rb +15 -4
- data/lib/puppet/http/service/compiler.rb +69 -0
- data/lib/puppet/http/service/file_server.rb +2 -1
- data/lib/puppet/indirector/catalog/compiler.rb +1 -0
- data/lib/puppet/indirector/fact_search.rb +60 -0
- data/lib/puppet/indirector/facts/facter.rb +24 -3
- data/lib/puppet/indirector/facts/json.rb +27 -0
- data/lib/puppet/indirector/facts/yaml.rb +3 -58
- data/lib/puppet/indirector/file_metadata/rest.rb +1 -0
- data/lib/puppet/indirector/json.rb +5 -1
- data/lib/puppet/indirector/node/json.rb +8 -0
- data/lib/puppet/indirector/report/json.rb +34 -0
- data/lib/puppet/module_tool/applications/installer.rb +48 -2
- data/lib/puppet/module_tool/errors/shared.rb +17 -2
- data/lib/puppet/network/formats.rb +69 -1
- data/lib/puppet/network/http/factory.rb +4 -0
- data/lib/puppet/pal/pal_impl.rb +70 -17
- data/lib/puppet/parser/ast/leaf.rb +3 -2
- data/lib/puppet/parser/functions/fqdn_rand.rb +14 -6
- data/lib/puppet/parser/templatewrapper.rb +1 -1
- data/lib/puppet/pops/evaluator/deferred_resolver.rb +5 -3
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +22 -3
- data/lib/puppet/pops/model/ast_transformer.rb +1 -1
- data/lib/puppet/pops/types/p_sem_ver_type.rb +8 -2
- data/lib/puppet/pops/types/p_sensitive_type.rb +10 -0
- data/lib/puppet/property/list.rb +1 -1
- data/lib/puppet/provider/group/groupadd.rb +13 -8
- data/lib/puppet/provider/package/apt.rb +34 -2
- data/lib/puppet/provider/package/aptitude.rb +6 -0
- data/lib/puppet/provider/package/dnfmodule.rb +1 -1
- data/lib/puppet/provider/package/nim.rb +11 -6
- data/lib/puppet/provider/service/debian.rb +2 -0
- data/lib/puppet/provider/service/systemd.rb +14 -4
- data/lib/puppet/provider/service/windows.rb +38 -0
- data/lib/puppet/provider/user/aix.rb +2 -2
- data/lib/puppet/provider/user/directoryservice.rb +25 -12
- data/lib/puppet/provider/user/useradd.rb +62 -8
- data/lib/puppet/reference/configuration.rb +7 -6
- data/lib/puppet/settings.rb +33 -28
- data/lib/puppet/settings/alias_setting.rb +37 -0
- data/lib/puppet/settings/base_setting.rb +26 -2
- data/lib/puppet/settings/environment_conf.rb +1 -0
- data/lib/puppet/transaction/additional_resource_generator.rb +1 -1
- data/lib/puppet/type/file.rb +19 -1
- data/lib/puppet/type/file/selcontext.rb +1 -1
- data/lib/puppet/type/package.rb +3 -3
- data/lib/puppet/type/service.rb +18 -38
- data/lib/puppet/type/tidy.rb +21 -2
- data/lib/puppet/type/user.rb +38 -20
- data/lib/puppet/util/autoload.rb +1 -8
- data/lib/puppet/util/fact_dif.rb +81 -0
- data/lib/puppet/util/monkey_patches.rb +7 -0
- data/lib/puppet/util/posix.rb +54 -5
- data/lib/puppet/util/rubygems.rb +5 -1
- data/lib/puppet/util/selinux.rb +30 -4
- data/lib/puppet/util/windows/adsi.rb +46 -0
- data/lib/puppet/util/windows/api_types.rb +1 -1
- data/lib/puppet/util/windows/principal.rb +9 -2
- data/lib/puppet/util/windows/service.rb +1 -1
- data/lib/puppet/util/windows/sid.rb +4 -2
- data/lib/puppet/version.rb +1 -1
- data/locales/puppet.pot +372 -288
- data/man/man5/puppet.conf.5 +282 -254
- data/man/man8/puppet-agent.8 +2 -2
- data/man/man8/puppet-apply.8 +2 -2
- data/man/man8/puppet-catalog.8 +1 -1
- data/man/man8/puppet-config.8 +1 -1
- data/man/man8/puppet-describe.8 +1 -1
- data/man/man8/puppet-device.8 +2 -2
- data/man/man8/puppet-doc.8 +1 -1
- data/man/man8/puppet-epp.8 +1 -1
- data/man/man8/puppet-facts.8 +90 -1
- data/man/man8/puppet-filebucket.8 +3 -3
- data/man/man8/puppet-generate.8 +1 -1
- data/man/man8/puppet-help.8 +1 -1
- data/man/man8/puppet-key.8 +1 -1
- data/man/man8/puppet-lookup.8 +1 -1
- data/man/man8/puppet-man.8 +1 -1
- data/man/man8/puppet-module.8 +1 -1
- data/man/man8/puppet-node.8 +4 -1
- data/man/man8/puppet-parser.8 +1 -1
- data/man/man8/puppet-plugin.8 +1 -1
- data/man/man8/puppet-report.8 +4 -1
- data/man/man8/puppet-resource.8 +1 -1
- data/man/man8/puppet-script.8 +2 -2
- data/man/man8/puppet-ssl.8 +5 -1
- data/man/man8/puppet-status.8 +1 -1
- data/man/man8/puppet.8 +2 -2
- data/spec/fixtures/integration/application/agent/cached_deferred_catalog.json +91 -0
- data/spec/fixtures/ssl/127.0.0.1-key.pem +107 -57
- data/spec/fixtures/ssl/127.0.0.1.pem +52 -31
- data/spec/fixtures/ssl/bad-basic-constraints.pem +57 -35
- data/spec/fixtures/ssl/bad-int-basic-constraints.pem +57 -35
- data/spec/fixtures/ssl/ca.pem +57 -35
- data/spec/fixtures/ssl/crl.pem +28 -18
- data/spec/fixtures/ssl/ec-key.pem +11 -11
- data/spec/fixtures/ssl/ec.pem +33 -24
- data/spec/fixtures/ssl/encrypted-ec-key.pem +12 -12
- data/spec/fixtures/ssl/encrypted-key.pem +108 -58
- data/spec/fixtures/ssl/intermediate-agent-crl.pem +28 -19
- data/spec/fixtures/ssl/intermediate-agent.pem +57 -36
- data/spec/fixtures/ssl/intermediate-crl.pem +31 -21
- data/spec/fixtures/ssl/intermediate.pem +57 -36
- data/spec/fixtures/ssl/pluto-key.pem +107 -57
- data/spec/fixtures/ssl/pluto.pem +52 -30
- data/spec/fixtures/ssl/request-key.pem +107 -57
- data/spec/fixtures/ssl/request.pem +47 -26
- data/spec/fixtures/ssl/revoked-key.pem +107 -57
- data/spec/fixtures/ssl/revoked.pem +52 -30
- data/spec/fixtures/ssl/signed-key.pem +107 -57
- data/spec/fixtures/ssl/signed.pem +52 -30
- data/spec/fixtures/ssl/tampered-cert.pem +52 -30
- data/spec/fixtures/ssl/tampered-csr.pem +47 -26
- data/spec/fixtures/ssl/unknown-127.0.0.1-key.pem +107 -57
- data/spec/fixtures/ssl/unknown-127.0.0.1.pem +50 -29
- data/spec/fixtures/ssl/unknown-ca-key.pem +107 -57
- data/spec/fixtures/ssl/unknown-ca.pem +55 -33
- data/spec/fixtures/unit/provider/service/systemd/list_unit_files_services_vendor_preset +9 -0
- data/spec/fixtures/unit/provider/user/aix/aix_passwd_file.out +4 -0
- data/spec/integration/application/agent_spec.rb +160 -3
- data/spec/integration/application/apply_spec.rb +19 -0
- data/spec/integration/application/plugin_spec.rb +1 -1
- data/spec/integration/application/resource_spec.rb +30 -0
- data/spec/integration/defaults_spec.rb +0 -7
- data/spec/integration/environments/setting_hooks_spec.rb +1 -1
- data/spec/integration/http/client_spec.rb +12 -0
- data/spec/integration/indirector/direct_file_server_spec.rb +1 -3
- data/spec/integration/resource/type_collection_spec.rb +2 -6
- data/spec/integration/transaction_spec.rb +4 -9
- data/spec/integration/util/windows/adsi_spec.rb +21 -1
- data/spec/integration/util/windows/principal_spec.rb +21 -0
- data/spec/integration/util/windows/registry_spec.rb +6 -10
- data/spec/lib/puppet/test_ca.rb +2 -2
- data/spec/lib/puppet_spec/settings.rb +6 -1
- data/spec/spec_helper.rb +12 -5
- data/spec/unit/agent_spec.rb +8 -6
- data/spec/unit/application/agent_spec.rb +7 -3
- data/spec/unit/application/config_spec.rb +224 -4
- data/spec/unit/application/facts_spec.rb +482 -3
- data/spec/unit/application/filebucket_spec.rb +0 -2
- data/spec/unit/application/ssl_spec.rb +23 -0
- data/spec/unit/application_spec.rb +51 -9
- data/spec/unit/configurer/downloader_spec.rb +6 -0
- data/spec/unit/configurer_spec.rb +23 -0
- data/spec/unit/confine/feature_spec.rb +1 -1
- data/spec/unit/confine_spec.rb +8 -2
- data/spec/unit/defaults_spec.rb +36 -1
- data/spec/unit/environments_spec.rb +221 -68
- data/spec/unit/face/config_spec.rb +27 -32
- data/spec/unit/face/facts_spec.rb +4 -0
- data/spec/unit/face/node_spec.rb +0 -11
- data/spec/unit/file_serving/configuration/parser_spec.rb +0 -1
- data/spec/unit/file_serving/fileset_spec.rb +60 -0
- data/spec/unit/file_serving/metadata_spec.rb +3 -3
- data/spec/unit/file_serving/terminus_helper_spec.rb +11 -4
- data/spec/unit/file_system_spec.rb +9 -0
- data/spec/unit/forge/module_release_spec.rb +2 -7
- data/spec/unit/functions/inline_epp_spec.rb +26 -1
- data/spec/unit/gettext/config_spec.rb +12 -0
- data/spec/unit/http/service/compiler_spec.rb +172 -0
- data/spec/unit/http/service_spec.rb +1 -1
- data/spec/unit/indirector/catalog/compiler_spec.rb +14 -10
- data/spec/unit/indirector/face_spec.rb +0 -1
- data/spec/unit/indirector/facts/facter_spec.rb +95 -1
- data/spec/unit/indirector/facts/json_spec.rb +255 -0
- data/spec/unit/indirector/file_bucket_file/selector_spec.rb +26 -8
- data/spec/unit/indirector/indirection_spec.rb +8 -12
- data/spec/unit/indirector/key/file_spec.rb +0 -1
- data/spec/unit/indirector/node/json_spec.rb +33 -0
- data/spec/{integration/indirector/report/yaml.rb → unit/indirector/report/json_spec.rb} +13 -24
- data/spec/unit/indirector/report/yaml_spec.rb +72 -8
- data/spec/unit/indirector_spec.rb +2 -2
- data/spec/unit/module_tool/applications/installer_spec.rb +66 -0
- data/spec/unit/network/authconfig_spec.rb +0 -3
- data/spec/unit/network/formats_spec.rb +41 -0
- data/spec/unit/network/http/api/indirected_routes_spec.rb +0 -9
- data/spec/unit/network/http/factory_spec.rb +19 -0
- data/spec/unit/network/http/handler_spec.rb +0 -5
- data/spec/unit/parser/compiler_spec.rb +3 -19
- data/spec/unit/parser/functions/fqdn_rand_spec.rb +15 -1
- data/spec/unit/parser/resource_spec.rb +14 -8
- data/spec/unit/parser/templatewrapper_spec.rb +4 -3
- data/spec/unit/pops/evaluator/deferred_resolver_spec.rb +20 -0
- data/spec/unit/pops/types/p_sem_ver_type_spec.rb +18 -0
- data/spec/unit/pops/types/p_sensitive_type_spec.rb +18 -0
- data/spec/unit/property_spec.rb +1 -0
- data/spec/unit/provider/group/groupadd_spec.rb +5 -2
- data/spec/unit/provider/nameservice_spec.rb +66 -65
- data/spec/unit/provider/package/apt_spec.rb +28 -23
- data/spec/unit/provider/package/aptitude_spec.rb +1 -1
- data/spec/unit/provider/package/base_spec.rb +6 -5
- data/spec/unit/provider/package/dnfmodule_spec.rb +10 -1
- data/spec/unit/provider/package/nim_spec.rb +42 -0
- data/spec/unit/provider/package/pacman_spec.rb +18 -12
- data/spec/unit/provider/package/pip_spec.rb +6 -11
- data/spec/unit/provider/package/pkgdmg_spec.rb +0 -4
- data/spec/unit/provider/service/init_spec.rb +1 -0
- data/spec/unit/provider/service/openwrt_spec.rb +3 -1
- data/spec/unit/provider/service/systemd_spec.rb +53 -8
- data/spec/unit/provider/service/windows_spec.rb +202 -0
- data/spec/unit/provider/user/aix_spec.rb +5 -0
- data/spec/unit/provider/user/directoryservice_spec.rb +67 -35
- data/spec/unit/provider/user/hpux_spec.rb +1 -1
- data/spec/unit/provider/user/pw_spec.rb +2 -0
- data/spec/unit/provider/user/useradd_spec.rb +71 -3
- data/spec/unit/provider_spec.rb +8 -10
- data/spec/unit/puppet_pal_catalog_spec.rb +45 -0
- data/spec/unit/resource/capability_finder_spec.rb +6 -1
- data/spec/unit/resource/catalog_spec.rb +1 -1
- data/spec/unit/resource/type_spec.rb +1 -1
- data/spec/unit/resource_spec.rb +11 -10
- data/spec/unit/settings_spec.rb +419 -242
- data/spec/unit/ssl/base_spec.rb +0 -1
- data/spec/unit/ssl/host_spec.rb +0 -5
- data/spec/unit/ssl/ssl_provider_spec.rb +14 -8
- data/spec/unit/ssl/state_machine_spec.rb +19 -5
- data/spec/unit/transaction/additional_resource_generator_spec.rb +3 -9
- data/spec/unit/transaction/event_manager_spec.rb +14 -11
- data/spec/unit/transaction_spec.rb +18 -11
- data/spec/unit/type/file/content_spec.rb +0 -1
- data/spec/unit/type/file/selinux_spec.rb +3 -5
- data/spec/unit/type/file_spec.rb +0 -6
- data/spec/unit/type/group_spec.rb +13 -6
- data/spec/unit/type/resources_spec.rb +7 -7
- data/spec/unit/type/service_spec.rb +60 -189
- data/spec/unit/type/tidy_spec.rb +17 -8
- data/spec/unit/type/user_spec.rb +45 -0
- data/spec/unit/type_spec.rb +2 -2
- data/spec/unit/util/at_fork_spec.rb +2 -2
- data/spec/unit/util/autoload_spec.rb +5 -1
- data/spec/unit/util/backups_spec.rb +1 -2
- data/spec/unit/util/execution_spec.rb +15 -11
- data/spec/unit/util/inifile_spec.rb +6 -14
- data/spec/unit/util/log_spec.rb +8 -7
- data/spec/unit/util/logging_spec.rb +3 -3
- data/spec/unit/util/posix_spec.rb +363 -15
- data/spec/unit/util/rubygems_spec.rb +2 -2
- data/spec/unit/util/selinux_spec.rb +163 -68
- data/spec/unit/util/storage_spec.rb +3 -1
- data/spec/unit/util/suidmanager_spec.rb +44 -41
- data/spec/unit/util/windows/sid_spec.rb +6 -0
- data/spec/unit/util_spec.rb +13 -6
- data/tasks/generate_cert_fixtures.rake +2 -2
- metadata +33 -16
- data/spec/integration/application/config_spec.rb +0 -74
- data/spec/lib/matchers/include.rb +0 -27
- data/spec/lib/matchers/include_spec.rb +0 -32
- data/spec/unit/face/catalog_spec.rb +0 -6
- data/spec/unit/face/module_spec.rb +0 -3
| @@ -4,14 +4,22 @@ | |
| 4 4 | 
             
            # and the values are arrays of elements in the collection that correspond to the key.
         | 
| 5 5 | 
             
            Puppet::Functions.create_function(:group_by) do
         | 
| 6 6 | 
             
              # @param collection A collection of things to group.
         | 
| 7 | 
            -
              # @example Group array of strings by length, results in e.g. { 1 => [a, b], 2 => [ab] }
         | 
| 7 | 
            +
              # @example Group array of strings by length, results in e.g. `{ 1 => [a, b], 2 => [ab] }`
         | 
| 8 | 
            +
              #   ```puppet
         | 
| 8 9 | 
             
              #   [a, b, ab].group_by |$s| { $s.length }
         | 
| 9 | 
            -
              # | 
| 10 | 
            +
              #   ```
         | 
| 11 | 
            +
              # @example Group array of strings by length and index, results in e.g. `{1 => ['a'], 2 => ['b', 'ab']}`
         | 
| 12 | 
            +
              #   ```puppet
         | 
| 10 13 | 
             
              #   [a, b, ab].group_by |$i, $s| { $i%2 + $s.length }
         | 
| 11 | 
            -
              # | 
| 14 | 
            +
              #   ```
         | 
| 15 | 
            +
              # @example Group hash iterating by key-value pair, results in e.g. `{ 2 => [['a', [1, 2]]], 1 => [['b', [1]]] }`
         | 
| 16 | 
            +
              #   ```puppet
         | 
| 12 17 | 
             
              #   { a => [1, 2], b => [1] }.group_by |$kv| { $kv[1].length }
         | 
| 13 | 
            -
              # | 
| 14 | 
            -
              # | 
| 18 | 
            +
              #   ```
         | 
| 19 | 
            +
              # @example Group hash iterating by key and value, results in e.g. `{ 2 => [['a', [1, 2]]], 1 => [['b', [1]]] }`
         | 
| 20 | 
            +
              #   ```puppet
         | 
| 21 | 
            +
              #    { a => [1, 2], b => [1] }.group_by |$k, $v| { $v.length }
         | 
| 22 | 
            +
              #   ```
         | 
| 15 23 | 
             
              dispatch :group_by_1 do
         | 
| 16 24 | 
             
                required_param 'Collection', :collection
         | 
| 17 25 | 
             
                block_param 'Callable[1,1]', :block
         | 
| @@ -51,6 +51,7 @@ Puppet::Functions.create_function(:inline_epp, Puppet::Functions::InternalFuncti | |
| 51 51 | 
             
                scope_param()
         | 
| 52 52 | 
             
                param 'String', :template
         | 
| 53 53 | 
             
                optional_param 'Hash[Pattern[/^\w+$/], Any]', :parameters
         | 
| 54 | 
            +
                return_type 'Variant[String, Sensitive[String]]'
         | 
| 54 55 | 
             
              end
         | 
| 55 56 |  | 
| 56 57 | 
             
              def inline_epp(scope, template, parameters = nil)
         | 
| @@ -23,7 +23,7 @@ | |
| 23 23 | 
             
            #  .lest || { fail("no value for $data[a][b][c]" }
         | 
| 24 24 | 
             
            # ```
         | 
| 25 25 | 
             
            #
         | 
| 26 | 
            -
            # Would fail the operation because  | 
| 26 | 
            +
            # Would fail the operation because `$data[a][b][c]` results in `undef`
         | 
| 27 27 | 
             
            # (there is no `b` key in `a`).
         | 
| 28 28 | 
             
            #
         | 
| 29 29 | 
             
            # In contrast - this example:
         | 
    
        data/lib/puppet/functions/new.rb
    CHANGED
    
    | @@ -51,7 +51,7 @@ | |
| 51 51 | 
             
            # The following sections show the arguments and conversion rules
         | 
| 52 52 | 
             
            # per data type built into the Puppet Type System.
         | 
| 53 53 | 
             
            #
         | 
| 54 | 
            -
            # ### Conversion to Optional[T] and NotUndef[T]
         | 
| 54 | 
            +
            # ### Conversion to `Optional[T]` and `NotUndef[T]`
         | 
| 55 55 | 
             
            #
         | 
| 56 56 | 
             
            # Conversion to these data types is the same as a conversion to the type argument `T`.
         | 
| 57 57 | 
             
            # In the case of `Optional[T]` it is accepted that the argument to convert may be `undef`.
         | 
| @@ -85,13 +85,13 @@ | |
| 85 85 | 
             
            #   * `0` as radix 8.
         | 
| 86 86 | 
             
            #   * All others are decimal.
         | 
| 87 87 | 
             
            # * Conversion from `String` accepts an optional sign in the string.
         | 
| 88 | 
            -
            # * For hexadecimal (radix 16) conversion an optional leading "0x" | 
| 89 | 
            -
            # * For octal (radix 8) an optional leading "0" is accepted.
         | 
| 90 | 
            -
            # * For binary (radix 2) an optional leading "0b" or "0B" is accepted.
         | 
| 88 | 
            +
            # * For hexadecimal (radix 16) conversion an optional leading `"0x"`, or `"0X"` is accepted.
         | 
| 89 | 
            +
            # * For octal (radix 8) an optional leading `"0"` is accepted.
         | 
| 90 | 
            +
            # * For binary (radix 2) an optional leading `"0b"` or `"0B"` is accepted.
         | 
| 91 91 | 
             
            # * When `radix` is set to `default`, the conversion is based on the leading.
         | 
| 92 | 
            -
            #   characters in the string. A leading "0" for radix 8, a leading "0x" | 
| 93 | 
            -
            #   radix 16, and leading "0b" or "0B" for binary.
         | 
| 94 | 
            -
            # * Conversion from `Boolean` results in 0 for `false` and 1 for `true`.
         | 
| 92 | 
            +
            #   characters in the string. A leading `"0"` for radix 8, a leading `"0x"`, or `"0X"` for
         | 
| 93 | 
            +
            #   radix 16, and leading `"0b"` or `"0B"` for binary.
         | 
| 94 | 
            +
            # * Conversion from `Boolean` results in `0` for `false` and `1` for `true`.
         | 
| 95 95 | 
             
            # * Conversion from `Integer`, `Float`, and `Boolean` ignores the radix.
         | 
| 96 96 | 
             
            # * `Float` value fractions are truncated (no rounding).
         | 
| 97 97 | 
             
            # * When `abs` is set to `true`, the result will be an absolute integer.
         | 
| @@ -119,9 +119,9 @@ | |
| 119 119 | 
             
            # ```
         | 
| 120 120 | 
             
            #
         | 
| 121 121 | 
             
            # * For an integer, the floating point fraction of `.0` is added to the value.
         | 
| 122 | 
            -
            # * A `Boolean` `true` is converted to 1.0 | 
| 122 | 
            +
            # * A `Boolean` `true` is converted to `1.0`, and a `false` to `0.0`.
         | 
| 123 123 | 
             
            # * In `String` format, integer prefixes for hex and binary are understood (but not octal since
         | 
| 124 | 
            -
            #   floating point in string format may start with a '0').
         | 
| 124 | 
            +
            #   floating point in string format may start with a `'0'`).
         | 
| 125 125 | 
             
            # * When `abs` is set to `true`, the result will be an absolute floating point value.
         | 
| 126 126 | 
             
            #
         | 
| 127 127 | 
             
            # ### Conversion to Numeric
         | 
| @@ -139,7 +139,7 @@ | |
| 139 139 | 
             
            # * If the value has a decimal period, or if given in scientific notation
         | 
| 140 140 | 
             
            #   (e/E), the result is a `Float`, otherwise the value is an `Integer`. The
         | 
| 141 141 | 
             
            #   conversion from `String` always uses a radix based on the prefix of the string.
         | 
| 142 | 
            -
            # * Conversion from `Boolean` results in 0 for `false` and 1 for `true`.
         | 
| 142 | 
            +
            # * Conversion from `Boolean` results in `0` for `false` and `1` for `true`.
         | 
| 143 143 | 
             
            # * When `abs` is set to `true`, the result will be an absolute `Float`or `Integer` value.
         | 
| 144 144 | 
             
            #
         | 
| 145 145 | 
             
            # @example Converting to Numeric in different ways
         | 
| @@ -225,7 +225,7 @@ | |
| 225 225 | 
             
            # )
         | 
| 226 226 | 
             
            # ```
         | 
| 227 227 | 
             
            #
         | 
| 228 | 
            -
            # The directive consists of a percent ( | 
| 228 | 
            +
            # The directive consists of a percent (`%`) character, zero or more flags, optional minimum field width and
         | 
| 229 229 | 
             
            # a conversion specifier as follows:
         | 
| 230 230 | 
             
            # ```
         | 
| 231 231 | 
             
            # %[Flags][Width]Conversion
         | 
| @@ -291,7 +291,7 @@ | |
| 291 291 | 
             
            # argument is omitted, an array of default formats will be used.
         | 
| 292 292 | 
             
            #
         | 
| 293 293 | 
             
            # A third optional timezone argument can be provided. The first argument will then be parsed as if it represents a local time in that
         | 
| 294 | 
            -
            # timezone. The timezone can be any timezone that is recognized when using the '%z' or '%Z' formats, or the word 'current' | 
| 294 | 
            +
            # timezone. The timezone can be any timezone that is recognized when using the `'%z'` or `'%Z'` formats, or the word `'current'`, in which
         | 
| 295 295 | 
             
            # case the current timezone of the evaluating process will be used. The timezone argument is case insensitive.
         | 
| 296 296 | 
             
            #
         | 
| 297 297 | 
             
            # The default timezone, when no argument is provided, or when using the keyword `default`, is 'UTC'.
         | 
| @@ -336,7 +336,7 @@ | |
| 336 336 | 
             
            # | 0     | Use zeros for padding
         | 
| 337 337 | 
             
            # | #     | Change names to upper-case or change case of am/pm
         | 
| 338 338 | 
             
            # | ^     | Use uppercase
         | 
| 339 | 
            -
            # | :     | Use colons for  | 
| 339 | 
            +
            # | :     | Use colons for `%z`
         | 
| 340 340 | 
             
            #
         | 
| 341 341 | 
             
            # ##### Format directives (names and padding can be altered using flags):
         | 
| 342 342 | 
             
            #
         | 
| @@ -345,48 +345,48 @@ | |
| 345 345 | 
             
            # | Format | Meaning |
         | 
| 346 346 | 
             
            # | ------ | ------- |
         | 
| 347 347 | 
             
            # | Y | Year with century, zero-padded to at least 4 digits |
         | 
| 348 | 
            -
            # | C | year / 100 (rounded down such as 20 in 2009) |
         | 
| 349 | 
            -
            # | y | year % 100 (00..99) |
         | 
| 350 | 
            -
            # | m | Month of the year, zero-padded (01..12) |
         | 
| 351 | 
            -
            # | B | The full month name ("January") |
         | 
| 352 | 
            -
            # | b | The abbreviated month name ("Jan") |
         | 
| 353 | 
            -
            # | h | Equivalent to  | 
| 354 | 
            -
            # | d | Day of the month, zero-padded (01..31) |
         | 
| 355 | 
            -
            # | e | Day of the month, blank-padded ( | 
| 356 | 
            -
            # | j | Day of the year (001..366) |
         | 
| 348 | 
            +
            # | C | year / 100 (rounded down such as `20` in `2009`) |
         | 
| 349 | 
            +
            # | y | year % 100 (`00..99`) |
         | 
| 350 | 
            +
            # | m | Month of the year, zero-padded (`01..12`) |
         | 
| 351 | 
            +
            # | B | The full month name (`"January"`) |
         | 
| 352 | 
            +
            # | b | The abbreviated month name (`"Jan"`) |
         | 
| 353 | 
            +
            # | h | Equivalent to `%b` |
         | 
| 354 | 
            +
            # | d | Day of the month, zero-padded (`01..31`) |
         | 
| 355 | 
            +
            # | e | Day of the month, blank-padded (`1..31`) |
         | 
| 356 | 
            +
            # | j | Day of the year (`001..366`) |
         | 
| 357 357 | 
             
            #
         | 
| 358 358 | 
             
            # **Time (Hour, Minute, Second, Subsecond):**
         | 
| 359 359 | 
             
            #
         | 
| 360 360 | 
             
            # | Format | Meaning |
         | 
| 361 361 | 
             
            # | ------ | ------- |
         | 
| 362 | 
            -
            # | H | Hour of the day, 24-hour clock, zero-padded (00..23) |
         | 
| 363 | 
            -
            # | k | Hour of the day, 24-hour clock, blank-padded ( | 
| 364 | 
            -
            # | I | Hour of the day, 12-hour clock, zero-padded (01..12) |
         | 
| 365 | 
            -
            # | l | Hour of the day, 12-hour clock, blank-padded ( | 
| 366 | 
            -
            # | P | Meridian indicator, lowercase ("am" or "pm") |
         | 
| 367 | 
            -
            # | p | Meridian indicator, uppercase ("AM" or "PM") |
         | 
| 368 | 
            -
            # | M | Minute of the hour (00..59) |
         | 
| 369 | 
            -
            # | S | Second of the minute (00..60) |
         | 
| 370 | 
            -
            # | L | Millisecond of the second (000..999). Digits under millisecond are truncated to not produce 1000 |
         | 
| 362 | 
            +
            # | H | Hour of the day, 24-hour clock, zero-padded (`00..23`) |
         | 
| 363 | 
            +
            # | k | Hour of the day, 24-hour clock, blank-padded (`0..23`) |
         | 
| 364 | 
            +
            # | I | Hour of the day, 12-hour clock, zero-padded (`01..12`) |
         | 
| 365 | 
            +
            # | l | Hour of the day, 12-hour clock, blank-padded (`1..12`) |
         | 
| 366 | 
            +
            # | P | Meridian indicator, lowercase (`"am"` or `"pm"`) |
         | 
| 367 | 
            +
            # | p | Meridian indicator, uppercase (`"AM"` or `"PM"`) |
         | 
| 368 | 
            +
            # | M | Minute of the hour (`00..59`) |
         | 
| 369 | 
            +
            # | S | Second of the minute (`00..60`) |
         | 
| 370 | 
            +
            # | L | Millisecond of the second (`000..999`). Digits under millisecond are truncated to not produce 1000 |
         | 
| 371 371 | 
             
            # | N | Fractional seconds digits, default is 9 digits (nanosecond). Digits under a specified width are truncated to avoid carry up |
         | 
| 372 372 | 
             
            #
         | 
| 373 373 | 
             
            # **Time (Hour, Minute, Second, Subsecond):**
         | 
| 374 374 | 
             
            #
         | 
| 375 375 | 
             
            # | Format | Meaning |
         | 
| 376 376 | 
             
            # | ------ | ------- |
         | 
| 377 | 
            -
            # | z   | Time zone as hour and minute offset from UTC (e.g.  | 
| 378 | 
            -
            # | :z  | hour and minute offset from UTC with a colon (e.g.  | 
| 379 | 
            -
            # | ::z | hour, minute and second offset from UTC (e.g.  | 
| 377 | 
            +
            # | z   | Time zone as hour and minute offset from UTC (e.g. `+0900`) |
         | 
| 378 | 
            +
            # | :z  | hour and minute offset from UTC with a colon (e.g. `+09:00`) |
         | 
| 379 | 
            +
            # | ::z | hour, minute and second offset from UTC (e.g. `+09:00:00`) |
         | 
| 380 380 | 
             
            # | Z   | Abbreviated time zone name or similar information.  (OS dependent) |
         | 
| 381 381 | 
             
            #
         | 
| 382 382 | 
             
            # **Weekday:**
         | 
| 383 383 | 
             
            #
         | 
| 384 384 | 
             
            # | Format | Meaning |
         | 
| 385 385 | 
             
            # | ------ | ------- |
         | 
| 386 | 
            -
            # | A | The full weekday name ("Sunday") |
         | 
| 387 | 
            -
            # | a | The abbreviated name ("Sun") |
         | 
| 388 | 
            -
            # | u | Day of the week (Monday is 1 | 
| 389 | 
            -
            # | w | Day of the week (Sunday is 0 | 
| 386 | 
            +
            # | A | The full weekday name (`"Sunday"`) |
         | 
| 387 | 
            +
            # | a | The abbreviated name (`"Sun"`) |
         | 
| 388 | 
            +
            # | u | Day of the week (Monday is `1`, `1..7`) |
         | 
| 389 | 
            +
            # | w | Day of the week (Sunday is `0`, `0..6`) |
         | 
| 390 390 | 
             
            #
         | 
| 391 391 | 
             
            # **ISO 8601 week-based year and week number:**
         | 
| 392 392 | 
             
            #
         | 
| @@ -397,8 +397,8 @@ | |
| 397 397 | 
             
            # | Format | Meaning |
         | 
| 398 398 | 
             
            # | ------ | ------- |
         | 
| 399 399 | 
             
            # | G | The week-based year |
         | 
| 400 | 
            -
            # | g | The last 2 digits of the week-based year (00..99) |
         | 
| 401 | 
            -
            # | V | Week number of the week-based year (01..53) |
         | 
| 400 | 
            +
            # | g | The last 2 digits of the week-based year (`00..99`) |
         | 
| 401 | 
            +
            # | V | Week number of the week-based year (`01..53`) |
         | 
| 402 402 | 
             
            #
         | 
| 403 403 | 
             
            # **Week number:**
         | 
| 404 404 | 
             
            #
         | 
| @@ -407,8 +407,8 @@ | |
| 407 407 | 
             
            #
         | 
| 408 408 | 
             
            # | Format | Meaning |
         | 
| 409 409 | 
             
            # | ------ | ------- |
         | 
| 410 | 
            -
            # | U | Week number of the year. The week starts with Sunday. (00..53) |
         | 
| 411 | 
            -
            # | W | Week number of the year. The week starts with Monday. (00..53) |
         | 
| 410 | 
            +
            # | U | Week number of the year. The week starts with Sunday. (`00..53`) |
         | 
| 411 | 
            +
            # | W | Week number of the year. The week starts with Monday. (`00..53`) |
         | 
| 412 412 | 
             
            #
         | 
| 413 413 | 
             
            # **Seconds since the Epoch:**
         | 
| 414 414 | 
             
            #
         | 
| @@ -419,23 +419,23 @@ | |
| 419 419 | 
             
            #
         | 
| 420 420 | 
             
            # | Format | Meaning |
         | 
| 421 421 | 
             
            # | ------ | ------- |
         | 
| 422 | 
            -
            # | n | Newline character ( | 
| 423 | 
            -
            # | t | Tab character ( | 
| 424 | 
            -
            # | % | Literal  | 
| 422 | 
            +
            # | n | Newline character (`\n`) |
         | 
| 423 | 
            +
            # | t | Tab character (`\t`) |
         | 
| 424 | 
            +
            # | % | Literal `%` character |
         | 
| 425 425 | 
             
            #
         | 
| 426 426 | 
             
            # **Combination:**
         | 
| 427 427 | 
             
            #
         | 
| 428 428 | 
             
            # | Format | Meaning |
         | 
| 429 429 | 
             
            # | ------ | ------- |
         | 
| 430 | 
            -
            # | c | date and time ( | 
| 431 | 
            -
            # | D | Date ( | 
| 432 | 
            -
            # | F | The ISO 8601 date format ( | 
| 433 | 
            -
            # | v | VMS date ( | 
| 434 | 
            -
            # | x | Same as  | 
| 435 | 
            -
            # | X | Same as  | 
| 436 | 
            -
            # | r | 12-hour time ( | 
| 437 | 
            -
            # | R | 24-hour time ( | 
| 438 | 
            -
            # | T | 24-hour time ( | 
| 430 | 
            +
            # | c | date and time (`%a %b %e %T %Y`) |
         | 
| 431 | 
            +
            # | D | Date (`%m/%d/%y`) |
         | 
| 432 | 
            +
            # | F | The ISO 8601 date format (`%Y-%m-%d`) |
         | 
| 433 | 
            +
            # | v | VMS date (`%e-%^b-%4Y`) |
         | 
| 434 | 
            +
            # | x | Same as `%D` |
         | 
| 435 | 
            +
            # | X | Same as `%T` |
         | 
| 436 | 
            +
            # | r | 12-hour time (`%I:%M:%S %p`) |
         | 
| 437 | 
            +
            # | R | 24-hour time (`%H:%M`) |
         | 
| 438 | 
            +
            # | T | 24-hour time (`%H:%M:%S`) |
         | 
| 439 439 | 
             
            #
         | 
| 440 440 | 
             
            # The default array contains the following patterns:
         | 
| 441 441 | 
             
            #
         | 
| @@ -489,7 +489,7 @@ | |
| 489 489 | 
             
            # The mapping from data type to format is referred to as the *format map*. This map
         | 
| 490 490 | 
             
            # allows different formatting depending on type.
         | 
| 491 491 | 
             
            #
         | 
| 492 | 
            -
            # @example Positive Integers in Hexadecimal prefixed with '0x' | 
| 492 | 
            +
            # @example Positive Integers in Hexadecimal prefixed with `'0x'`, negative in Decimal
         | 
| 493 493 | 
             
            #
         | 
| 494 494 | 
             
            # ```puppet
         | 
| 495 495 | 
             
            # $format_map = {
         | 
| @@ -578,13 +578,13 @@ | |
| 578 578 | 
             
            #
         | 
| 579 579 | 
             
            # | Format  | Integer Formats
         | 
| 580 580 | 
             
            # | ------  | ---------------
         | 
| 581 | 
            -
            # | d       | Decimal, negative values produces leading  | 
| 582 | 
            -
            # | x X     | Hexadecimal in lower or upper case. Uses  | 
| 583 | 
            -
            # | o       | Octal. Uses  | 
| 584 | 
            -
            # | b B     | Binary with prefix  | 
| 585 | 
            -
            # | c       | Numeric value representing a Unicode value, result is a one unicode character string, quoted if alternative flag  | 
| 586 | 
            -
            # | s       | Same as d | 
| 587 | 
            -
            # | p       | Same as d | 
| 581 | 
            +
            # | d       | Decimal, negative values produces leading `-`.
         | 
| 582 | 
            +
            # | x X     | Hexadecimal in lower or upper case. Uses `..f/..F` for negative values unless `+` is also used. A `#` adds prefix `0x/0X`.
         | 
| 583 | 
            +
            # | o       | Octal. Uses `..0` for negative values unless `+` is also used. A `#` adds prefix `0`.
         | 
| 584 | 
            +
            # | b B     | Binary with prefix `b` or `B`. Uses `..1/..1` for negative values unless `+` is also used.
         | 
| 585 | 
            +
            # | c       | Numeric value representing a Unicode value, result is a one unicode character string, quoted if alternative flag `#` is used
         | 
| 586 | 
            +
            # | s       | Same as `d`, or `d` in quotes if alternative flag `#` is used.
         | 
| 587 | 
            +
            # | p       | Same as `d`.
         | 
| 588 588 | 
             
            # | eEfgGaA | Converts integer to float and formats using the floating point rules.
         | 
| 589 589 | 
             
            #
         | 
| 590 590 | 
             
            # Defaults to `d`.
         | 
| @@ -594,11 +594,11 @@ | |
| 594 594 | 
             
            # | Format  | Float formats
         | 
| 595 595 | 
             
            # | ------  | -------------
         | 
| 596 596 | 
             
            # | f       | Floating point in non exponential notation.
         | 
| 597 | 
            -
            # | e E     | Exponential notation with  | 
| 598 | 
            -
            # | g G     | Conditional exponential with  | 
| 599 | 
            -
            # | a A     | Hexadecimal exponential form, using  | 
| 600 | 
            -
            # | s       | Converted to string using format p | 
| 601 | 
            -
            # | p       | Same as f format with minimum significant number of fractional digits, prec has no effect.
         | 
| 597 | 
            +
            # | e E     | Exponential notation with `e` or `E`.
         | 
| 598 | 
            +
            # | g G     | Conditional exponential with `e` or `E` if exponent `< -4` or `>=` the precision.
         | 
| 599 | 
            +
            # | a A     | Hexadecimal exponential form, using `x`/`X` as prefix and `p`/`P` before exponent.
         | 
| 600 | 
            +
            # | s       | Converted to string using format `p`, then applying string formatting rule, alternate form `#`` quotes result.
         | 
| 601 | 
            +
            # | p       | Same as `f` format with minimum significant number of fractional digits, prec has no effect.
         | 
| 602 602 | 
             
            # | dxXobBc | Converts float to integer and formats using the integer rules.
         | 
| 603 603 | 
             
            #
         | 
| 604 604 | 
             
            # Defaults to `p`.
         | 
| @@ -621,12 +621,12 @@ | |
| 621 621 | 
             
            #
         | 
| 622 622 | 
             
            # | Format    | Boolean Formats
         | 
| 623 623 | 
             
            # | ----      | -------------------
         | 
| 624 | 
            -
            # | t T       | String 'true'/'false' or 'True'/'False' | 
| 625 | 
            -
            # | y Y       | String 'yes'/'no' | 
| 626 | 
            -
            # | dxXobB    | Numeric value 0/1 in accordance with the given format which must be valid integer format.
         | 
| 627 | 
            -
            # | eEfgGaA   | Numeric value 0.0/1.0 in accordance with the given float format and flags.
         | 
| 628 | 
            -
            # | s         | String 'true' / 'false' | 
| 629 | 
            -
            # | p         | String 'true' / 'false' | 
| 624 | 
            +
            # | t T       | String `'true'/'false'` or `'True'/'False'`, first char if alternate form is used (i.e. `'t'/'f'` or `'T'/'F'`).
         | 
| 625 | 
            +
            # | y Y       | String `'yes'/'no'`, `'Yes'/'No'`, `'y'/'n'` or `'Y'/'N'` if alternative flag `#` is used.
         | 
| 626 | 
            +
            # | dxXobB    | Numeric value `0/1` in accordance with the given format which must be valid integer format.
         | 
| 627 | 
            +
            # | eEfgGaA   | Numeric value `0.0/1.0` in accordance with the given float format and flags.
         | 
| 628 | 
            +
            # | s         | String `'true'` / `'false'`.
         | 
| 629 | 
            +
            # | p         | String `'true'` / `'false'`.
         | 
| 630 630 | 
             
            #
         | 
| 631 631 | 
             
            # **Regexp to String**
         | 
| 632 632 | 
             
            #
         | 
| @@ -640,33 +640,33 @@ | |
| 640 640 | 
             
            # | Format    | Undef formats
         | 
| 641 641 | 
             
            # | ------    | -------------
         | 
| 642 642 | 
             
            # | s         | Empty string, or quoted empty string if alternative flag `#` is used.
         | 
| 643 | 
            -
            # | p         | String 'undef' | 
| 644 | 
            -
            # | n         | String 'nil' | 
| 645 | 
            -
            # | dxXobB    | String 'NaN' | 
| 646 | 
            -
            # | eEfgGaA   | String 'NaN' | 
| 647 | 
            -
            # | v         | String 'n/a' | 
| 648 | 
            -
            # | V         | String 'N/A' | 
| 649 | 
            -
            # | u         | String 'undef' | 
| 643 | 
            +
            # | p         | String `'undef'`, or quoted `'"undef"'` if alternative flag `#` is used.
         | 
| 644 | 
            +
            # | n         | String `'nil'`, or `'null'` if alternative flag `#` is used.
         | 
| 645 | 
            +
            # | dxXobB    | String `'NaN'`.
         | 
| 646 | 
            +
            # | eEfgGaA   | String `'NaN'`.
         | 
| 647 | 
            +
            # | v         | String `'n/a'`.
         | 
| 648 | 
            +
            # | V         | String `'N/A'`.
         | 
| 649 | 
            +
            # | u         | String `'undef'`, or `'undefined'` if alternative `#` flag is used.
         | 
| 650 650 | 
             
            #
         | 
| 651 651 | 
             
            # **Default value to String**
         | 
| 652 652 | 
             
            #
         | 
| 653 653 | 
             
            # | Format    | Default formats
         | 
| 654 654 | 
             
            # | ------    | ---------------
         | 
| 655 | 
            -
            # | d D       | String 'default' or 'Default' | 
| 656 | 
            -
            # | s         | Same as d | 
| 657 | 
            -
            # | p         | Same as d | 
| 655 | 
            +
            # | d D       | String `'default'` or `'Default'`, alternative form `#` causes value to be quoted.
         | 
| 656 | 
            +
            # | s         | Same as `d`.
         | 
| 657 | 
            +
            # | p         | Same as `d`.
         | 
| 658 658 | 
             
            #
         | 
| 659 659 | 
             
            # **Binary value to String**
         | 
| 660 660 | 
             
            #
         | 
| 661 661 | 
             
            # | Format    | Default formats
         | 
| 662 662 | 
             
            # | ------    | ---------------
         | 
| 663 663 | 
             
            # | s         | binary as unquoted UTF-8 characters (errors if byte sequence is invalid UTF-8). Alternate form escapes non ascii bytes.
         | 
| 664 | 
            -
            # | p         | 'Binary("<base64strict>")'
         | 
| 665 | 
            -
            # | b         | '<base64>' - base64 string with newlines inserted
         | 
| 666 | 
            -
            # | B         | '<base64strict>' - base64 strict string (without newlines inserted)
         | 
| 667 | 
            -
            # | u         | '<base64urlsafe>' - base64 urlsafe string
         | 
| 668 | 
            -
            # | t         | 'Binary' - outputs the name of the type only
         | 
| 669 | 
            -
            # | T         | 'BINARY' - output the name of the type in all caps only
         | 
| 664 | 
            +
            # | p         | `'Binary("<base64strict>")'`
         | 
| 665 | 
            +
            # | b         | `'<base64>'` - base64 string with newlines inserted
         | 
| 666 | 
            +
            # | B         | `'<base64strict>'` - base64 strict string (without newlines inserted)
         | 
| 667 | 
            +
            # | u         | `'<base64urlsafe>'` - base64 urlsafe string
         | 
| 668 | 
            +
            # | t         | `'Binary'` - outputs the name of the type only
         | 
| 669 | 
            +
            # | T         | `'BINARY'` - output the name of the type in all caps only
         | 
| 670 670 | 
             
            #
         | 
| 671 671 | 
             
            # * The alternate form flag `#` will quote the binary or base64 text output.
         | 
| 672 672 | 
             
            # * The format `%#s` allows invalid UTF-8 characters and outputs all non ascii bytes
         | 
| @@ -678,8 +678,8 @@ | |
| 678 678 | 
             
            # | Format    | Array/Tuple Formats
         | 
| 679 679 | 
             
            # | ------    | -------------
         | 
| 680 680 | 
             
            # | a         | Formats with `[ ]` delimiters and `,`, alternate form `#` indents nested arrays/hashes.
         | 
| 681 | 
            -
            # | s         | Same as a | 
| 682 | 
            -
            # | p         | Same as a | 
| 681 | 
            +
            # | s         | Same as `a`.
         | 
| 682 | 
            +
            # | p         | Same as `a`.
         | 
| 683 683 | 
             
            #
         | 
| 684 684 | 
             
            # See "Flags" `<[({\|` for formatting of delimiters, and "Additional parameters for containers; Array and Hash" for
         | 
| 685 685 | 
             
            # more information about options.
         | 
| @@ -695,7 +695,7 @@ | |
| 695 695 | 
             
            # | h         | Formats with `{ }` delimiters, `,` element separator and ` => ` inner element separator unless overridden by flags.
         | 
| 696 696 | 
             
            # | s         | Same as h.
         | 
| 697 697 | 
             
            # | p         | Same as h.
         | 
| 698 | 
            -
            # | a         | Converts the hash to an array of [k,v] tuples and formats it using array rule(s).
         | 
| 698 | 
            +
            # | a         | Converts the hash to an array of `[k,v]` tuples and formats it using array rule(s).
         | 
| 699 699 | 
             
            #
         | 
| 700 700 | 
             
            # See "Flags" `<[({\|` for formatting of delimiters, and "Additional parameters for containers; Array and Hash" for
         | 
| 701 701 | 
             
            # more information about options.
         | 
| @@ -714,18 +714,18 @@ | |
| 714 714 | 
             
            # | Flag     | Effect
         | 
| 715 715 | 
             
            # | ------   | ------
         | 
| 716 716 | 
             
            # | (space)  | A space instead of `+` for numeric output (`-` is shown), for containers skips delimiters.
         | 
| 717 | 
            -
            # | #        | Alternate format; prefix 0x/0x | 
| 718 | 
            -
            # | +        | Show sign  | 
| 717 | 
            +
            # | #        | Alternate format; prefix `0x/0x`, `0` (octal) and `0b/0B` for binary, Floats force decimal '.'. For g/G keep trailing `0`.
         | 
| 718 | 
            +
            # | +        | Show sign `+/-` depending on value's sign, changes `x`, `X`, `o`, `b`, `B` format to not use 2's complement form.
         | 
| 719 719 | 
             
            # | -        | Left justify the value in the given width.
         | 
| 720 | 
            -
            # | 0        | Pad with 0 instead of space for widths larger than value.
         | 
| 721 | 
            -
            # | <[({\|   | Defines an enclosing pair  | 
| 720 | 
            +
            # | 0        | Pad with `0` instead of space for widths larger than value.
         | 
| 721 | 
            +
            # | <[({\|   | Defines an enclosing pair `<> [] () {} or \| \|` when used with a container type.
         | 
| 722 722 | 
             
            #
         | 
| 723 723 | 
             
            # ### Conversion to Boolean
         | 
| 724 724 | 
             
            #
         | 
| 725 725 | 
             
            # Accepts a single value as argument:
         | 
| 726 726 | 
             
            #
         | 
| 727 | 
            -
            # * Float 0.0 is `false`, all other float values are `true`
         | 
| 728 | 
            -
            # * Integer 0 is `false`, all other integer values are `true`
         | 
| 727 | 
            +
            # * Float `0.0` is `false`, all other float values are `true`
         | 
| 728 | 
            +
            # * Integer `0` is `false`, all other integer values are `true`
         | 
| 729 729 | 
             
            # * Strings
         | 
| 730 730 | 
             
            #   * `true` if 'true', 'yes', 'y' (case independent compare)
         | 
| 731 731 | 
             
            #   * `false` if 'false', 'no', 'n' (case independent compare)
         | 
| @@ -840,7 +840,7 @@ | |
| 840 840 | 
             
            # function SemVer.new(SemVerHash $hash_args)
         | 
| 841 841 | 
             
            # ```
         | 
| 842 842 | 
             
            #
         | 
| 843 | 
            -
            # @example SemVer and SemVerRange usage
         | 
| 843 | 
            +
            # @example `SemVer` and `SemVerRange` usage
         | 
| 844 844 | 
             
            #
         | 
| 845 845 | 
             
            # ```puppet
         | 
| 846 846 | 
             
            # # As a type, SemVer can describe disjunct ranges which versions can be
         | 
| @@ -856,7 +856,7 @@ | |
| 856 856 | 
             
            # notice(SemVer('3.4.5') =~ $t) # true
         | 
| 857 857 | 
             
            # ```
         | 
| 858 858 | 
             
            #
         | 
| 859 | 
            -
            # ### Creating a SemVerRange
         | 
| 859 | 
            +
            # ### Creating a `SemVerRange`
         | 
| 860 860 | 
             
            #
         | 
| 861 861 | 
             
            # A `SemVerRange` object represents a range of `SemVer`. It can be created from
         | 
| 862 862 | 
             
            # a `String`, or from two `SemVer` instances, where either end can be given as
         | 
| @@ -4,14 +4,22 @@ | |
| 4 4 | 
             
            # the second containing the rest.
         | 
| 5 5 | 
             
            Puppet::Functions.create_function(:partition) do
         | 
| 6 6 | 
             
              # @param collection A collection of things to partition.
         | 
| 7 | 
            -
              # @example Partition array of empty strings, results in e.g. [[''], [b, c]]
         | 
| 7 | 
            +
              # @example Partition array of empty strings, results in e.g. `[[''], [b, c]]`
         | 
| 8 | 
            +
              #   ```puppet
         | 
| 8 9 | 
             
              #   ['', b, c].partition |$s| { $s.empty }
         | 
| 9 | 
            -
              # | 
| 10 | 
            +
              #   ```
         | 
| 11 | 
            +
              # @example Partition array of strings using index, results in e.g. `[['', 'ab'], ['b']]`
         | 
| 12 | 
            +
              #   ```puppet
         | 
| 10 13 | 
             
              #   ['', b, ab].partition |$i, $s| { $i == 2 or $s.empty }
         | 
| 11 | 
            -
              # | 
| 14 | 
            +
              #   ```
         | 
| 15 | 
            +
              # @example Partition hash of strings by key-value pair, results in e.g. `[[['b', []]], [['a', [1, 2]]]]`
         | 
| 16 | 
            +
              #   ```puppet
         | 
| 12 17 | 
             
              #   { a => [1, 2], b => [] }.partition |$kv| { $kv[1].empty }
         | 
| 13 | 
            -
              # | 
| 18 | 
            +
              #   ```
         | 
| 19 | 
            +
              # @example Partition hash of strings by key and value, results in e.g. `[[['b', []]], [['a', [1, 2]]]]`
         | 
| 20 | 
            +
              #   ```puppet
         | 
| 14 21 | 
             
              #   { a => [1, 2], b => [] }.partition |$k, $v| { $v.empty }
         | 
| 22 | 
            +
              #   ```
         | 
| 15 23 | 
             
              dispatch :partition_1 do
         | 
| 16 24 | 
             
                required_param 'Collection', :collection
         | 
| 17 25 | 
             
                block_param 'Callable[1,1]', :block
         |