Module: Poise::Helpers::DefinedIn
- Included in:
- Inversion::Provider, Provider, Resource
- Defined in:
- lib/poise/helpers/defined_in.rb
Overview
A mixin to track where a resource or provider was defined. This can provide either the filename of the class or the cookbook it was defined in.
Class Method Summary collapse
-
.poise_defined!(caller_array)
Record that the class/module was defined.
-
.poise_defined_in ⇒ String
The file this class or module was defined in, or nil if it isn't found.
-
.poise_defined_in_cookbook(run_context, file = nil) ⇒ String
The cookbook this class or module was defined in.
Class Method Details
.poise_defined!(caller_array)
This method returns an undefined value.
Record that the class/module was defined. Called automatically by Ruby for all normal cases.
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'lib/poise/helpers/defined_in.rb', line 94 def poise_defined!(caller_array) # Only try to set this once. return if @poise_defined_in # Parse out just the filenames. caller_paths = caller_array.map {|line| line[CALLER_REGEXP, 1] } # Find the first non-poise, non-chef line. This assumes Halite # transformation which I'm not thrilled about. caller_path = caller_paths.find do |line| line && !line.start_with?(POISE_LIB_ROOT) && !line.start_with?(CHEF_LIB_ROOT) end raise Poise::Error.new("Unable to find a caller path for: #{caller_array.inspect}") unless caller_path if ::File::ALT_SEPARATOR caller_path.gsub!(::File::ALT_SEPARATOR, ::File::SEPARATOR) end Chef::Log.debug("[#{self.name}] Recording poise_defined_in as #{caller_path}") @poise_defined_in = caller_path end |
.poise_defined_in ⇒ String
The file this class or module was defined in, or nil if it isn't found.
69 70 71 72 |
# File 'lib/poise/helpers/defined_in.rb', line 69 def poise_defined_in raise Poise::Error.new("Unable to determine location of #{self.name}") unless @poise_defined_in @poise_defined_in end |
.poise_defined_in_cookbook(run_context, file = nil) ⇒ String
The cookbook this class or module was defined in. Can pass a file to check that instead.
81 82 83 84 85 86 87 |
# File 'lib/poise/helpers/defined_in.rb', line 81 def poise_defined_in_cookbook(run_context, file=nil) file ||= poise_defined_in Poise.debug("[#{self.name}] Checking cookbook name for #{file}") Poise::Utils.find_cookbook_name(run_context, file).tap do |cookbook| Poise.debug("[#{self.name}] found cookbook #{cookbook.inspect}") end end |