diff options
| author | daurnimator <quae@daurnimator.com> | 2019-10-19 10:34:19 +0200 |
|---|---|---|
| committer | daurnimator <quae@daurnimator.com> | 2019-11-30 15:52:37 +1100 |
| commit | 27c09f27b22b26463e7e6b47431d539c7e496c6e (patch) | |
| tree | dee213251215ab07f6226a58c6a32dd12fe4303d /src | |
| parent | acf8bcb82ae697a5bac94bfbe93c3ad9d7487795 (diff) | |
| download | luarocks-27c09f27b22b26463e7e6b47431d539c7e496c6e.tar.gz luarocks-27c09f27b22b26463e7e6b47431d539c7e496c6e.tar.bz2 luarocks-27c09f27b22b26463e7e6b47431d539c7e496c6e.zip | |
Add --no-manifest flag to skip creating/updating a global manifest
Diffstat (limited to 'src')
| -rw-r--r-- | src/luarocks/cmd.lua | 4 | ||||
| -rw-r--r-- | src/luarocks/cmd/install.lua | 1 | ||||
| -rw-r--r-- | src/luarocks/cmd/make.lua | 7 | ||||
| -rw-r--r-- | src/luarocks/core/cfg.lua | 1 | ||||
| -rw-r--r-- | src/luarocks/manif/writer.lua | 16 |
5 files changed, 25 insertions, 4 deletions
diff --git a/src/luarocks/cmd.lua b/src/luarocks/cmd.lua index eef043e7..b19535e2 100644 --- a/src/luarocks/cmd.lua +++ b/src/luarocks/cmd.lua | |||
| @@ -584,6 +584,10 @@ function cmd.run_command(description, commands, external_namespace, ...) | |||
| 584 | cfg.local_cache = dir.path(fs.system_cache_dir(), "luarocks") | 584 | cfg.local_cache = dir.path(fs.system_cache_dir(), "luarocks") |
| 585 | end | 585 | end |
| 586 | 586 | ||
| 587 | if args.no_manifest then | ||
| 588 | cfg.no_manifest = true | ||
| 589 | end | ||
| 590 | |||
| 587 | if not args.command then | 591 | if not args.command then |
| 588 | parser:epilog(variables_help..get_config_text(cfg)) | 592 | parser:epilog(variables_help..get_config_text(cfg)) |
| 589 | util.printout() | 593 | util.printout() |
diff --git a/src/luarocks/cmd/install.lua b/src/luarocks/cmd/install.lua index ad2a5ea7..88556e25 100644 --- a/src/luarocks/cmd/install.lua +++ b/src/luarocks/cmd/install.lua | |||
| @@ -42,6 +42,7 @@ function install.add_to_parser(parser) | |||
| 42 | cmd:flag("--check-lua-versions", "If the rock can't be found, check repository ".. | 42 | cmd:flag("--check-lua-versions", "If the rock can't be found, check repository ".. |
| 43 | "and report if it is available for another Lua version.") | 43 | "and report if it is available for another Lua version.") |
| 44 | util.deps_mode_option(cmd) | 44 | util.deps_mode_option(cmd) |
| 45 | cmd:flag("--no-manifest", "Skip creating/updating the manifest") | ||
| 45 | -- luarocks build options | 46 | -- luarocks build options |
| 46 | parser:flag("--pack-binary-rock"):hidden(true) | 47 | parser:flag("--pack-binary-rock"):hidden(true) |
| 47 | parser:option("--branch"):hidden(true) | 48 | parser:option("--branch"):hidden(true) |
diff --git a/src/luarocks/cmd/make.lua b/src/luarocks/cmd/make.lua index a2ae4cd0..13e974c1 100644 --- a/src/luarocks/cmd/make.lua +++ b/src/luarocks/cmd/make.lua | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | 1 | ||
| 2 | --- Module implementing the LuaRocks "make" command. | 2 | --- Module implementing the LuaRocks "make" command. |
| 3 | -- Builds sources in the current directory, but unlike "build", | 3 | -- Builds sources in the current directory, but unlike "build", |
| 4 | -- it does not fetch sources, etc., assuming everything is | 4 | -- it does not fetch sources, etc., assuming everything is |
| 5 | -- available in the current directory. | 5 | -- available in the current directory. |
| 6 | local make = {} | 6 | local make = {} |
| 7 | 7 | ||
| @@ -40,6 +40,7 @@ function make.cmd_options(parser) | |||
| 40 | "and report if it is available for another Lua version.") | 40 | "and report if it is available for another Lua version.") |
| 41 | parser:flag("--pin", "Pin the exact dependencies used for the rockspec".. | 41 | parser:flag("--pin", "Pin the exact dependencies used for the rockspec".. |
| 42 | "being built into a luarocks.lock file in the current directory.") | 42 | "being built into a luarocks.lock file in the current directory.") |
| 43 | parser:flag("--no-manifest", "Skip creating/updating the manifest") | ||
| 43 | util.deps_mode_option(parser) | 44 | util.deps_mode_option(parser) |
| 44 | end | 45 | end |
| 45 | 46 | ||
| @@ -53,7 +54,7 @@ version or without version name. If rockspecs for different rocks are found or | |||
| 53 | there are several rockspecs without version, you must specify which to use, | 54 | there are several rockspecs without version, you must specify which to use, |
| 54 | through the command-line. | 55 | through the command-line. |
| 55 | 56 | ||
| 56 | This command is useful as a tool for debugging rockspecs. | 57 | This command is useful as a tool for debugging rockspecs. |
| 57 | To install rocks, you'll normally want to use the "install" and "build" | 58 | To install rocks, you'll normally want to use the "install" and "build" |
| 58 | commands. See the help on those for details. | 59 | commands. See the help on those for details. |
| 59 | 60 | ||
| @@ -87,7 +88,7 @@ function make.command(args) | |||
| 87 | if not rockspec_filename:match("rockspec$") then | 88 | if not rockspec_filename:match("rockspec$") then |
| 88 | return nil, "Invalid argument: 'make' takes a rockspec as a parameter. "..util.see_help("make") | 89 | return nil, "Invalid argument: 'make' takes a rockspec as a parameter. "..util.see_help("make") |
| 89 | end | 90 | end |
| 90 | 91 | ||
| 91 | local rockspec, err, errcode = fetch.load_rockspec(rockspec_filename) | 92 | local rockspec, err, errcode = fetch.load_rockspec(rockspec_filename) |
| 92 | if not rockspec then | 93 | if not rockspec then |
| 93 | return nil, err | 94 | return nil, err |
diff --git a/src/luarocks/core/cfg.lua b/src/luarocks/core/cfg.lua index e26c263c..ffa6964a 100644 --- a/src/luarocks/core/cfg.lua +++ b/src/luarocks/core/cfg.lua | |||
| @@ -187,6 +187,7 @@ local function make_defaults(lua_version, target_cpu, platforms, home) | |||
| 187 | fs_use_modules = true, | 187 | fs_use_modules = true, |
| 188 | hooks_enabled = true, | 188 | hooks_enabled = true, |
| 189 | deps_mode = "one", | 189 | deps_mode = "one", |
| 190 | no_manifest = false, | ||
| 190 | check_certificates = false, | 191 | check_certificates = false, |
| 191 | 192 | ||
| 192 | cache_timeout = 60, | 193 | cache_timeout = 60, |
diff --git a/src/luarocks/manif/writer.lua b/src/luarocks/manif/writer.lua index 44580a46..8c6e4505 100644 --- a/src/luarocks/manif/writer.lua +++ b/src/luarocks/manif/writer.lua | |||
| @@ -338,12 +338,18 @@ function writer.make_manifest(repo, deps_mode, remote) | |||
| 338 | local vmanifest = { repository = {}, modules = {}, commands = {} } | 338 | local vmanifest = { repository = {}, modules = {}, commands = {} } |
| 339 | local ok, err = store_results(results, vmanifest) | 339 | local ok, err = store_results(results, vmanifest) |
| 340 | filter_by_lua_version(vmanifest, luaver, repo, cache) | 340 | filter_by_lua_version(vmanifest, luaver, repo, cache) |
| 341 | save_table(repo, "manifest-"..luaver, vmanifest) | 341 | if not cfg.no_manifest then |
| 342 | save_table(repo, "manifest-"..luaver, vmanifest) | ||
| 343 | end | ||
| 342 | end | 344 | end |
| 343 | else | 345 | else |
| 344 | update_dependencies(manifest, deps_mode) | 346 | update_dependencies(manifest, deps_mode) |
| 345 | end | 347 | end |
| 346 | 348 | ||
| 349 | if cfg.no_manifest then | ||
| 350 | -- We want to have cache updated; but exit before save_table is called | ||
| 351 | return true | ||
| 352 | end | ||
| 347 | return save_table(repo, "manifest", manifest) | 353 | return save_table(repo, "manifest", manifest) |
| 348 | end | 354 | end |
| 349 | 355 | ||
| @@ -381,6 +387,10 @@ function writer.add_to_manifest(name, version, repo, deps_mode) | |||
| 381 | if not ok then return nil, err end | 387 | if not ok then return nil, err end |
| 382 | 388 | ||
| 383 | update_dependencies(manifest, deps_mode) | 389 | update_dependencies(manifest, deps_mode) |
| 390 | |||
| 391 | if cfg.no_manifest then | ||
| 392 | return true | ||
| 393 | end | ||
| 384 | return save_table(rocks_dir, "manifest", manifest) | 394 | return save_table(rocks_dir, "manifest", manifest) |
| 385 | end | 395 | end |
| 386 | 396 | ||
| @@ -436,6 +446,10 @@ function writer.remove_from_manifest(name, version, repo, deps_mode) | |||
| 436 | end | 446 | end |
| 437 | 447 | ||
| 438 | update_dependencies(manifest, deps_mode) | 448 | update_dependencies(manifest, deps_mode) |
| 449 | |||
| 450 | if cfg.no_manifest then | ||
| 451 | return true | ||
| 452 | end | ||
| 439 | return save_table(rocks_dir, "manifest", manifest) | 453 | return save_table(rocks_dir, "manifest", manifest) |
| 440 | end | 454 | end |
| 441 | 455 | ||
