lib/multirepo/commands/command.rb
require "claide"
require "multirepo/info"
require "multirepo/multirepo-exception"
require "multirepo/config"
require "multirepo/files/config-file"
require "multirepo/files/lock-file"
module MultiRepo
class Command < CLAide::Command
self.abstract_command = true
self.command = "multi"
self.version = VERSION
self.description = DESCRIPTION
def self.report_error(exception)
if exception.instance_of?(MultiRepoException)
Console.log_error(exception.message)
exit 1
end
fail exception
end
def initialize(argv)
@argv = argv
Config.instance.verbose |= argv.flag?("verbose") ? true : false
Config.instance.extra_output ||= argv.option("extra-output")
Config.instance.git_executable ||= argv.option("git-exe", "git")
super
end
def run
help!
end
def validate!
super
path = Config.instance.git_executable
is_git_exe = path =~ /.*(git)|(git.exe)$/
file_exists = path == "git" || File.exist?(path)
help! "Invalid git executable '#{path}'" unless is_git_exe && file_exists
end
def install_hooks(path)
actual_path = path || "."
Utils.install_hook("pre-commit", actual_path)
Utils.install_hook("post-commit", actual_path)
end
def uninstall_hooks
FileUtils.rm_f(".git/hooks/pre-commit")
FileUtils.rm_f(".git/hooks/post-commit")
end
def update_gitconfig(path)
actual_path = path || "."
resource_file = Utils.path_for_resource(".gitconfig")
target_file = File.join(actual_path, '.git/config')
template = File.read(resource_file)
first_template_line = template.lines.first
Utils.append_if_missing(target_file, Regexp.new(Regexp.quote(first_template_line)), template)
end
def multirepo_enabled_dependencies
ConfigFile.new(".").load_entries.select { |e| Utils.multirepo_enabled?(e.repo.path) }
end
def ensure_in_work_tree
repo = Repo.new(".")
fail MultiRepoException, "Not a git repository" unless repo.exists?
fail MultiRepoException, "HEAD is unborn (you must perform at least one commit)" unless repo.head_born?
end
def ensure_multirepo_enabled
fail MultiRepoException, "multirepo is not initialized in this repository." unless Utils.multirepo_enabled?(".")
end
def ensure_multirepo_tracked
fail MultiRepoException, "Revision is not tracked by multirepo." unless Utils.multirepo_tracked?(".")
lock_file_valid = LockFile.new(".").validate!
fail MultiRepoException, "Revision is multirepo-enabled but contains a corrupted lock file!" unless lock_file_valid
end
end
end