summaryrefslogtreecommitdiff
path: root/tool/file2lastrev.rb
diff options
context:
space:
mode:
authorNobuyoshi Nakada <nobu@ruby-lang.org>2022-10-12 22:03:35 +0900
committerNobuyoshi Nakada <nobu@ruby-lang.org>2022-10-12 22:24:53 +0900
commit80da7250c5d7c862e3c1e1431683a1f1211a4d9c (patch)
tree7e6405e04d736594e13666e2caceff6e072d6d6f /tool/file2lastrev.rb
parent70bc8cc6c219667dcae85bbf78bc0bc00e05c76e (diff)
file2lastrev.rb: Refactor VCS directory search
Search VCS directory after other options are in effective, i.e., `--srcdir=nonexitent --suppress_not_found` options, as well as the reverse order case, should print the current date only and exit successfully.
Diffstat (limited to 'tool/file2lastrev.rb')
-rwxr-xr-xtool/file2lastrev.rb23
1 files changed, 8 insertions, 15 deletions
diff --git a/tool/file2lastrev.rb b/tool/file2lastrev.rb
index 09cb959932..94c2b2a9d6 100755
--- a/tool/file2lastrev.rb
+++ b/tool/file2lastrev.rb
@@ -26,19 +26,11 @@ vcs = nil
OptionParser.new {|opts|
opts.banner << " paths..."
vcs_options = VCS.define_options(opts)
- new_vcs = proc do |path|
- begin
- vcs = VCS.detect(path, vcs_options, opts.new)
- rescue VCS::NotFoundError => e
- abort "#{File.basename(Program)}: #{e.message}" unless @suppress_not_found
- opts.remove
- nil
- end
- end
+ srcdir = nil
opts.new
opts.on("--srcdir=PATH", "use PATH as source directory") do |path|
- abort "#{File.basename(Program)}: srcdir is already set" if vcs
- new_vcs[path]
+ abort "#{File.basename(Program)}: srcdir is already set" if srcdir
+ srcdir = path
end
opts.on("--changed", "changed rev") do
self.output = :changed
@@ -60,10 +52,11 @@ OptionParser.new {|opts|
@suppress_not_found = true
end
opts.order! rescue abort "#{File.basename(Program)}: #{$!}\n#{opts}"
- if vcs
- vcs.set_options(vcs_options) # options after --srcdir
- elsif new_vcs["."]
- else @suppress_not_found
+ begin
+ vcs = VCS.detect(srcdir || ".", vcs_options, opts.new)
+ rescue VCS::NotFoundError => e
+ abort "#{File.basename(Program)}: #{e.message}" unless @suppress_not_found
+ opts.remove
(vcs = VCS::Null.new(nil)).set_options(vcs_options)
end
}