Sha256: 7e22cdb81d8aa42f7eb6494096cf641bac79b826ba036ac8bc4b9d6777d1bfc2

Contents?: true

Size: 2 KB

Versions: 32

Compression:

Stored size: 2 KB

Contents

# frozen_string_literal: true

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 #{entry}")
        load "#{vendor_dir}/#{entry}"
      end

      # @api private
      def require_libs
        require_relative '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 =~ /load_(\w+?)\.rb$/
            load_entry entry
          end
        end

        require_libs
      end
    end
  end
end

Version data entries

32 entries across 32 versions & 1 rubygems

Version Path
puppet-8.10.0 lib/puppet/vendor.rb
puppet-8.10.0-x86-mingw32 lib/puppet/vendor.rb
puppet-8.10.0-x64-mingw32 lib/puppet/vendor.rb
puppet-8.10.0-universal-darwin lib/puppet/vendor.rb
puppet-8.9.0 lib/puppet/vendor.rb
puppet-8.9.0-x86-mingw32 lib/puppet/vendor.rb
puppet-8.9.0-x64-mingw32 lib/puppet/vendor.rb
puppet-8.9.0-universal-darwin lib/puppet/vendor.rb
puppet-8.8.1 lib/puppet/vendor.rb
puppet-8.8.1-x86-mingw32 lib/puppet/vendor.rb
puppet-8.8.1-x64-mingw32 lib/puppet/vendor.rb
puppet-8.8.1-universal-darwin lib/puppet/vendor.rb
puppet-8.7.0 lib/puppet/vendor.rb
puppet-8.7.0-x86-mingw32 lib/puppet/vendor.rb
puppet-8.7.0-x64-mingw32 lib/puppet/vendor.rb
puppet-8.7.0-universal-darwin lib/puppet/vendor.rb
puppet-8.6.0 lib/puppet/vendor.rb
puppet-8.6.0-x86-mingw32 lib/puppet/vendor.rb
puppet-8.6.0-x64-mingw32 lib/puppet/vendor.rb
puppet-8.6.0-universal-darwin lib/puppet/vendor.rb