diff options
author | TP Honey <tphoney@users.noreply.github.com> | 2015-03-05 19:15:41 +0000 |
---|---|---|
committer | TP Honey <tphoney@users.noreply.github.com> | 2015-03-05 19:15:41 +0000 |
commit | bf8e5b0573f78f2c2c780494a735bfac25d4488d (patch) | |
tree | 2c81ecba270068294b25ad7d2b17919cb71fee04 /lib/puppet/parser/functions/assert_private.rb | |
parent | 668b3c31b591b9ee67ab215715b95adf8e78608a (diff) | |
parent | 4a68b224c4a4a986be6b4bf9580fc4f23251e3c6 (diff) | |
download | puppet-stdlib-bf8e5b0573f78f2c2c780494a735bfac25d4488d.tar.gz puppet-stdlib-bf8e5b0573f78f2c2c780494a735bfac25d4488d.tar.bz2 |
Merge pull request #422 from cyberious/assert_private
Assert private
Diffstat (limited to 'lib/puppet/parser/functions/assert_private.rb')
-rw-r--r-- | lib/puppet/parser/functions/assert_private.rb | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/lib/puppet/parser/functions/assert_private.rb b/lib/puppet/parser/functions/assert_private.rb new file mode 100644 index 0000000..66c79cc --- /dev/null +++ b/lib/puppet/parser/functions/assert_private.rb @@ -0,0 +1,29 @@ +# +# assert_private.rb +# + +module Puppet::Parser::Functions + newfunction(:assert_private, :doc => <<-'EOS' + Sets the current class or definition as private. + Calling the class or definition from outside the current module will fail. + EOS + ) do |args| + + raise(Puppet::ParseError, "assert_private(): Wrong number of arguments "+ + "given (#{args.size}}) for 0 or 1)") if args.size > 1 + + scope = self + if scope.lookupvar('module_name') != scope.lookupvar('caller_module_name') + message = nil + if args[0] and args[0].is_a? String + message = args[0] + else + manifest_name = scope.source.name + manifest_type = scope.source.type + message = (manifest_type.to_s == 'hostclass') ? 'Class' : 'Definition' + message += " #{manifest_name} is private" + end + raise(Puppet::ParseError, message) + end + end +end |