Class: Puppet::Vendor

Inherits:
Object show all
Defined in:
lib/puppet/vendor.rb

Overview

Simple module to manage vendored code.

To vendor a library:

  • Download its whole git repo or untar into ‘lib/puppet/vendor/<libname>`

  • Create a vendor/puppetload_libraryname.rb file to add its libdir into the $:. (Look at existing load_xxx files, they should all follow the same pattern).

  • Add a <libname>/PUPPET_README.md file describing what the library is for and where it comes from.

  • To load the vendored lib upfront, add a ‘require ’<vendorlib>‘`line to `vendor/require_vendored.rb`.

  • To load the vendored lib on demand, add a comment to ‘vendor/require_vendored.rb`

    to make it clear it should not be loaded upfront.
    

At runtime, the #load_vendored method should be called. It will ensure all vendored libraries are added to the global ‘$:` path, and will then call execute the up-front loading specified in `vendor/require_vendored.rb`.

The intention is to not change vendored libraries and to eventually make adding them in optional so that distros can simply adjust their packaging to exclude this directory and the various load_xxx.rb scripts if they wish to install these gems as native packages.

Class Method Summary collapse

Class Method Details

.load_entry(entry) ⇒ Object

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.



35
36
37
38
# File 'lib/puppet/vendor.rb', line 35

def load_entry(entry)
  Puppet.debug("Loading vendored #{entry}")
  load "#{vendor_dir}/#{entry}"
end

.load_vendoredObject

Configures the path for all vendored libraries and loads required libraries. (This is the entry point for loading vendored libraries).



48
49
50
51
52
53
54
55
56
# File 'lib/puppet/vendor.rb', line 48

def load_vendored
  Dir.entries(vendor_dir).each do |entry|
    if entry =~ /load_(\w+?)\.rb$/
      load_entry entry
    end
  end

  require_libs
end

.require_libsObject

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.



41
42
43
# File 'lib/puppet/vendor.rb', line 41

def require_libs
  require_relative 'vendor/require_vendored'
end

.vendor_dirObject

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.



30
31
32
# File 'lib/puppet/vendor.rb', line 30

def vendor_dir
  File.join([File.dirname(File.expand_path(__FILE__)), "vendor"])
end