aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHisham Muhammad <hisham@gobolinux.org>2016-11-13 16:01:17 -0200
committerGitHub <noreply@github.com>2016-11-13 16:01:17 -0200
commit9f4fa981c5defaaf7b82b629ff68f1e3ec58650f (patch)
tree35f0bb1d1e4df0b5780f16e84cadc943f5eec15d
parent5e5d324e19135b1de0d3014ea203b910abc22853 (diff)
parent47530921d71ef34fcd29a631584ca38af0df99d7 (diff)
downloadluarocks-9f4fa981c5defaaf7b82b629ff68f1e3ec58650f.tar.gz
luarocks-9f4fa981c5defaaf7b82b629ff68f1e3ec58650f.tar.bz2
luarocks-9f4fa981c5defaaf7b82b629ff68f1e3ec58650f.zip
Merge pull request #652 from mpeterv/fix-which
`luarocks show `improvements: fix module paths, add command listing
-rw-r--r--src/luarocks/cmd/show.lua21
-rw-r--r--src/luarocks/path.lua21
-rw-r--r--src/luarocks/repos.lua27
3 files changed, 42 insertions, 27 deletions
diff --git a/src/luarocks/cmd/show.lua b/src/luarocks/cmd/show.lua
index 1ff81e08..ad48b153 100644
--- a/src/luarocks/cmd/show.lua
+++ b/src/luarocks/cmd/show.lua
@@ -9,6 +9,7 @@ local path = require("luarocks.path")
9local deps = require("luarocks.deps") 9local deps = require("luarocks.deps")
10local fetch = require("luarocks.fetch") 10local fetch = require("luarocks.fetch")
11local manif = require("luarocks.manif") 11local manif = require("luarocks.manif")
12local repos = require("luarocks.repos")
12 13
13show.help_summary = "Show information about an installed rock." 14show.help_summary = "Show information about an installed rock."
14 15
@@ -66,6 +67,12 @@ local function installed_rock_label(name, tree)
66 return installed and "(using "..version..")" or "(missing)" 67 return installed and "(using "..version..")" or "(missing)"
67end 68end
68 69
70local function print_items(name, version, item_set, item_type, repo)
71 for item_name in util.sortedpairs(item_set) do
72 util.printout("\t"..item_name.." ("..repos.which(name, version, item_type, item_name, repo)..")")
73 end
74end
75
69--- Driver function for "show" command. 76--- Driver function for "show" command.
70-- @param name or nil: an existing package name. 77-- @param name or nil: an existing package name.
71-- @param version string or nil: a version may also be passed. 78-- @param version string or nil: a version may also be passed.
@@ -121,13 +128,19 @@ function show.command(flags, name, version)
121 util.printout("Labels: ", table.concat(descript.labels, ", ")) 128 util.printout("Labels: ", table.concat(descript.labels, ", "))
122 end 129 end
123 util.printout("Installed in: ", path.rocks_tree_to_string(repo)) 130 util.printout("Installed in: ", path.rocks_tree_to_string(repo))
131
132 if next(minfo.commands) then
133 util.printout()
134 util.printout("Commands: ")
135 print_items(name, version, minfo.commands, "command", repo)
136 end
137
124 if next(minfo.modules) then 138 if next(minfo.modules) then
125 util.printout() 139 util.printout()
126 util.printout("Modules:") 140 util.printout("Modules: ")
127 for mod, filename in util.sortedpairs(minfo.modules) do 141 print_items(name, version, minfo.modules, "module", repo)
128 util.printout("\t"..mod.." ("..path.which(mod, filename, name, version, repo, manifest)..")")
129 end
130 end 142 end
143
131 local direct_deps = {} 144 local direct_deps = {}
132 if #rockspec.dependencies > 0 then 145 if #rockspec.dependencies > 0 then
133 util.printout() 146 util.printout()
diff --git a/src/luarocks/path.lua b/src/luarocks/path.lua
index 83e9c295..71893cf1 100644
--- a/src/luarocks/path.lua
+++ b/src/luarocks/path.lua
@@ -231,25 +231,4 @@ function path.use_tree(tree)
231 cfg.deploy_lib_dir = path.deploy_lib_dir(tree) 231 cfg.deploy_lib_dir = path.deploy_lib_dir(tree)
232end 232end
233 233
234--- Return the pathname of the file that would be loaded for a module,
235-- returning the versioned pathname if given version is not the default version
236-- in the given manifest.
237-- @param module_name string: module name (eg. "socket.core")
238-- @param file_name string: module file name as in manifest (eg. "socket/core.so")
239-- @param name string: name of the package (eg. "luasocket")
240-- @param version string: version number (eg. "2.0.2-1")
241-- @param tree string: repository path (eg. "/usr/local")
242-- @param manifest table: the manifest table for the tree.
243-- @return string: filename of the module (eg. "/usr/local/lib/lua/5.1/socket/core.so")
244function path.which(module_name, file_name, name, version, tree, manifest)
245 local versions = manifest.modules[module_name]
246 assert(versions)
247 for i, name_version in ipairs(versions) do
248 if name_version == name.."/"..version then
249 return path.which_i(file_name, name, version, tree, i):gsub("//", "/")
250 end
251 end
252 assert(false)
253end
254
255return path 234return path
diff --git a/src/luarocks/repos.lua b/src/luarocks/repos.lua
index 7c3251b9..5d5dedd6 100644
--- a/src/luarocks/repos.lua
+++ b/src/luarocks/repos.lua
@@ -231,8 +231,9 @@ end
231-- item from the newest version of lexicographically smallest package 231-- item from the newest version of lexicographically smallest package
232-- is deployed using non-versioned name and others use versioned names. 232-- is deployed using non-versioned name and others use versioned names.
233 233
234local function get_deploy_paths(name, version, deploy_type, file_path) 234local function get_deploy_paths(name, version, deploy_type, file_path, repo)
235 local deploy_dir = cfg["deploy_" .. deploy_type .. "_dir"] 235 repo = repo or cfg.root_dir
236 local deploy_dir = path["deploy_" .. deploy_type .. "_dir"](repo)
236 local non_versioned = dir.path(deploy_dir, file_path) 237 local non_versioned = dir.path(deploy_dir, file_path)
237 local versioned = path.versioned_name(non_versioned, deploy_dir, name, version) 238 local versioned = path.versioned_name(non_versioned, deploy_dir, name, version)
238 return non_versioned, versioned 239 return non_versioned, versioned
@@ -423,4 +424,26 @@ function repos.delete_version(name, version, deps_mode, quick)
423 return writer.remove_from_manifest(name, version, nil, deps_mode) 424 return writer.remove_from_manifest(name, version, nil, deps_mode)
424end 425end
425 426
427--- Find full path to a file providing a module or a command
428-- in a package.
429-- @param name string: name of package.
430-- @param version string: exact package version in string format.
431-- @param item_type string: "module" or "command".
432-- @param item_name string: module or command name.
433-- @param root string or nil: A local root dir for a rocks tree. If not given, the default is used.
434-- @return string: absolute path to the file providing given module
435-- or command.
436function repos.which(name, version, item_type, item_name, repo)
437 local deploy_type, file_path = manif.get_providing_file(name, version, item_type, item_name, repo)
438 local non_versioned, versioned = get_deploy_paths(name, version, deploy_type, file_path, repo)
439 local cur_name, cur_version = manif.get_current_provider(item_type, item_name)
440 local deploy_path = (name == cur_name and version == cur_version) and non_versioned or versioned
441
442 if deploy_type == "bin" and cfg.wrapper_suffix and cfg.wrapper_suffix ~= "" then
443 deploy_path = find_suffixed(deploy_path, cfg.wrapper_suffix) or deploy_path
444 end
445
446 return deploy_path
447end
448
426return repos 449return repos