lib/multirepo/commands/add-command.rb
require "multirepo/utility/console"
require "multirepo/files/config-file"
module MultiRepo
class AddCommand < Command
self.command = "add"
self.summary = "Track an additional dependency with multirepo."
def self.options
[['<path>', 'The relative path to the new dependency (e.g. ../MyNewDependency)']].concat(super)
end
def initialize(argv)
@path = with_trailing_slash(argv.shift_argument)
super
end
def validate!
super
help! "You must specify a repository to add as a dependency" unless @path
end
def run
ensure_in_work_tree
ensure_multirepo_enabled
ensure_repo_valid
config_file = ConfigFile.new(".")
entry = ConfigEntry.new(Repo.new(@path))
if config_file.entry_exists?(entry)
Console.log_info("There is already an entry for '#{@path}' in the .multirepo file")
else
config_file.add_entry(entry)
Console.log_step("Added '#{@path}' to the .multirepo file")
end
end
def ensure_repo_valid
fail MultiRepoException, "The provided path is not a direct sibling of the main repository" unless validate_is_sibling_repo(@path)
fail MultiRepoException, "There is no folder at path '#{@path}'" unless Dir.exist?(@path)
fail MultiRepoException, "'#{@path}' is not a repository" unless Repo.new(@path).exists?
end
def validate_is_sibling_repo(path)
parent_dir = File.expand_path("..")
path = File.expand_path("..", path)
return parent_dir == path
end
def with_trailing_slash(path)
if path.end_with?("/") then path else path + "/" end
end
end
end