public
Description: Gitorious aims to provide a great way of doing distributed opensource code collaboration.
Homepage: http://gitorious.org/projects/gitorious
Clone URL: git://github.com/dysinger/gitorious.git
gitorious / script / graph_generator
100755 65 lines (53 sloc) 1.708 kb
1
2
3
4
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
53
54
55
56
57
58
59
60
61
62
63
64
65
#!/usr/bin/env ruby
 
require 'tmpdir'
require "fileutils"
 
LOCK_FILE_PATH = File.join(Dir.tmpdir, "gitorious_graphgenerator_lockfile")
if File.exist?(LOCK_FILE_PATH)
    $stderr.puts "Lockfile '#{LOCK_FILE_PATH}' exists!"
    exit(1)
end
 
FileUtils.touch(LOCK_FILE_PATH)
 
ENV["RAILS_ENV"] ||= "production"
require File.dirname(__FILE__) + "/../config/environment"
 
log = Logger.new(File.join(RAILS_ROOT, "log", "graph_generator.log"))
log.formatter = Logger::Formatter.new
log.level = Logger::INFO
log.formatter.datetime_format = "%Y-%m-%d %H:%M:%S"
 
STATUS_FILE = File.join(RAILS_ROOT, "tmp", "graph_generator.status")
update_status = !File.exist?(STATUS_FILE)
tmpdir = File.join(RAILS_ROOT, "tmp", "graph_generator")
if !File.directory?(tmpdir)
  FileUtils.mkdir_p(tmpdir)
elsif !update_status
  mtime = File.mtime(STATUS_FILE).utc
 
  days = (Time.now.utc - mtime) / (3600*24)
  if days >= 5
    log.info "Cleaning '#{tmpdir}'..."
    Dir.glob(File.join(tmpdir, "*.status")) do |file|
      FileUtils.rm(file)
    end
 
    update_status = true
  end
end
 
if update_status
  FileUtils.touch(STATUS_FILE)
end
 
log.info "Starting graph generation run..."
Repository.find(:all).each_with_index do |repository, index|
  begin
    Gitorious::Graphs::Builder.generate_all_for(repository)
    if index % 5 == 0
      # GC every five cycles
      GC.start
    end
    sleep(0.1)
  rescue => e
    log.fatal "Error generating graphs for repo##{repository.id}"
    exception_backtrace_string = "#{e.class.name} #{e.message}\n#{e.backtrace.join("\n ")}"
    log.fatal exception_backtrace_string
    $stderr.puts exception_backtrace_string
# exit(1)    
  end
end
log.info "Done with graph generation run"
 
FileUtils.rm(LOCK_FILE_PATH)