Class: Bundler::Plugin::Index
Relationships & Source Files | |
Namespace Children | |
Exceptions:
| |
Inherits: | Object |
Defined in: | lib/bundler/plugin/index.rb |
Class Method Summary
- .new ⇒ Index constructor
Instance Attribute Summary
- #commands readonly
Instance Method Summary
-
#command_plugin(command)
Fetch the name of plugin handling the command.
-
#global_index_file
Path where the global index file is stored.
-
#hook_plugins(event)
Returns the list of plugin names handling the passed event.
-
#index_file
Path of default index file.
- #installed?(name) ⇒ Boolean
-
#installed_in_plugin_root?(name) ⇒ Boolean
This plugin is installed inside the .bundle/plugin directory, and thus is managed solely by
::Bundler
. - #installed_plugins
- #load_paths(name)
-
#local_index_file
Path where the local index file is stored.
- #plugin_commands(plugin)
- #plugin_path(name)
-
#register_plugin(name, path, load_paths, commands, sources, hooks)
This function is to be called when a new plugin is installed.
- #source?(source) ⇒ Boolean
- #source_plugin(name)
- #unregister_plugin(name)
-
#load_index(index_file, global = false)
private
Reads the index file from the directory and initializes the instance variables.
-
#save_index
private
Should be called when any of the instance variables change.
Constructor Details
.new ⇒ Index
# File 'lib/bundler/plugin/index.rb', line 25
def initialize @plugin_paths = {} @commands = {} @sources = {} @hooks = {} @load_paths = {} begin load_index(global_index_file, true) rescue GenericSystemCallError # no need to fail when on a read-only FS, for example nil rescue ArgumentError => e # ruby 3.4 checks writability in Dir.tmpdir raise unless e.&.include?("could not find a temporary directory") nil end load_index(local_index_file) if SharedHelpers.in_bundle? end
Instance Attribute Details
#commands (readonly)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 23
attr_reader :commands
Instance Method Details
#command_plugin(command)
Fetch the name of plugin handling the command
# File 'lib/bundler/plugin/index.rb', line 114
def command_plugin(command) @commands[command] end
#global_index_file
Path where the global index file is stored
# File 'lib/bundler/plugin/index.rb', line 96
def global_index_file Plugin.global_root.join("index") end
#hook_plugins(event)
Returns the list of plugin names handling the passed event
# File 'lib/bundler/plugin/index.rb', line 139
def hook_plugins(event) @hooks[event] || [] end
#index_file
Path of default index file
#installed?(name) ⇒ Boolean
# File 'lib/bundler/plugin/index.rb', line 118
def installed?(name) @plugin_paths[name] end
#installed_in_plugin_root?(name) ⇒ Boolean
This plugin is installed inside the .bundle/plugin directory, and thus is managed solely by ::Bundler
# File 'lib/bundler/plugin/index.rb', line 145
def installed_in_plugin_root?(name) return false unless (path = installed?(name)) path.start_with?("#{Plugin.root}/") end
#installed_plugins
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 122
def installed_plugins @plugin_paths.keys end
#load_index(index_file, global = false) (private)
Reads the index file from the directory and initializes the instance variables.
It skips the sources if the second param is true
# File 'lib/bundler/plugin/index.rb', line 159
def load_index(index_file, global = false) SharedHelpers.filesystem_access(index_file, :read) do |index_f| valid_file = index_f&.exist? && !index_f.size.zero? break unless valid_file data = index_f.read require_relative "../yaml_serializer" index = YAMLSerializer.load(data) @commands.merge!(index["commands"]) @hooks.merge!(index["hooks"]) @load_paths.merge!(index["load_paths"]) @plugin_paths.merge!(index["plugin_paths"]) @sources.merge!(index["sources"]) unless global end end
#load_paths(name)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 109
def load_paths(name) @load_paths[name] end
#local_index_file
Path where the local index file is stored
# File 'lib/bundler/plugin/index.rb', line 101
def local_index_file Plugin.local_root.join("index") end
#plugin_commands(plugin)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 126
def plugin_commands(plugin) @commands.find_all {|_, n| n == plugin }.map(&:first) end
#plugin_path(name)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 105
def plugin_path(name) Pathname.new @plugin_paths[name] end
#register_plugin(name, path, load_paths, commands, sources, hooks)
This function is to be called when a new plugin is installed. This function shall add the functions of the plugin to existing maps and also the name to source location.
# File 'lib/bundler/plugin/index.rb', line 54
def register_plugin(name, path, load_paths, commands, sources, hooks) old_commands = @commands.dup common = commands & @commands.keys raise CommandConflict.new(name, common) unless common.empty? commands.each {|c| @commands[c] = name } common = sources & @sources.keys raise SourceConflict.new(name, common) unless common.empty? sources.each {|k| @sources[k] = name } hooks.each do |event| event_hooks = (@hooks[event] ||= []) << name event_hooks.uniq! end @plugin_paths[name] = path @load_paths[name] = load_paths save_index rescue StandardError @commands = old_commands raise end
#save_index (private)
Should be called when any of the instance variables change. Stores the instance variables in YAML format. (The instance variables are supposed to be only String key value pairs)
# File 'lib/bundler/plugin/index.rb', line 180
def save_index index = { "commands" => @commands, "hooks" => @hooks, "load_paths" => @load_paths, "plugin_paths" => @plugin_paths, "sources" => @sources, } require_relative "../yaml_serializer" SharedHelpers.filesystem_access(index_file) do |index_f| FileUtils.mkdir_p(index_f.dirname) File.open(index_f, "w") {|f| f.puts YAMLSerializer.dump(index) } end end
#source?(source) ⇒ Boolean
#source_plugin(name)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 134
def source_plugin(name) @sources[name] end
#unregister_plugin(name)
[ GitHub ]# File 'lib/bundler/plugin/index.rb', line 78
def unregister_plugin(name) @commands.delete_if {|_, v| v == name } @sources.delete_if {|_, v| v == name } @hooks.each do |hook, names| names.delete(name) @hooks.delete(hook) if names.empty? end @plugin_paths.delete(name) @load_paths.delete(name) save_index end