#!/usr/bin/env python
import sys, os.path
assert(len(sys.argv) == 4)
resultsDir = sys.argv[1]
summaryFile = sys.argv[2]
overviewFile = sys.argv[3]
results = []
for dir in os.listdir(resultsDir) :
  summary = os.path.join(resultsDir, dir, summaryFile)
  if os.path.exists(summary) :
    file = open(summary)
    lines = file.readlines()
    if len(lines) == 0 or len(lines[0].split("/")) != 2 :
      continue
    coveredCount = int(lines[0].split("/")[0])
    totalCount = int(lines[0].split("/")[1])
    results.append((dir,coveredCount,totalCount))
# Compute coverage chart URL
chartparams = ["chs=320x240", "cht=lc", "chtt=Coverage (Relative)", "chxt=y", "chxl=0:|50%|80%|100%|", "chxp=0,50,80,100"]
chartdata = []
for (url,covered,total) in results :
  chartdata.append(str(100*covered/total))
chartparams.append("chd=t:" + ",".join(chartdata))
coverageChartURL = "http://chart.apis.google.com/chart?" + '&'.join(chartparams)
# Compute the maximum of lines over time
maximumNumberOfLines = 0
for (url,covered,total) in results :
  maximumNumberOfLines = max(maximumNumberOfLines,total)
# Compute code chart URL
chartparams = ["chs=320x240", "cht=lc", "chtt=Coverage (Absolute)", "chxt=y", "chxl=0:|" + str(maximumNumberOfLines) + "|", "chxp=0,100", "chm=b,FF0000,0,1,0|b,80C65A,1,2,0", "chco=00000000,00000000,00000000"]
coveredLinesData = []
totalLinesData = []
nullLinesData = []
for (url,covered,total) in results :
  coveredLinesData.append(str(100*covered/maximumNumberOfLines))
  totalLinesData.append(str(100*total/maximumNumberOfLines))
  nullLinesData.append("0")
chartparams.append("chd=t:" + ",".join(totalLinesData) + "|" + ",".join(coveredLinesData) + "|" + ",".join(nullLinesData))
codeChartURL = "http://chart.apis.google.com/chart?" + '&'.join(chartparams)
# Output page
output = open(os.path.join(resultsDir,overviewFile), 'w')
output.write("" % {'url' : coverageChartURL})
output.write("
" % {'url' : codeChartURL})
output.write("