Class: Chef::CookbookCollection
- Defined in:
- lib/chef/cookbook/cookbook_collection.rb
Overview
Chef::CookbookCollection
This class is the consistent interface for a node to obtain its cookbooks by name.
This class is basically a glorified Hash, but since there are several ways this cookbook information is collected, (e.g. CookbookLoader for solo, hash of auto-vivified Cookbook objects for lazily-loaded remote cookbooks), it gets transformed into this.
Instance Method Summary collapse
-
#initialize(cookbook_versions = {}) ⇒ CookbookCollection
constructor
The input is a mapping of cookbook name to CookbookVersion objects.
Methods inherited from Mash
#[]=, #default, #delete, #except, #fetch, from_hash, #initialize_copy, #key?, #merge, #regular_update, #regular_writer, #stringify_keys!, #symbolize_keys, #to_hash, #update, #values_at
Constructor Details
#initialize(cookbook_versions = {}) ⇒ CookbookCollection
The input is a mapping of cookbook name to CookbookVersion objects. We simply extract them
36 37 38 39 40 41 42 |
# File 'lib/chef/cookbook/cookbook_collection.rb', line 36 def initialize(cookbook_versions={}) super() do |hash, key| raise Chef::Exceptions::CookbookNotFound, "Cookbook #{key} not found. " << "If you're loading #{key} from another cookbook, make sure you configure the dependency in your metadata" end cookbook_versions.each{ |cookbook_name, cookbook_version| self[cookbook_name] = cookbook_version } end |