puppet 4.7.1-x86-mingw32 → 4.8.0-x86-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.
- data/Gemfile +0 -3
- data/MAINTAINERS +76 -0
- data/README.md +0 -6
- data/Rakefile +2 -2
- data/lib/puppet/agent.rb +3 -3
- data/lib/puppet/application/apply.rb +1 -1
- data/lib/puppet/configurer.rb +2 -2
- data/lib/puppet/data_providers.rb +1 -0
- data/lib/puppet/data_providers/data_adapter.rb +1 -0
- data/lib/puppet/data_providers/data_function_support.rb +1 -0
- data/lib/puppet/data_providers/function_env_data_provider.rb +1 -0
- data/lib/puppet/data_providers/function_module_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_config.rb +1 -0
- data/lib/puppet/data_providers/hiera_env_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_interpolate.rb +1 -0
- data/lib/puppet/data_providers/hiera_module_data_provider.rb +1 -0
- data/lib/puppet/data_providers/hiera_support.rb +1 -2
- data/lib/puppet/data_providers/json_data_provider_factory.rb +2 -0
- data/lib/puppet/data_providers/yaml_data_provider_factory.rb +2 -0
- data/lib/puppet/defaults.rb +20 -1
- data/lib/puppet/environments.rb +5 -2
- data/lib/puppet/face/catalog.rb +1 -1
- data/lib/puppet/face/epp.rb +57 -11
- data/lib/puppet/face/module/install.rb +6 -6
- data/lib/puppet/functions.rb +23 -24
- data/lib/puppet/functions/alert.rb +14 -0
- data/lib/puppet/functions/binary_file.rb +25 -0
- data/lib/puppet/functions/break.rb +22 -0
- data/lib/puppet/functions/contain.rb +33 -0
- data/lib/puppet/functions/crit.rb +14 -0
- data/lib/puppet/functions/debug.rb +14 -0
- data/lib/puppet/functions/emerg.rb +14 -0
- data/lib/puppet/functions/epp.rb +1 -1
- data/lib/puppet/functions/err.rb +14 -0
- data/lib/puppet/functions/find_file.rb +31 -0
- data/lib/puppet/functions/include.rb +21 -0
- data/lib/puppet/functions/info.rb +14 -0
- data/lib/puppet/functions/new.rb +1 -1
- data/lib/puppet/functions/next.rb +23 -0
- data/lib/puppet/functions/notice.rb +14 -0
- data/lib/puppet/functions/regsubst.rb +12 -16
- data/lib/puppet/functions/require.rb +37 -0
- data/lib/puppet/functions/return.rb +22 -0
- data/lib/puppet/functions/strftime.rb +35 -0
- data/lib/puppet/functions/warning.rb +14 -0
- data/lib/puppet/generate/models/type/type.rb +4 -0
- data/lib/puppet/generate/templates/type/pcore.erb +2 -1
- data/lib/puppet/indirector/face.rb +6 -1
- data/lib/puppet/network/http/error.rb +2 -2
- data/lib/puppet/network/http/handler.rb +2 -2
- data/lib/puppet/node/environment.rb +11 -0
- data/lib/puppet/parser/ast.rb +5 -0
- data/lib/puppet/parser/ast/pops_bridge.rb +17 -4
- data/lib/puppet/parser/compiler.rb +29 -1
- data/lib/puppet/parser/functions.rb +6 -0
- data/lib/puppet/parser/functions/assert_type.rb +1 -1
- data/lib/puppet/parser/functions/binary_file.rb +24 -0
- data/lib/puppet/parser/functions/break.rb +39 -0
- data/lib/puppet/parser/functions/contain.rb +7 -15
- data/lib/puppet/parser/functions/defined.rb +2 -2
- data/lib/puppet/parser/functions/dig.rb +1 -1
- data/lib/puppet/parser/functions/each.rb +1 -1
- data/lib/puppet/parser/functions/epp.rb +2 -2
- data/lib/puppet/parser/functions/filter.rb +1 -1
- data/lib/puppet/parser/functions/find_file.rb +28 -0
- data/lib/puppet/parser/functions/hiera.rb +4 -4
- data/lib/puppet/parser/functions/hiera_array.rb +1 -1
- data/lib/puppet/parser/functions/hiera_hash.rb +1 -1
- data/lib/puppet/parser/functions/hiera_include.rb +1 -1
- data/lib/puppet/parser/functions/include.rb +4 -8
- data/lib/puppet/parser/functions/inline_epp.rb +1 -1
- data/lib/puppet/parser/functions/lest.rb +1 -1
- data/lib/puppet/parser/functions/lookup.rb +4 -2
- data/lib/puppet/parser/functions/map.rb +1 -1
- data/lib/puppet/parser/functions/match.rb +1 -1
- data/lib/puppet/parser/functions/new.rb +414 -18
- data/lib/puppet/parser/functions/next.rb +38 -0
- data/lib/puppet/parser/functions/reduce.rb +1 -1
- data/lib/puppet/parser/functions/regsubst.rb +4 -2
- data/lib/puppet/parser/functions/require.rb +4 -27
- data/lib/puppet/parser/functions/return.rb +71 -0
- data/lib/puppet/parser/functions/reverse_each.rb +1 -1
- data/lib/puppet/parser/functions/scanf.rb +13 -8
- data/lib/puppet/parser/functions/slice.rb +1 -1
- data/lib/puppet/parser/functions/split.rb +1 -1
- data/lib/puppet/parser/functions/step.rb +1 -1
- data/lib/puppet/parser/functions/strftime.rb +185 -0
- data/lib/puppet/parser/functions/then.rb +1 -1
- data/lib/puppet/parser/functions/type.rb +1 -1
- data/lib/puppet/parser/functions/with.rb +3 -3
- data/lib/puppet/parser/resource.rb +8 -5
- data/lib/puppet/parser/scope.rb +1 -1
- data/lib/puppet/plugins/configuration.rb +8 -0
- data/lib/puppet/plugins/data_providers.rb +1 -0
- data/lib/puppet/plugins/data_providers/data_provider.rb +7 -28
- data/lib/puppet/plugins/data_providers/registry.rb +1 -0
- data/lib/puppet/pops.rb +4 -0
- data/lib/puppet/pops/evaluator/access_operator.rb +36 -5
- data/lib/puppet/pops/evaluator/closure.rb +81 -12
- data/lib/puppet/pops/evaluator/compare_operator.rb +24 -1
- data/lib/puppet/pops/evaluator/evaluator_impl.rb +29 -5
- data/lib/puppet/pops/evaluator/json_strict_literal_evaluator.rb +1 -1
- data/lib/puppet/pops/evaluator/runtime3_converter.rb +53 -62
- data/lib/puppet/pops/evaluator/runtime3_support.rb +15 -6
- data/lib/puppet/pops/functions/dispatch.rb +9 -2
- data/lib/puppet/pops/functions/dispatcher.rb +3 -1
- data/lib/puppet/pops/functions/function.rb +19 -2
- data/lib/puppet/pops/issues.rb +9 -0
- data/lib/puppet/pops/label_provider.rb +2 -2
- data/lib/puppet/pops/loader/loader.rb +17 -0
- data/lib/puppet/pops/loader/static_loader.rb +0 -41
- data/lib/puppet/pops/lookup.rb +12 -0
- data/lib/puppet/pops/lookup/context.rb +86 -0
- data/lib/puppet/pops/lookup/explainer.rb +46 -6
- data/lib/puppet/pops/lookup/invocation.rb +19 -0
- data/lib/puppet/pops/lookup/sub_lookup.rb +1 -1
- data/lib/puppet/pops/model/factory.rb +20 -8
- data/lib/puppet/pops/model/model_label_provider.rb +3 -0
- data/lib/puppet/pops/model/model_meta.rb +2 -0
- data/lib/puppet/pops/model/model_tree_dumper.rb +14 -0
- data/lib/puppet/pops/parser/egrammar.ra +11 -6
- data/lib/puppet/pops/parser/eparser.rb +1112 -1086
- data/lib/puppet/pops/parser/heredoc_support.rb +1 -2
- data/lib/puppet/pops/pcore.rb +1 -0
- data/lib/puppet/pops/puppet_stack.rb +3 -3
- data/lib/puppet/pops/resource/param.rb +5 -1
- data/lib/puppet/pops/resource/resource_type_impl.rb +8 -4
- data/lib/puppet/pops/resource/resource_type_set.pcore +1 -0
- data/lib/puppet/pops/serialization/abstract_reader.rb +19 -2
- data/lib/puppet/pops/serialization/abstract_writer.rb +16 -3
- data/lib/puppet/pops/serialization/deserializer.rb +5 -1
- data/lib/puppet/pops/serialization/extension.rb +2 -0
- data/lib/puppet/pops/serialization/json.rb +76 -26
- data/lib/puppet/pops/serialization/serializer.rb +5 -1
- data/lib/puppet/pops/serialization/time_factory.rb +2 -1
- data/lib/puppet/pops/time/timespan.rb +718 -0
- data/lib/puppet/pops/time/timestamp.rb +148 -0
- data/lib/puppet/pops/types/p_binary_type.rb +220 -0
- data/lib/puppet/pops/types/p_object_type.rb +12 -6
- data/lib/puppet/pops/types/p_sensitive_type.rb +5 -1
- data/lib/puppet/pops/types/p_timespan_type.rb +141 -0
- data/lib/puppet/pops/types/p_timestamp_type.rb +69 -0
- data/lib/puppet/pops/types/string_converter.rb +62 -0
- data/lib/puppet/pops/types/type_asserter.rb +1 -1
- data/lib/puppet/pops/types/type_calculator.rb +17 -3
- data/lib/puppet/pops/types/type_factory.rb +35 -1
- data/lib/puppet/pops/types/type_formatter.rb +64 -11
- data/lib/puppet/pops/types/type_mismatch_describer.rb +110 -61
- data/lib/puppet/pops/types/type_parser.rb +18 -4
- data/lib/puppet/pops/types/types.rb +98 -63
- data/lib/puppet/pops/validation.rb +9 -1
- data/lib/puppet/pops/validation/checker4_0.rb +7 -0
- data/lib/puppet/property.rb +1 -1
- data/lib/puppet/provider.rb +3 -6
- data/lib/puppet/provider/mcx/mcxcontent.rb +1 -1
- data/lib/puppet/provider/mount/parsed.rb +18 -4
- data/lib/puppet/provider/nameservice/directoryservice.rb +15 -7
- data/lib/puppet/provider/package/gem.rb +6 -1
- data/lib/puppet/provider/package/pip.rb +0 -1
- data/lib/puppet/provider/package/pkg.rb +5 -1
- data/lib/puppet/provider/package/pkgng.rb +1 -1
- data/lib/puppet/provider/package/yum.rb +10 -0
- data/lib/puppet/provider/service/launchd.rb +1 -0
- data/lib/puppet/provider/user/directoryservice.rb +6 -6
- data/lib/puppet/provider/yumrepo/inifile.rb +1 -1
- data/lib/puppet/provider/zpool/zpool.rb +1 -1
- data/lib/puppet/resource.rb +54 -12
- data/lib/puppet/resource/capability_finder.rb +15 -9
- data/lib/puppet/resource/catalog.rb +25 -6
- data/lib/puppet/resource/type.rb +3 -1
- data/lib/puppet/settings.rb +1 -1
- data/lib/puppet/settings/environment_conf.rb +12 -4
- data/lib/puppet/syntax_checkers/base64.rb +41 -0
- data/lib/puppet/syntax_checkers/json.rb +0 -2
- data/lib/puppet/transaction.rb +6 -0
- data/lib/puppet/transaction/additional_resource_generator.rb +5 -0
- data/lib/puppet/transaction/report.rb +7 -2
- data/lib/puppet/type.rb +2 -1
- data/lib/puppet/type/file/checksum.rb +1 -0
- data/lib/puppet/type/file/content.rb +4 -4
- data/lib/puppet/type/mount.rb +44 -0
- data/lib/puppet/type/ssh_authorized_key.rb +1 -1
- data/lib/puppet/type/tidy.rb +3 -0
- data/lib/puppet/type/user.rb +12 -6
- data/lib/puppet/util/log.rb +25 -0
- data/lib/puppet/util/plist.rb +8 -3
- data/lib/puppet/version.rb +1 -1
- data/lib/puppet_x.rb +7 -1
- data/spec/integration/application/apply_spec.rb +118 -0
- data/spec/integration/parser/compiler_spec.rb +28 -0
- data/spec/integration/parser/pcore_resource_spec.rb +40 -3
- data/spec/integration/provider/mount_spec.rb +2 -1
- data/spec/integration/util/windows/principal_spec.rb +2 -2
- data/spec/integration/util/windows/registry_spec.rb +4 -4
- data/spec/lib/puppet_spec/compiler.rb +5 -1
- data/spec/lib/puppet_spec/unindent.rb +5 -0
- data/spec/shared_contexts/types_setup.rb +6 -0
- data/spec/shared_examples/rhel_package_provider.rb +16 -0
- data/spec/spec_helper.rb +1 -0
- data/spec/unit/agent_spec.rb +11 -0
- data/spec/unit/application/lookup_spec.rb +94 -3
- data/spec/unit/capability_spec.rb +22 -0
- data/spec/unit/configurer_spec.rb +8 -0
- data/spec/unit/face/epp_face_spec.rb +22 -3
- data/spec/unit/functions/assert_type_spec.rb +3 -3
- data/spec/unit/functions/binary_file_spec.rb +46 -0
- data/spec/unit/functions/break_spec.rb +89 -0
- data/spec/unit/{parser/functions → functions}/contain_spec.rb +68 -3
- data/spec/unit/functions/find_file_spec.rb +69 -0
- data/spec/unit/functions/include_spec.rb +175 -0
- data/spec/unit/functions/logging_spec.rb +54 -0
- data/spec/unit/functions/lookup_spec.rb +3 -3
- data/spec/unit/functions/new_spec.rb +105 -5
- data/spec/unit/functions/next_spec.rb +93 -0
- data/spec/unit/functions/require_spec.rb +83 -0
- data/spec/unit/functions/return_spec.rb +105 -0
- data/spec/unit/{parser/functions → functions}/shared.rb +14 -11
- data/spec/unit/functions/strftime_spec.rb +152 -0
- data/spec/unit/functions4_spec.rb +22 -0
- data/spec/unit/indirector/face_spec.rb +10 -2
- data/spec/unit/network/http/error_spec.rb +1 -2
- data/spec/unit/network/http/handler_spec.rb +6 -5
- data/spec/unit/parser/functions/hiera_array_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_hash_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_include_spec.rb +1 -1
- data/spec/unit/parser/functions/hiera_spec.rb +1 -1
- data/spec/unit/parser/functions/lookup_spec.rb +1 -1
- data/spec/unit/parser/functions/regsubst_spec.rb +1 -1
- data/spec/unit/parser/functions/split_spec.rb +1 -1
- data/spec/unit/pops/evaluator/access_ops_spec.rb +81 -1
- data/spec/unit/pops/evaluator/arithmetic_ops_spec.rb +170 -0
- data/spec/unit/pops/evaluator/evaluating_parser_spec.rb +29 -4
- data/spec/unit/pops/evaluator/runtime3_converter_spec.rb +112 -4
- data/spec/unit/pops/loaders/dependency_loader_spec.rb +12 -0
- data/spec/unit/pops/loaders/static_loader_spec.rb +0 -26
- data/spec/unit/pops/lookup/context_spec.rb +149 -0
- data/spec/unit/pops/parser/parse_functions_spec.rb +19 -0
- data/spec/unit/pops/parser/parse_lambda_spec.rb +19 -0
- data/spec/unit/pops/puppet_stack_spec.rb +1 -1
- data/spec/unit/pops/resource/resource_type_impl_spec.rb +74 -0
- data/spec/unit/pops/serialization/packer_spec.rb +34 -14
- data/spec/unit/pops/serialization/serialization_spec.rb +67 -5
- data/spec/unit/pops/time/timespan_spec.rb +121 -0
- data/spec/unit/pops/types/p_binary_type_spec.rb +243 -0
- data/spec/unit/pops/types/p_object_type_spec.rb +7 -7
- data/spec/unit/pops/types/p_sensitive_type_spec.rb +1 -1
- data/spec/unit/pops/types/p_timespan_type_spec.rb +273 -0
- data/spec/unit/pops/types/p_timestamp_type_spec.rb +311 -0
- data/spec/unit/pops/types/p_type_set_type_spec.rb +13 -13
- data/spec/unit/pops/types/ruby_generator_spec.rb +12 -12
- data/spec/unit/pops/types/string_converter_spec.rb +89 -0
- data/spec/unit/pops/types/type_asserter_spec.rb +3 -3
- data/spec/unit/pops/types/type_calculator_spec.rb +113 -5
- data/spec/unit/pops/types/type_formatter_spec.rb +40 -0
- data/spec/unit/pops/types/type_mismatch_describer_spec.rb +49 -38
- data/spec/unit/pops/types/type_parser_spec.rb +87 -4
- data/spec/unit/pops/types/types_spec.rb +1 -1
- data/spec/unit/pops/validator/validator_spec.rb +23 -0
- data/spec/unit/provider/mount/parsed_spec.rb +47 -29
- data/spec/unit/provider/package/pkg_spec.rb +109 -99
- data/spec/unit/provider/ssh_authorized_key/parsed_spec.rb +1 -0
- data/spec/unit/provider/user/aix_spec.rb +1 -1
- data/spec/unit/provider/user/directoryservice_spec.rb +101 -30
- data/spec/unit/resource/capability_finder_spec.rb +29 -7
- data/spec/unit/resource/catalog_spec.rb +127 -0
- data/spec/unit/ssl/certificate_request_spec.rb +1 -1
- data/spec/unit/transaction/additional_resource_generator_spec.rb +30 -0
- data/spec/unit/transaction/persistence_spec.rb +1 -6
- data/spec/unit/transaction/report_spec.rb +23 -0
- data/spec/unit/transaction_spec.rb +38 -0
- data/spec/unit/type/mount_spec.rb +5 -0
- data/spec/unit/util/plist_spec.rb +14 -2
- metadata +71 -12
- data/spec/integration/parser/functions/require_spec.rb +0 -43
- data/spec/unit/parser/functions/include_spec.rb +0 -55
- data/spec/unit/parser/functions/require_spec.rb +0 -68
| @@ -1,40 +1,36 @@ | |
| 1 1 | 
             
            # Perform regexp replacement on a string or array of strings.
         | 
| 2 2 | 
             
            #
         | 
| 3 | 
            -
            # @ | 
| 4 | 
            -
            #
         | 
| 5 | 
            -
            # Get the third octet from the node's IP address:
         | 
| 6 | 
            -
            #
         | 
| 7 | 
            -
            #   $i3 = regsubst($ipaddress,'^(\\d+)\\.(\\d+)\\.(\\d+)\\.(\\d+)$','\\3')
         | 
| 8 | 
            -
            #
         | 
| 9 | 
            -
            # Put angle brackets around each octet in the node's IP address:
         | 
| 10 | 
            -
            #
         | 
| 11 | 
            -
            #   $x = regsubst($ipaddress, /([0-9]+)/, '<\\1>', 'G')
         | 
| 12 | 
            -
            #
         | 
| 13 | 
            -
            # @param target [Array[String]|String]
         | 
| 3 | 
            +
            # @param target [String, Array[String]]
         | 
| 14 4 | 
             
            #      The string or array of strings to operate on.  If an array, the replacement will be
         | 
| 15 5 | 
             
            #      performed on each of the elements in the array, and the return value will be an array.
         | 
| 16 | 
            -
            # @param  | 
| 6 | 
            +
            # @param pattern [String, Regexp, Type[Regexp]]
         | 
| 17 7 | 
             
            #      The regular expression matching the target string.  If you want it anchored at the start
         | 
| 18 8 | 
             
            #      and or end of the string, you must do that with ^ and $ yourself.
         | 
| 19 | 
            -
            # @param replacement [String | 
| 9 | 
            +
            # @param replacement [String, Hash[String, String]]
         | 
| 20 10 | 
             
            #      Replacement string. Can contain backreferences to what was matched using \\0 (whole match),
         | 
| 21 11 | 
             
            #      \\1 (first set of parentheses), and so on.
         | 
| 22 12 | 
             
            #      If the second argument is a Hash, and the matched text is one of its keys, the corresponding value is the replacement string.
         | 
| 23 | 
            -
            # @param flags [ | 
| 13 | 
            +
            # @param flags [Optional[Pattern[/^[GEIM]*$/]], Pattern[/^G?$/]]
         | 
| 24 14 | 
             
            #      Optional. String of single letter flags for how the regexp is interpreted (E, I, and M cannot be used
         | 
| 25 15 | 
             
            #      if pattern is a precompiled regexp):
         | 
| 26 16 | 
             
            #        - *E*         Extended regexps
         | 
| 27 17 | 
             
            #        - *I*         Ignore case in regexps
         | 
| 28 18 | 
             
            #        - *M*         Multiline regexps
         | 
| 29 19 | 
             
            #        - *G*         Global replacement; all occurrences of the regexp in each target string will be replaced.  Without this, only the first occurrence will be replaced.
         | 
| 30 | 
            -
            # @param encoding [ | 
| 20 | 
            +
            # @param encoding [Enum['N','E','S','U']]
         | 
| 31 21 | 
             
            #      Optional. How to handle multibyte characters when compiling the regexp (must not be used when pattern is a
         | 
| 32 22 | 
             
            #      precompiled regexp). A single-character string with the following values:
         | 
| 33 23 | 
             
            #        - *N*         None
         | 
| 34 24 | 
             
            #        - *E*         EUC
         | 
| 35 25 | 
             
            #        - *S*         SJIS
         | 
| 36 26 | 
             
            #        - *U*         UTF-8
         | 
| 37 | 
            -
            # @return [Array[String] | 
| 27 | 
            +
            # @return [Array[String], String] The result of the substitution. Result type is the same as for the target parameter.
         | 
| 28 | 
            +
            #
         | 
| 29 | 
            +
            # @example Get the third octet from the node's IP address:
         | 
| 30 | 
            +
            #     $i3 = regsubst($ipaddress,'^(\\d+)\\.(\\d+)\\.(\\d+)\\.(\\d+)$','\\3')
         | 
| 31 | 
            +
            #
         | 
| 32 | 
            +
            # @example Put angle brackets around each octet in the node's IP address:
         | 
| 33 | 
            +
            #     $x = regsubst($ipaddress, /([0-9]+)/, '<\\1>', 'G')
         | 
| 38 34 | 
             
            #
         | 
| 39 35 | 
             
            Puppet::Functions.create_function(:regsubst) do
         | 
| 40 36 | 
             
              dispatch :regsubst_string do
         | 
| @@ -0,0 +1,37 @@ | |
| 1 | 
            +
            # Requires the specified classes
         | 
| 2 | 
            +
            # For documentation see the 3.x function stub
         | 
| 3 | 
            +
            Puppet::Functions.create_function(:require, Puppet::Functions::InternalFunction) do
         | 
| 4 | 
            +
              dispatch :require_impl do
         | 
| 5 | 
            +
                scope_param
         | 
| 6 | 
            +
                # The function supports what the type system sees as Ruby runtime objects, and
         | 
| 7 | 
            +
                # they cannot be parameterized to find what is actually valid instances.
         | 
| 8 | 
            +
                # The validation is instead done in the function body itself via a call to
         | 
| 9 | 
            +
                # `transform_and_assert_classnames` on the calling scope.
         | 
| 10 | 
            +
                required_repeated_param 'Any', :names
         | 
| 11 | 
            +
              end
         | 
| 12 | 
            +
             | 
| 13 | 
            +
              def require_impl(scope, *classes)
         | 
| 14 | 
            +
                # Make call patterns uniform and protected against nested arrays, also make
         | 
| 15 | 
            +
                # names absolute if so desired.
         | 
| 16 | 
            +
                classes = scope.transform_and_assert_classnames(classes.flatten)
         | 
| 17 | 
            +
             | 
| 18 | 
            +
                result = classes.map {|name| Puppet::Pops::Types::TypeFactory.host_class(name) }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                # This is the same as calling the include function (but faster) since it again
         | 
| 21 | 
            +
                # would otherwise need to perform the optional absolute name transformation
         | 
| 22 | 
            +
                # (for no reason since they are already made absolute here).
         | 
| 23 | 
            +
                #
         | 
| 24 | 
            +
                scope.compiler.evaluate_classes(classes, scope, false)
         | 
| 25 | 
            +
                krt = scope.environment.known_resource_types
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                classes.each do |klass|
         | 
| 28 | 
            +
                  # lookup the class in the scopes
         | 
| 29 | 
            +
                  klass = (classobj = krt.find_hostclass(klass)) ? classobj.name : nil
         | 
| 30 | 
            +
                  raise Puppet::ParseError.new("Could not find class #{klass}") unless klass
         | 
| 31 | 
            +
                  ref = Puppet::Resource.new(:class, klass)
         | 
| 32 | 
            +
                  resource = scope.resource
         | 
| 33 | 
            +
                  resource.set_parameter(:require, [resource[:require]].flatten.compact << ref)
         | 
| 34 | 
            +
                end
         | 
| 35 | 
            +
                result
         | 
| 36 | 
            +
              end
         | 
| 37 | 
            +
            end
         | 
| @@ -0,0 +1,22 @@ | |
| 1 | 
            +
            # Make iteration continue with the next value optionally given a value for this iteration.
         | 
| 2 | 
            +
            # If a value is not given it defaults to `undef`
         | 
| 3 | 
            +
            #
         | 
| 4 | 
            +
            # @since 4.7.0
         | 
| 5 | 
            +
            #
         | 
| 6 | 
            +
            Puppet::Functions.create_function(:return, Puppet::Functions::InternalFunction) do
         | 
| 7 | 
            +
              dispatch :return_impl do
         | 
| 8 | 
            +
                optional_param 'Any', :value
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              def return_impl(value = nil)
         | 
| 12 | 
            +
                stacktrace = Puppet::Pops::PuppetStack.stacktrace()
         | 
| 13 | 
            +
                if stacktrace.size > 0
         | 
| 14 | 
            +
                  file, line = stacktrace[0]
         | 
| 15 | 
            +
                else
         | 
| 16 | 
            +
                  file = nil
         | 
| 17 | 
            +
                  line = nil
         | 
| 18 | 
            +
                end
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                raise Puppet::Pops::Evaluator::Return.new(value, file, line)
         | 
| 21 | 
            +
              end
         | 
| 22 | 
            +
            end
         | 
| @@ -0,0 +1,35 @@ | |
| 1 | 
            +
            # (Documentation in 3.x stub)
         | 
| 2 | 
            +
            #
         | 
| 3 | 
            +
            # @since 4.8.0
         | 
| 4 | 
            +
            #
         | 
| 5 | 
            +
            Puppet::Functions.create_function(:strftime) do
         | 
| 6 | 
            +
              dispatch :format_timespan do
         | 
| 7 | 
            +
                param 'Timespan', :time_object
         | 
| 8 | 
            +
                param 'String', :format
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              dispatch :format_timestamp do
         | 
| 12 | 
            +
                param 'Timestamp', :time_object
         | 
| 13 | 
            +
                param 'String', :format
         | 
| 14 | 
            +
                optional_param 'String', :timezone
         | 
| 15 | 
            +
              end
         | 
| 16 | 
            +
             | 
| 17 | 
            +
              dispatch :legacy_strftime do
         | 
| 18 | 
            +
                param 'String', :format
         | 
| 19 | 
            +
                optional_param 'String', :timezone
         | 
| 20 | 
            +
              end
         | 
| 21 | 
            +
             | 
| 22 | 
            +
              def format_timespan(time_object, format)
         | 
| 23 | 
            +
                time_object.format(format)
         | 
| 24 | 
            +
              end
         | 
| 25 | 
            +
             | 
| 26 | 
            +
              def format_timestamp(time_object, format, timezone = nil)
         | 
| 27 | 
            +
                time_object.format(format, timezone)
         | 
| 28 | 
            +
              end
         | 
| 29 | 
            +
             | 
| 30 | 
            +
              def legacy_strftime(format, timezone = nil)
         | 
| 31 | 
            +
                Puppet.warn_once('deprecation', 'legacy#strftime',
         | 
| 32 | 
            +
                  'The argument signature (String format, [String timezone]) is deprecated for #strfime. See #strftime documentation and Timespan type for more info')
         | 
| 33 | 
            +
                Puppet::Pops::Time::Timestamp.format_time(format, Time.now.utc, timezone)
         | 
| 34 | 
            +
              end
         | 
| 35 | 
            +
            end
         | 
| @@ -0,0 +1,14 @@ | |
| 1 | 
            +
            # Log a message on the server at level notice.
         | 
| 2 | 
            +
            Puppet::Functions.create_function(:warning, Puppet::Functions::InternalFunction) do
         | 
| 3 | 
            +
              # @param values The values to log.
         | 
| 4 | 
            +
              # @return [Undef]
         | 
| 5 | 
            +
              dispatch :warning do
         | 
| 6 | 
            +
                scope_param
         | 
| 7 | 
            +
                repeated_param 'Any', :values
         | 
| 8 | 
            +
                return_type 'Undef'
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
             | 
| 11 | 
            +
              def warning(scope, *values)
         | 
| 12 | 
            +
                Puppet::Util::Log.log_func(scope, :warning, values)
         | 
| 13 | 
            +
              end
         | 
| 14 | 
            +
            end
         | 
| @@ -24,6 +24,9 @@ module Puppet | |
| 24 24 | 
             
                      # Gets the isomorphic member attribute of the type
         | 
| 25 25 | 
             
                      attr_reader :isomorphic
         | 
| 26 26 |  | 
| 27 | 
            +
                      # Gets the capability member attribute of the type
         | 
| 28 | 
            +
                      attr_reader :capability
         | 
| 29 | 
            +
             | 
| 27 30 | 
             
                      # Initializes a type model.
         | 
| 28 31 | 
             
                      # @param type [Puppet::Type] The Puppet type to model.
         | 
| 29 32 | 
             
                      # @return [void]
         | 
| @@ -45,6 +48,7 @@ module Puppet | |
| 45 48 | 
             
                          ]
         | 
| 46 49 | 
             
                        end]
         | 
| 47 50 | 
             
                        @isomorphic = type.isomorphic?
         | 
| 51 | 
            +
                        @capability = type.is_capability?
         | 
| 48 52 | 
             
                      end
         | 
| 49 53 |  | 
| 50 54 | 
             
                      def render(template)
         | 
| @@ -39,7 +39,12 @@ class Puppet::Indirector::Face < Puppet::Face | |
| 39 39 |  | 
| 40 40 | 
             
              def call_indirection_method(method, key, options)
         | 
| 41 41 | 
             
                begin
         | 
| 42 | 
            -
                   | 
| 42 | 
            +
                  if method == :save
         | 
| 43 | 
            +
                    # key is really the instance to save
         | 
| 44 | 
            +
                    result = indirection.__send__(method, key, nil, options)
         | 
| 45 | 
            +
                  else
         | 
| 46 | 
            +
                    result = indirection.__send__(method, key, options)
         | 
| 47 | 
            +
                  end
         | 
| 43 48 | 
             
                rescue => detail
         | 
| 44 49 | 
             
                  message = "Could not call '#{method}' on '#{indirection_name}': #{detail}"
         | 
| 45 50 | 
             
                  Puppet.log_exception(detail, message)
         | 
| @@ -59,11 +59,11 @@ module Puppet::Network::HTTP::Error | |
| 59 59 |  | 
| 60 60 | 
             
                def initialize(original_error, issue_kind = Issues::RUNTIME_ERROR)
         | 
| 61 61 | 
             
                  super("Server Error: " + original_error.message, CODE, issue_kind)
         | 
| 62 | 
            -
                  @backtrace =  | 
| 62 | 
            +
                  @backtrace = original_error.backtrace
         | 
| 63 63 | 
             
                end
         | 
| 64 64 |  | 
| 65 65 | 
             
                def to_json
         | 
| 66 | 
            -
                  JSON({:message => message, :issue_kind => @issue_kind | 
| 66 | 
            +
                  JSON({:message => message, :issue_kind => @issue_kind})
         | 
| 67 67 | 
             
                end
         | 
| 68 68 | 
             
              end
         | 
| 69 69 | 
             
            end
         | 
| @@ -68,7 +68,7 @@ module Puppet::Network::HTTP::Handler | |
| 68 68 | 
             
                new_response.respond_with(e.status, "application/json", e.to_json)
         | 
| 69 69 | 
             
              rescue StandardError => e
         | 
| 70 70 | 
             
                http_e = Puppet::Network::HTTP::Error::HTTPServerError.new(e)
         | 
| 71 | 
            -
                log_msg = [http_e.message, * | 
| 71 | 
            +
                log_msg = [http_e.message, *http_e.backtrace].join("\n")
         | 
| 72 72 | 
             
                Puppet.err(log_msg)
         | 
| 73 73 | 
             
                new_response.respond_with(http_e.status, "application/json", http_e.to_json)
         | 
| 74 74 | 
             
              ensure
         | 
| @@ -168,7 +168,7 @@ module Puppet::Network::HTTP::Handler | |
| 168 168 |  | 
| 169 169 | 
             
              def configure_profiler(request_headers, request_params)
         | 
| 170 170 | 
             
                if (request_headers.has_key?(Puppet::Network::HTTP::HEADER_ENABLE_PROFILING.downcase) or Puppet[:profile])
         | 
| 171 | 
            -
                  Puppet::Util::Profiler.add_profiler(Puppet::Util::Profiler::Aggregate.new(Puppet.method(: | 
| 171 | 
            +
                  Puppet::Util::Profiler.add_profiler(Puppet::Util::Profiler::Aggregate.new(Puppet.method(:info), request_params.object_id))
         | 
| 172 172 | 
             
                end
         | 
| 173 173 | 
             
              end
         | 
| 174 174 |  | 
| @@ -218,6 +218,17 @@ class Puppet::Node::Environment | |
| 218 218 | 
             
                errors
         | 
| 219 219 | 
             
              end
         | 
| 220 220 |  | 
| 221 | 
            +
              # Checks if this environment permits use of rich data types in the catalog
         | 
| 222 | 
            +
              # @return [Boolean] `true` if rich data is permitted.
         | 
| 223 | 
            +
              # @api private
         | 
| 224 | 
            +
              def rich_data?
         | 
| 225 | 
            +
                if @rich_data.nil?
         | 
| 226 | 
            +
                  environment_conf = Puppet.lookup(:environments).get_conf(name)
         | 
| 227 | 
            +
                  @rich_data = (environment_conf.nil? ? Puppet[:rich_data] : environment_conf.rich_data)
         | 
| 228 | 
            +
                end
         | 
| 229 | 
            +
                @rich_data
         | 
| 230 | 
            +
              end
         | 
| 231 | 
            +
             | 
| 221 232 | 
             
              # Return an environment-specific Puppet setting.
         | 
| 222 233 | 
             
              #
         | 
| 223 234 | 
             
              # @api public
         | 
    
        data/lib/puppet/parser/ast.rb
    CHANGED
    
    | @@ -29,6 +29,11 @@ class Puppet::Parser::AST | |
| 29 29 | 
             
                # is called so many times during parsing.
         | 
| 30 30 | 
             
                begin
         | 
| 31 31 | 
             
                  return self.evaluate(scope)
         | 
| 32 | 
            +
                rescue Puppet::Pops::Evaluator::PuppetStopIteration => detail
         | 
| 33 | 
            +
                  raise detail
         | 
| 34 | 
            +
            #      # Only deals with StopIteration from the break() function as a general
         | 
| 35 | 
            +
            #      # StopIteration is a general runtime problem
         | 
| 36 | 
            +
            #      raise Puppet::ParseError.new(detail.message, detail.file, detail.line, detail)
         | 
| 32 37 | 
             
                rescue Puppet::Error => detail
         | 
| 33 38 | 
             
                  raise adderrorcontext(detail)
         | 
| 34 39 | 
             
                rescue => detail
         | 
| @@ -61,6 +61,19 @@ class Puppet::Parser::AST::PopsBridge | |
| 61 61 | 
             
                end
         | 
| 62 62 | 
             
              end
         | 
| 63 63 |  | 
| 64 | 
            +
              class ExpressionSupportingReturn < Expression
         | 
| 65 | 
            +
                def initialize args
         | 
| 66 | 
            +
                  super
         | 
| 67 | 
            +
                end
         | 
| 68 | 
            +
             | 
| 69 | 
            +
                def evaluate(scope)
         | 
| 70 | 
            +
                  return catch(:return) do
         | 
| 71 | 
            +
                    return catch(:next) do
         | 
| 72 | 
            +
                      return super(scope)
         | 
| 73 | 
            +
                    end
         | 
| 74 | 
            +
                  end
         | 
| 75 | 
            +
                end
         | 
| 76 | 
            +
              end
         | 
| 64 77 | 
             
              # Bridges the top level "Program" produced by the pops parser.
         | 
| 65 78 | 
             
              # Its main purpose is to give one point where all definitions are instantiated (actually defined since the
         | 
| 66 79 | 
             
              # Puppet 3x terminology is somewhat misleading - the definitions are instantiated, but instances of the created types
         | 
| @@ -174,26 +187,26 @@ class Puppet::Parser::AST::PopsBridge | |
| 174 187 | 
             
                end
         | 
| 175 188 |  | 
| 176 189 | 
             
                # Produces a hash with data for Definition and HostClass
         | 
| 177 | 
            -
                def args_from_definition(o, modname)
         | 
| 190 | 
            +
                def args_from_definition(o, modname, expr_class = Expression)
         | 
| 178 191 | 
             
                  args = {
         | 
| 179 192 | 
             
                   :arguments => o.parameters.collect {|p| instantiate_Parameter(p) },
         | 
| 180 193 | 
             
                   :argument_types => create_type_map(o),
         | 
| 181 194 | 
             
                   :module_name => modname
         | 
| 182 195 | 
             
                  }
         | 
| 183 196 | 
             
                  unless is_nop?(o.body)
         | 
| 184 | 
            -
                    args[:code] =  | 
| 197 | 
            +
                    args[:code] = expr_class.new(:value => o.body)
         | 
| 185 198 | 
             
                  end
         | 
| 186 199 | 
             
                  @ast_transformer.merge_location(args, o)
         | 
| 187 200 | 
             
                end
         | 
| 188 201 |  | 
| 189 202 | 
             
                def instantiate_HostClassDefinition(o, modname)
         | 
| 190 | 
            -
                  args = args_from_definition(o, modname)
         | 
| 203 | 
            +
                  args = args_from_definition(o, modname, ExpressionSupportingReturn)
         | 
| 191 204 | 
             
                  args[:parent] = absolute_reference(o.parent_class)
         | 
| 192 205 | 
             
                  Puppet::Resource::Type.new(:hostclass, o.name, @context.merge(args))
         | 
| 193 206 | 
             
                end
         | 
| 194 207 |  | 
| 195 208 | 
             
                def instantiate_ResourceTypeDefinition(o, modname)
         | 
| 196 | 
            -
                  instance = Puppet::Resource::Type.new(:definition, o.name, @context.merge(args_from_definition(o, modname)))
         | 
| 209 | 
            +
                  instance = Puppet::Resource::Type.new(:definition, o.name, @context.merge(args_from_definition(o, modname, ExpressionSupportingReturn)))
         | 
| 197 210 | 
             
                  Puppet::Pops::Loaders.register_runtime3_type(instance.name, Puppet::Pops::Adapters::SourcePosAdapter.adapt(o).to_uri)
         | 
| 198 211 | 
             
                  instance
         | 
| 199 212 | 
             
                end
         | 
| @@ -585,6 +585,11 @@ class Puppet::Parser::Compiler | |
| 585 585 | 
             
                    urs = unevaluated_resources.each do |resource|
         | 
| 586 586 | 
             
                     begin
         | 
| 587 587 | 
             
                        resource.evaluate
         | 
| 588 | 
            +
                     rescue Puppet::Pops::Evaluator::PuppetStopIteration => detail
         | 
| 589 | 
            +
                       # needs to be handled specifically as the error has the file/line/position where this
         | 
| 590 | 
            +
                       # occurred rather than the resource
         | 
| 591 | 
            +
                       fail(Puppet::Pops::Issues::RUNTIME_ERROR, detail, {:detail => detail.message}, detail)
         | 
| 592 | 
            +
             | 
| 588 593 | 
             
                      rescue Puppet::Error => e
         | 
| 589 594 | 
             
                        # PuppetError has the ability to wrap an exception, if so, use the wrapped exception's
         | 
| 590 595 | 
             
                        # call stack instead
         | 
| @@ -860,11 +865,34 @@ class Puppet::Parser::Compiler | |
| 860 865 | 
             
                scope = @topscope.class_scope(settings_type)
         | 
| 861 866 |  | 
| 862 867 | 
             
                env = environment
         | 
| 868 | 
            +
                settings_hash = {}
         | 
| 863 869 | 
             
                Puppet.settings.each do |name, setting|
         | 
| 864 870 | 
             
                  next if name == :name
         | 
| 865 | 
            -
                   | 
| 871 | 
            +
                  s_name = name.to_s
         | 
| 872 | 
            +
                  # Construct a hash (in anticipation it will be set in top scope under a name like $settings)
         | 
| 873 | 
            +
                  settings_hash[s_name] = transform_setting(env[name])
         | 
| 874 | 
            +
                  scope[s_name] = settings_hash[s_name]
         | 
| 875 | 
            +
                end
         | 
| 876 | 
            +
              end
         | 
| 877 | 
            +
             | 
| 878 | 
            +
              def transform_setting(val)
         | 
| 879 | 
            +
                case val
         | 
| 880 | 
            +
                when Integer, Float, String, TrueClass, FalseClass, NilClass
         | 
| 881 | 
            +
                  val
         | 
| 882 | 
            +
                when Symbol
         | 
| 883 | 
            +
                  val == :undef ? nil : val.to_s
         | 
| 884 | 
            +
                when Array
         | 
| 885 | 
            +
                  val.map {|entry| transform_setting(entry) }
         | 
| 886 | 
            +
                when Hash
         | 
| 887 | 
            +
                  result = {}
         | 
| 888 | 
            +
                  val.each {|k,v| result[transform_setting(k)] = transform_setting(v) }
         | 
| 889 | 
            +
                  result
         | 
| 890 | 
            +
                else
         | 
| 891 | 
            +
                  # not ideal, but required as there are settings values that are special
         | 
| 892 | 
            +
                  val.to_s
         | 
| 866 893 | 
             
                end
         | 
| 867 894 | 
             
              end
         | 
| 895 | 
            +
              private :transform_setting
         | 
| 868 896 |  | 
| 869 897 | 
             
              # Return an array of all of the unevaluated resources.  These will be definitions,
         | 
| 870 898 | 
             
              # which need to get evaluated into native resources.
         | 
| @@ -269,4 +269,10 @@ module Puppet::Parser::Functions | |
| 269 269 | 
             
                  environment_module(environment).get_function_info(name.intern) || environment_module(Puppet.lookup(:root_environment)).get_function_info(name.intern)
         | 
| 270 270 | 
             
                end
         | 
| 271 271 | 
             
              end
         | 
| 272 | 
            +
             | 
| 273 | 
            +
              class Error
         | 
| 274 | 
            +
                def self.is4x(name)
         | 
| 275 | 
            +
                  raise Puppet::ParseError, "#{name}() can only be called using the 4.x function API. See Scope#call_function"
         | 
| 276 | 
            +
                end
         | 
| 277 | 
            +
              end
         | 
| 272 278 | 
             
            end
         | 
| @@ -0,0 +1,24 @@ | |
| 1 | 
            +
            Puppet::Parser::Functions::newfunction(
         | 
| 2 | 
            +
              :binary_file,
         | 
| 3 | 
            +
              :type => :rvalue,
         | 
| 4 | 
            +
              :arity => 1,
         | 
| 5 | 
            +
            :doc => <<-DOC
         | 
| 6 | 
            +
            Loads a binary file from a module or file system and returns its contents as a Binary.
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            The argument to this function should be a `<MODULE NAME>/<FILE>`
         | 
| 9 | 
            +
            reference, which will load `<FILE>` from a module's `files`
         | 
| 10 | 
            +
            directory. (For example, the reference `mysql/mysqltuner.pl` will load the
         | 
| 11 | 
            +
            file `<MODULES DIRECTORY>/mysql/files/mysqltuner.pl`.)
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            This function also accepts an absolute file path that allows reading
         | 
| 14 | 
            +
            binary file content from anywhere on disk.
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            An error is raised if the given file does not exists.
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            To search for the existence of files, use the `find_file()` function.
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            - since 4.8.0
         | 
| 21 | 
            +
            DOC
         | 
| 22 | 
            +
            ) do |args|
         | 
| 23 | 
            +
              Error.is4x('binary_file')
         | 
| 24 | 
            +
            end
         | 
| @@ -0,0 +1,39 @@ | |
| 1 | 
            +
            Puppet::Parser::Functions::newfunction(
         | 
| 2 | 
            +
              :break,
         | 
| 3 | 
            +
              :arity => 0,
         | 
| 4 | 
            +
              :doc => <<-DOC
         | 
| 5 | 
            +
            Breaks the innermost iteration as if it encountered an end of input.
         | 
| 6 | 
            +
            This function does not return to the caller.
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            The signal produced to stop the iteration bubbles up through
         | 
| 9 | 
            +
            the call stack until either terminating the innermost iteration or
         | 
| 10 | 
            +
            raising an error if the end of the call stack is reached.
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            The break() function does not accept an argument.
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            **Example:** Using `break`
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            ```puppet
         | 
| 17 | 
            +
            $data = [1,2,3]
         | 
| 18 | 
            +
            notice $data.map |$x| { if $x == 3 { break() } $x*10 }
         | 
| 19 | 
            +
            ```
         | 
| 20 | 
            +
             | 
| 21 | 
            +
            Would notice the value `[10, 20]`
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            **Example:** Using a nested `break`
         | 
| 24 | 
            +
             | 
| 25 | 
            +
            ```puppet
         | 
| 26 | 
            +
            function break_if_even($x) {
         | 
| 27 | 
            +
              if $x % 2 == 0 { break() }
         | 
| 28 | 
            +
            }
         | 
| 29 | 
            +
            $data = [1,2,3]
         | 
| 30 | 
            +
            notice $data.map |$x| { break_if_even($x); $x*10 }
         | 
| 31 | 
            +
            ```
         | 
| 32 | 
            +
            Would notice the value `[10]`
         | 
| 33 | 
            +
             | 
| 34 | 
            +
            * Also see functions `next` and `return`
         | 
| 35 | 
            +
            * Since 4.8.0
         | 
| 36 | 
            +
            DOC
         | 
| 37 | 
            +
            ) do |args|
         | 
| 38 | 
            +
              Error.is4x('break')
         | 
| 39 | 
            +
            end
         |