Method: Mono::Tool.sync

Defined in:
lib/mono/commands/sync.rb

.syncObject



5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# File 'lib/mono/commands/sync.rb', line 5

def self.sync
  repos = Mono.monofile

  count_orgs  = 0
  count_repos = 0

  total_repos = repos.size

  repos.each do |org,names|
    org_path = "#{Mono.root}/#{org}"
    FileUtils.mkdir_p( org_path ) unless Dir.exist?( org_path )   ## make sure path exists


    names.each do |name|
        puts "[#{count_repos+1}/#{total_repos}] #{org}@#{name}..."

        repo = GitHubRepo.new( org, name )  ## owner, name e.g. rubylibs/webservice


        Dir.chdir( org_path ) do
          if Dir.exist?( repo.name )
            GitProject.open( repo.name ) do |proj|
              if proj.changes?
                puts "!! WARN - local changes in workdir; skipping fast forward (remote) sync / merge"
              else
                proj.fast_forward   ## note: use git pull --ff-only (fast forward only - do NOT merge)

              end
            end
          else
            Git.clone( repo.ssh_clone_url )
          end
        end

#

# todo/fix: add (back) error log !!!!!!!!!!!!

#        rescue GitError => ex

#          puts "!! ERROR: #{ex.message}"

#

#          File.open( './errors.log', 'a' ) do |f|

#              f.write "#{Time.now} -- repo #{org}/#{name} - #{ex.message}\n"

#           end


        count_repos += 1
    end
    count_orgs += 1
  end

  ## print stats

  puts "#{count_repos} repo(s) @ #{count_orgs} org(s)"
end