Class: Toys::Loader
- Inherits:
-
Object
- Object
- Toys::Loader
- Defined in:
- lib/toys/loader.rb
Overview
The Loader service loads tools from configuration files, and finds the appropriate tool given a set of command line arguments.
This class is not thread-safe.
Instance Method Summary collapse
-
#add_block(high_priority: false, name: nil, &block) ⇒ self
Add a configuration block to the loader.
-
#add_path(paths, high_priority: false) ⇒ self
Add a configuration file/directory to the loader.
-
#has_subtools?(words) ⇒ Boolean
Returns true if the given path has at least one subtool.
-
#initialize(index_file_name: nil, preload_dir_name: nil, preload_file_name: nil, data_dir_name: nil, middleware_stack: [], extra_delimiters: "", mixin_lookup: nil, middleware_lookup: nil, template_lookup: nil) ⇒ Loader
constructor
Create a Loader.
-
#list_subtools(words, recursive: false, include_hidden: false) ⇒ Array<Toys::Tool>
Returns a list of subtools for the given path, loading from the configuration if necessary.
-
#lookup(args) ⇒ Array(Toys::Tool,Array<String>)
Given a list of command line arguments, find the appropriate tool to handle the command, loading it from the configuration if necessary.
-
#lookup_specific(words) ⇒ Toys::Tool?
Given a tool name, looks up the specific tool, loading it from the configuration if necessary.
-
#split_path(str) ⇒ Array<String>
Splits the given path using the delimiters configured in this Loader.
Constructor Details
#initialize(index_file_name: nil, preload_dir_name: nil, preload_file_name: nil, data_dir_name: nil, middleware_stack: [], extra_delimiters: "", mixin_lookup: nil, middleware_lookup: nil, template_lookup: nil) ⇒ Loader
Create a Loader
74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/toys/loader.rb', line 74 def initialize(index_file_name: nil, preload_dir_name: nil, preload_file_name: nil, data_dir_name: nil, middleware_stack: [], extra_delimiters: "", mixin_lookup: nil, middleware_lookup: nil, template_lookup: nil) if index_file_name && ::File.extname(index_file_name) != ".rb" raise ::ArgumentError, "Illegal index file name #{index_file_name.inspect}" end @mixin_lookup = mixin_lookup || ModuleLookup.new @middleware_lookup = middleware_lookup || ModuleLookup.new @template_lookup = template_lookup || ModuleLookup.new @index_file_name = index_file_name @preload_file_name = preload_file_name @preload_dir_name = preload_dir_name @data_dir_name = data_dir_name @middleware_stack = middleware_stack @worklist = [] @tool_data = {} @max_priority = @min_priority = 0 @extra_delimiters = process_extra_delimiters(extra_delimiters) get_tool([], -999_999) end |
Instance Method Details
#add_block(high_priority: false, name: nil, &block) ⇒ self
Add a configuration block to the loader.
127 128 129 130 131 132 133 |
# File 'lib/toys/loader.rb', line 127 def add_block(high_priority: false, name: nil, &block) name ||= "(Code block #{block.object_id})" priority = high_priority ? (@max_priority += 1) : (@min_priority -= 1) source = SourceInfo.create_proc_root(block, name) @worklist << [source, [], priority] self end |
#add_path(paths, high_priority: false) ⇒ self
Add a configuration file/directory to the loader.
104 105 106 107 108 109 110 111 112 |
# File 'lib/toys/loader.rb', line 104 def add_path(paths, high_priority: false) paths = Array(paths) priority = high_priority ? (@max_priority += 1) : (@min_priority -= 1) paths.each do |path| source = SourceInfo.create_path_root(path) @worklist << [source, [], priority] end self end |
#has_subtools?(words) ⇒ Boolean
Returns true if the given path has at least one subtool. Loads from the configuration if necessary.
215 216 217 218 219 220 221 222 223 224 |
# File 'lib/toys/loader.rb', line 215 def has_subtools?(words) # rubocop:disable Naming/PredicateName load_for_prefix(words) len = words.length @tool_data.each do |n, td| if !n.empty? && n.length > len && n.slice(0, len) == words && !td.definitions.empty? return true end end false end |
#list_subtools(words, recursive: false, include_hidden: false) ⇒ Array<Toys::Tool>
Returns a list of subtools for the given path, loading from the configuration if necessary.
190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 |
# File 'lib/toys/loader.rb', line 190 def list_subtools(words, recursive: false, include_hidden: false) load_for_prefix(words) found_tools = [] len = words.length @tool_data.each do |n, td| next if n.empty? if recursive next if n.length <= len || n.slice(0, len) != words else next unless n.slice(0..-2) == words end tool = td.active_definition || td.top_definition found_tools << tool unless tool.nil? end sort_tools_by_name(found_tools) include_hidden ? found_tools : filter_hidden_subtools(found_tools) end |
#lookup(args) ⇒ Array(Toys::Tool,Array<String>)
Given a list of command line arguments, find the appropriate tool to handle the command, loading it from the configuration if necessary. This always returns a tool. If the specific tool path is not defined and cannot be found in any configuration, it finds the nearest namespace that would contain that tool, up to the root tool.
Returns a tuple of the found tool, and the array of remaining arguments that are not part of the tool name and should be passed as tool args.
148 149 150 151 152 153 154 155 156 |
# File 'lib/toys/loader.rb', line 148 def lookup(args) orig_prefix, args = find_orig_prefix(args) prefix = orig_prefix loop do tool = lookup_specific(prefix) return [tool, args.slice(prefix.length..-1)] if tool prefix = prefix.slice(0..-2) end end |
#lookup_specific(words) ⇒ Toys::Tool?
Given a tool name, looks up the specific tool, loading it from the configuration if necessary.
If there is an active tool, returns it; otherwise, returns the highest
priority tool that has been defined. If no tool has been defined with
the given name, returns nil.
170 171 172 173 174 175 176 177 |
# File 'lib/toys/loader.rb', line 170 def lookup_specific(words) words = split_path(words.first) if words.size == 1 load_for_prefix(words) tool_data = get_tool_data(words) tool = tool_data.active_definition || tool_data.top_definition finish_definitions_in_tree(words) if tool tool end |
#split_path(str) ⇒ Array<String>
Splits the given path using the delimiters configured in this Loader. You may pass in either an array of strings, or a single string possibly delimited by path separators. Always returns an array of strings.
234 235 236 237 238 |
# File 'lib/toys/loader.rb', line 234 def split_path(str) return str.map(&:to_s) if str.is_a?(::Array) str = str.to_s @extra_delimiters ? str.split(@extra_delimiters) : [str] end |