]> rtime.felk.cvut.cz Git - can-benchmark.git/blobdiff - gw-tests/genhtml/genhtml.py
Add a CC license
[can-benchmark.git] / gw-tests / genhtml / genhtml.py
index cd4985b9c6d0613bc67225cfee2372ea6f442a88..a5114f1dca453f2ff1369e13581860d65c92959a 100755 (executable)
@@ -6,6 +6,10 @@ import sys;
 import urllib
 import traceback
 import glob
+import datetime
+
+html_copyright = """<div style="font-size: small; color: gray; margin-top: 1em;">Authors: Michal Sojka, Pavel Píša, Martin Hořeňovský, Copyright © 2010-%d Czech Technical University in Prague.<br />
+<a rel="license" href="http://creativecommons.org/licenses/by-sa/3.0/"><img alt="Creative Commons License" style="border-width:0; vertical-align:text-bottom;" src="http://i.creativecommons.org/l/by-sa/3.0/80x15.png" /></a> This work is licensed under a <a rel="license" href="http://creativecommons.org/licenses/by-sa/3.0/">Creative Commons Attribution-ShareAlike 3.0 Unported License</a>.</div>""" % datetime.date.today().year
 
 class DimValue(object):
     def __new__(cls, dim, value):
@@ -23,6 +27,8 @@ class DimValue(object):
        return "DimValue(%s, %s)" % (repr(self.dim), repr(self.value))
     def htmlTableHeading(self):
        return self.dim.htmlTableHeading(self.value)
+    def index(self):
+        return self.dim.sortedKeys.index(self.value)
 
 class DimValues(list):
     def replace(self, val):
@@ -152,8 +158,33 @@ class Test(object):
             print >>file, "<a href='%s/results.html'><img src='%s/%s'></a>" % \
                   (urllib.quote(self.path), urllib.quote(self.path), img)
     def fullImgLink(self, pngName):
-        return "<div><a href='%s'><img src='%s' /></a></div>" % \
-               (pngName[:-4]+".pdf", pngName)
+        ps = "<a href='%s'>Plot source</a>" % ("plot"+pngName[5:-4]+".gp")
+        if 'NO_PDF' in os.environ:
+            return "<div><img src='%s' />%s</div>" % (pngName, ps)
+        else:
+            return "<div><a href='%s'><img src='%s' /></a>%s</div>" % \
+                   (pngName[:-4]+".pdf", pngName, ps)
+        
+    def htmlPrintStats(self, html):
+        cwd = os.getcwd()
+        os.chdir(self.path)
+        stats = glob.glob("*-stat.txt")
+        print >>html, "<h3>Statistics</h3>"
+        print >>html, "<table><tr>"
+        stats.sort()
+        for i in stats:
+            lines = open(i).readlines()
+            def fixupLine(l):
+                comment = l.find("#")
+                if comment >= 0:
+                    l = l[:comment-1]
+                if l.find("cmdline=") == 0:
+                    l = "<abbr title=%s>cmdline=...</abbr>" % str(l[8:])
+                return l
+            lines = [fixupLine(l) for l in lines]
+            print >>html, "<td><h4>%s</h4>%s</td>" % (i, "<br />".join(lines))
+        print >>html, "</tr></table>"
+        os.chdir(cwd)
         
     def generateHtml(self):
         html = open(os.path.join(self.path, 'results.html'), "w")
@@ -188,20 +219,21 @@ class Test(object):
 
         print >>html, "</table></div>"
         print >>html, self.fullImgLink("graph.png")
-        print >>html, "<a href='./'>Raw data</a><br />"
-        print >>html, "<a href='%s'>Script source</a><br />" % (cdup+self.name+".sh.html")
-        print >>html, "<a href='%s'>Back to top</a><br />" % cdup
-
+        self.htmlPrintStats(html)
         cwd = os.getcwd()
         os.chdir(self.path)
         additionalImgs = glob.glob("graph?*.png")
-        if additionalImgs:
-            print "XXX"
-            print >>html, "<h2>Additional graphs</h2>"
+        if additionalImgs: print >>html, "<h3>Additional graphs</h3>"
         for i in additionalImgs:
+            print >>html, "<h4>%s</h4>" % i[5:-4]
             print >>html, self.fullImgLink(i)
         os.chdir(cwd)
         
+        print >>html, "<hr />"
+        print >>html, "<a href='./'>Raw data</a><br />"
+        print >>html, "<a href='%s'>Script source</a><br />" % (cdup+self.name+".sh.html")
+        print >>html, "<a href='%s'>Back to top</a><br />" % cdup
+        print >>html,"%s</body></html>" % html_copyright
         html.close()
 
 class Space(list):
@@ -297,13 +329,14 @@ h4 { margin: 0; }
 .otherview .other:hover { background: #eee; }
 .otherview .missing { color: gray; }
 .otherview .current { background: #ccc; }
+.na { width: 150px; height: 109px; display:  table-cell; text-align: center; vertical-align: middle; }
 """
         css.close()
         for test in self.values():
             print test.path
             test.generateHtml()
 
-       os.system("source-highlight -d --output-dir=. ../*.sh > /dev/null")
+       os.system("source-highlight -d --output-dir=. %s/*.sh > /dev/null" % sh_dir)
 
 class Page(object):
     def __init__(self, dimPair, valsOther, tests):
@@ -313,7 +346,7 @@ class Page(object):
        self.tests = tests
     def getName(self):
        return "%s-vs-%s-for-%s.html"%(self.dimy.type, self.dimx.type,
-                                       "-".join([v.value for v in self.valsOther]))
+                                       "-".join(["%02d"%v.index() for v in self.valsOther]))
     def generate(self):
        html = open(self.getName(), "w")
        title = "CAN gateway timing analysis" 
@@ -364,18 +397,19 @@ class Page(object):
                     test = tests.getTest(idx)
                     test.printThumbLink(html)
                 except KeyError:
-                    print >>html, "N/A"
+                    print >>html, "<span class='na'>N/A</span>"
                 print >>html, "</td>"
            print >>html, "</tr>"
        print >> html, """
 </table>
-<div style="font-size: small; color: gray; margin-top: 1em;">Authors: Michal Sojka, Pavel Píša, Copyright © 2010 Czech Technical University in Prague</div>
+%s
 </body>
-"""
+""" % html_copyright
 
 
 if __name__ == "__main__":
     os.chdir(sys.argv[1])
+    sh_dir = sys.argv[2]
     os.system("rm *.html")
     tests = Tests("./", Space(DimensionHostKern(), DimensionKern(), DimensionTraffic(), DimensionLoad(), DimensionTest()))
     tests.generateHtml()