blob: 308460555a2383ee5cd2b5852eb11193f58c0f8f [file] [log] [blame]
#!/usr/bin/env ruby
DOWNLOADS_FILE = 'pages/download.md'
def need_pages_submodule
unless File.exists?(DOWNLOADS_FILE)
raise "Robolectric pages submodule isn't present. Run git submodule update --init"
end
end
def fill_index_downloads
require 'digest/sha1'
download_html = "<!-- START_DOWNLOADS -->\n"
Dir.glob('pages/downloads/*.jar').sort.reverse.each do |f|
sha1 = Digest::SHA1.hexdigest File.read(f)
fn = f.sub(/^pages\//, '')
match = /robolectric-?([0-9]\.[0-9](\.[0-9])?)?(-all)?(-src)?\.jar/.match(f)
version = match[1] if match
version = "SNAPSHOT" unless version
prerelease = /\.rc/.match(f)
download_html += prerelease ? "<tr class=\"rc\">\n" : "<tr>\n"
download_html += " <td class=\"link\"><a href=\"#{fn}\" onClick=\"javascript:pageTracker._trackPageView('#{fn}'); \">#{fn.sub(/downloads\//, '')}</a></td>\n"
download_html += " <td class=\"version\">#{version}</td>\n"
download_html += " <td class=\"size\">#{File.size(f) / 1024}k</td>\n"
download_html += " <td class=\"date\">#{File.mtime(f).strftime("%Y/%m/%d %H:%M:%S %Z")}</td>\n"
download_html += " <td class=\"sha\">#{sha1}</td>\n"
download_html += "</tr>\n"
end
download_html += "<!-- END_DOWNLOADS -->"
downloads_page = File.read(DOWNLOADS_FILE)
matcher = /<!-- START_DOWNLOADS -->.*<!-- END_DOWNLOADS -->/m
downloads_page = downloads_page.sub(matcher, download_html)
File.open(DOWNLOADS_FILE, 'w') {|f| f.write(downloads_page)}
puts "rewrote " + DOWNLOADS_FILE
end
fill_index_downloads