class Bake::Registry::Aggregate
Public Class Methods
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 19 def self.default(working_directory, bakefile_path = nil) registry = self.new if bakefile_path registry.append_bakefile(bakefile_path) end registry.append_defaults(working_directory) return registry end
Create a loader using the specified working directory. @parameter working_directory [String]
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 32 def initialize # Used to de-duplicated directories: @roots = {} # The ordered list of loaders: @ordered = Array.new end
Initialize an empty array of registry.
Public Instance Methods
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 57 def append_bakefile(path) @ordered << BakefileLoader.new(path) end
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 76 def append_defaults(working_directory) # Load recipes from working directory: self.append_path(working_directory) # Load recipes from loaded gems: self.append_from_gems end
Add registry according to the current working directory and loaded gems. @parameter working_directory [String]
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 85 def append_from_gems ::Gem.loaded_specs.each do |name, spec| Console.debug(self) {"Checking gem #{name}: #{spec.full_gem_path}..."} if path = spec.full_gem_path and File.directory?(path) append_path(path, name: spec.full_name) end end end
Enumerate all loaded gems and add them.
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 64 def append_path(current = Dir.pwd, **options) bake_path = File.join(current, "bake") if File.directory?(bake_path) return insert(bake_path, **options) end return false end
Append a specific project path to the search path for recipes. The computed path will have ‘bake` appended to it. @parameter current [String] The path to add.
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 47 def each(&block) @ordered.each(&block) end
Enumerate the registry in order.
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 42 def empty? @ordered.empty? end
Whether any registry are defined. @returns [Boolean]
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 51 def scopes_for(path, &block) @ordered.each do |registry| registry.scopes_for(path, &block) end end
Protected Instance Methods
Source
# File vendor/bundle/ruby/3.4.0/gems/bake-0.23.1/lib/bake/registry/aggregate.rb, line 97 def insert(directory, **options) unless @roots.key?(directory) Console.debug(self) {"Adding #{directory.inspect}"} loader = DirectoryLoader.new(directory, **options) @roots[directory] = loader @ordered << loader return true end return false end