module Physique::ToolLocator
Public Instance Methods
locate_tool(paths, options = {})
click to toggle source
Allows you to locate a tool on disk given a file specification. For example…
locate_tool 'C:/Program Files/Microsoft SQL Server/**/Tools/Binn/SQLCMD.EXE'
The tool sorts any matching executables in descending order to that the most recent version is returned. To change this behavior call the method with the reverse option.
locate_tool 'C:/path/to/**/tool.exe', find_latest: false
Throws a ToolNotFoundError
if no tool could be found.
# File lib/physique/tool_locator.rb, line 26 def locate_tool(paths, options = {}) # FileList only correctly handles forward-slashes, even on Windows raise ToolNotFoundError, 'No tool paths provided' unless paths debug { "Extracting paths from the following pattern #{paths}" } paths = paths.gsub('\\', '/') paths = FileList[paths] unless paths.respond_to?(:each) debug { "Attempting to locate tool in the following paths #{paths}" } opts = Map.options(options).apply :find_latest => true paths = paths.collect { |p| which(p) }.compact.sort paths = paths.reverse if opts[:find_latest] tool = paths.first raise ToolNotFoundError, "Could not find tool in the following paths: \n #{paths}" if tool.nil? tool end
lookup_tool(name, project, package_folder)
click to toggle source
# File lib/physique/tool_locator.rb, line 13 def lookup_tool(name, project, package_folder) end
register_tool(name, executable, nuget_package = nil, nuget_path = nil)
click to toggle source
# File lib/physique/tool_locator.rb, line 10 def register_tool(name, executable, nuget_package = nil, nuget_path = nil) end
which(exe)
click to toggle source
# File lib/physique/tool_locator.rb, line 44 def which(exe) Albacore::CrossPlatformCmd.which(exe) || File.exists?(exe) ? exe : nil; end