This commit is contained in:
Petr Korolev 2016-07-21 17:26:40 +03:00
parent f32a02a75b
commit 939f6fd768

View File

@ -61,7 +61,7 @@ module GitHubChangelogGenerator
opts.on("-b", "--base [NAME]", "Optional base file to append generated changes to.") do |last| opts.on("-b", "--base [NAME]", "Optional base file to append generated changes to.") do |last|
options[:base] = last options[:base] = last
end end
opts.on("--bugs-label [LABEL]", "Setup custom label for bug-fixes section. Default is \"**Fixed bugs:**""") do |v| opts.on("--bugs-label [LABEL]", "Setup custom label for bug-fixes section. Default is \"**Fixed bugs:**" "") do |v|
options[:bug_prefix] = v options[:bug_prefix] = v
end end
opts.on("--enhancement-label [LABEL]", "Setup custom label for enhancements section. Default is \"**Implemented enhancements:**\"") do |v| opts.on("--enhancement-label [LABEL]", "Setup custom label for enhancements section. Default is \"**Implemented enhancements:**\"") do |v|
@ -213,22 +213,29 @@ module GitHubChangelogGenerator
# 2) in 2 params: repo name project # 2) in 2 params: repo name project
def self.fetch_user_and_project(options) def self.fetch_user_and_project(options)
if options[:user].nil? || options[:project].nil? if options[:user].nil? || options[:project].nil?
user_and_project_from_git(options, ARGV[0], ARGV[1]) user, project = user_and_project_from_git(options, ARGV[0], ARGV[1])
options[:user] ||= user
options[:project] ||= project
end end
end end
# Sets `:user` and `:project` in `options` from CLI arguments or `git remote` # Sets `:user` and `:project` in `options` from CLI arguments or `git remote`
# @param [String] arg0 first argument in cli
# @param [String] arg1 second argument in cli
# @return [Array<String>] user and project, or nil if unsuccessful
def self.user_and_project_from_git(options, arg0 = nil, arg1 = nil) def self.user_and_project_from_git(options, arg0 = nil, arg1 = nil)
options[:user], options[:project] = user_project_from_option(arg0, arg1, options[:github_site]) user, project = user_project_from_option(arg0, arg1, options[:github_site])
return if options[:user] && options[:project] unless user && project
if ENV["RUBYLIB"] =~ /ruby-debug-ide/
if ENV["RUBYLIB"] =~ /ruby-debug-ide/ user = "skywinder"
options[:user] = "skywinder" project = "changelog_test"
options[:project] = "changelog_test" else
else remote = `git config --get remote.#{options[:git_remote]}.url`
remote = `git config --get remote.#{options[:git_remote]}.url` user, project = user_project_from_remote(remote)
options[:user], options[:project] = user_project_from_remote(remote) end
end end
[user, project]
end end
# Returns GitHub username and project from CLI arguments # Returns GitHub username and project from CLI arguments