class Raykit::Console

def self.import(hash)

def self.import(hash)
    puts 'scanning...'
    scanned_remotes = Raykit::Git::scan_remote_urls
    remotes = Raykit::Git::remote_urls
    count = 0
    scanned_remotes.each{|remote|
        if(!remotes.include?(remote))
            puts "imported " + Rainbow(remote).yellow.bright
            remotes.insert(0,remote)
            count = count + 1
        end
    }
    if(count > 0)
        puts 'updating Raykit::Git::remote_urls'
        Raykit::Git::remote_urls = remotes
    end
end

def self.list(hash)

def self.list(hash)
    pattern=nil
    if(hash.include?(:pattern))
        pattern=hash[:pattern]
    end
    Raykit::Git::remote_urls.each{|url| 
        if(pattern.nil? || url.include?(pattern))
            puts Rainbow(url).yellow.bright
        end
    }
end

def self.rake(hash)

def self.rake(hash)
    cmd = Raykit::Rake::run(hash[:remote],'master')
    elapsed_str = Timer.get_elapsed_str(cmd.elapsed)
    if(cmd.exitstatus == 0)
        puts elapsed_str + " " +  Rainbow(cmd.command).yellow.bright + " (#{cmd.directory})"
        return elapsed_str + " " + cmd.command
    else
        puts "\r\n" + cmd.command + "\r\n"
        puts "\r\n" + cmd.output + "\r\n"
        puts "\r\n" + cmd.error + "\r\n"
        puts ''
        abort Rainbow(elapsed_str).red.bright + " " +  Rainbow(cmd.command).white
    end
end

def self.run

def self.run
    if(ARGV.length == 0)
        Parser.parse %w[--help]
        0
    else
        hash = Parser.parse ARGV
        #puts "hash: #{hash.to_s}"

        if(hash.include?(:verb))
            verb = hash[:verb]
            case verb
            when 'list'
                list(hash)
            when 'import'
                import(hash)
            when 'rake'
                rake(hash)
            end
        end
    end
end