Sha256: a16eaebed5620ae0923354de428936644b80f5a73a092eacdf2a3897c3537e36

Contents?: true

Size: 1.97 KB

Versions: 465

Compression:

Stored size: 1.97 KB

Contents

module Puppet
  # 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 Vendor
    class << self
      # @api private
      def vendor_dir
        File.join([File.dirname(File.expand_path(__FILE__)), "vendor"])
      end

      # @api private
      def load_entry(entry)
        Puppet.debug("Loading vendored #{$1}")
        load "#{vendor_dir}/#{entry}"
      end

      # @api private
      def require_libs
        require 'puppet/vendor/require_vendored'
      end

      # Configures the path for all vendored libraries and loads required libraries.
      # (This is the entry point for loading vendored libraries).
      #
      def load_vendored
        Dir.entries(vendor_dir).each do |entry|
          if entry.match(/load_(\w+?)\.rb$/)
            load_entry entry
          end
        end

        require_libs
      end
    end
  end
end

Version data entries

465 entries across 465 versions & 3 rubygems

Version Path
puppet-5.5.17-x86-mingw32 lib/puppet/vendor.rb
puppet-5.5.17 lib/puppet/vendor.rb
puppet-6.10.1 lib/puppet/vendor.rb
puppet-5.5.17-x64-mingw32 lib/puppet/vendor.rb
puppet-6.10.1-x86-mingw32 lib/puppet/vendor.rb
puppet-5.5.17-universal-darwin lib/puppet/vendor.rb
puppet-6.10.1-x64-mingw32 lib/puppet/vendor.rb
puppet-6.10.1-universal-darwin lib/puppet/vendor.rb
puppet-6.4.4 lib/puppet/vendor.rb
puppet-6.4.4-x86-mingw32 lib/puppet/vendor.rb
puppet-6.4.4-x64-mingw32 lib/puppet/vendor.rb
puppet-6.4.4-universal-darwin lib/puppet/vendor.rb
puppet-6.10.0 lib/puppet/vendor.rb
puppet-6.10.0-x86-mingw32 lib/puppet/vendor.rb
puppet-6.10.0-x64-mingw32 lib/puppet/vendor.rb
puppet-6.10.0-universal-darwin lib/puppet/vendor.rb
puppet-6.9.0 lib/puppet/vendor.rb
puppet-6.9.0-x86-mingw32 lib/puppet/vendor.rb
puppet-6.9.0-x64-mingw32 lib/puppet/vendor.rb
puppet-6.9.0-universal-darwin lib/puppet/vendor.rb