CMS 3D CMS Logo

dbfile2html.py
Go to the documentation of this file.
1 #!/usr/bin/env python
2 # coding: utf-8
3 '''
4 Generates static HTML for the given database file.
5 Warrning!: did not finish the implementation, see TODO comment.
6 
7 Author: Albertas Gimbutas, Vilnius University (LT)
8 e-mail: albertasgim@gmail.com
9 '''
10 from __future__ import absolute_import
11 from __future__ import print_function
12 import sqlite3
13 import re
14 from os import listdir, makedirs, getcwd
15 from os.path import isfile, join, exists, dirname, basename
16 from .app_utils import *
17 from optparse import OptionParser
18 
19 from jinja2 import Environment, FileSystemLoader, escape
20 env = Environment(loader=FileSystemLoader('templates')) # Template directory has to exist
21 
22 parser = OptionParser(usage='Usage: %prog --db PATH_TO_DB [options]')
23 parser.add_option('--db', action='store', dest='db_name',
24  help='Absolute path to SQLite3 database file.')
25 parser.add_option('--th', action='store', dest='threshold', default=1e-5,
26  help='Threshold to use for static HTML statistics. Default: %default.')
27 
28 def create_page(path, content):
29  path = join(*path)
30  if not exists(dirname(path)):
31  makedirs(dirname(path))
32  f = open(path + '.html', 'w')
33  f.write(content)
34  f.close()
35 
36 def dbfile2html(db_name, work_path, threshold=1e-5):
37  """
38  Generates static HTML from given release comparison database file.
39  Algorithm: iterates through database, renders Jinja2 templates and saves
40  them to static HTML files.
41  """
42  if not exists(db_name):
43  print("\nError: SQLite3 database file does not exsits. Exitting...\n")
44  exit()
45 
46  conn = sqlite3.connect(db_name)
47  c = conn.cursor()
48 
49  ## Initialise working directory.
50  path = join(work_path, 'static_html')
51  if not exists(path):
52  makedirs(path)
53 
54  global_context = {'db_name': None , 'threshold': threshold,
55  'file_id': None, 'args': [], 'kwargs': None}
56  global_context['static_html'] = True
57  global_context['base_path'] = work_path.strip('/')
58 
59  ## Generate DB list page
60  context = global_context.copy()
61  db_list_temp = env.get_template('db_list.html')
62  context['db_list'] = db_list_with_releases(work_path)
63  f = open(join(path, 'index.html'), 'w')
64  f.write(db_list_temp.render(context))
65 
66  ## Generate ReleaseComparison html pages
67  c.execute('''SELECT id, title, statistical_test FROM ReleaseComparison;''')
68  releases = c.fetchall()
69  rel_summary_temp = env.get_template('release_summary.html')
70  dir_summary_temp = env.get_template('directory_summary.html')
71 
72 
73  for rel_id, release_title, st_test in releases:
74  context = global_context.copy()
75  context.update(get_release_summary_stats(c, release_title, st_test, threshold))
76  context['release_title'] = release_title
77  context['st_test'] = st_test
78  create_page([path, release_title, st_test], rel_summary_temp.render(context))
79 
80  ## Generate RootFileComparison html pages
81  print('Generating %s (%s) comparison pages...' % (release_title, st_test))
82  c.execute('''SELECT id, directory_id FROM RootFileComparison WHERE release_comparison_id = ?;''', (rel_id,))
83  for file_id, file_top_dir_id in c.fetchall():
84  context['file_id'] = file_id
85  context.update(get_directory_summary_stats(c, [], file_id, threshold))
86  create_page([path, release_title, st_test, str(file_id)], dir_summary_temp.render(context))
87 
88  c.execute('''SELECT id FROM Directory WHERE parent_id=?''', (file_top_dir_id,))
89  children_dirs = c.fetchall()
90 
91  ## Generate Directory html pages
92  def create_dir_pages(c, dir_id, dir_path):
93  # Generate Directory page
94  c.execute('''SELECT name FROM Directory WHERE id=?''', (dir_id,))
95  dir_path.append(c.fetchone()[0])
96  context.update(get_directory_summary_stats(c, dir_path, file_id, threshold))
97  create_page([path, release_title, st_test, str(file_id)] + dir_path, dir_summary_temp.render(context))
98  # TODO: Call for subdirectories
99 
100  for children_dir in children_dirs:
101  create_dir_pages(c, children_dir[0], [])
102  print('Done.')
103 
104 
105 if __name__ == '__main__':
106  opts, args = parser.parse_args()
107  dbfile2html(opts.db_name, dirname(opts.db_name), opts.threshold)
S & print(S &os, JobReport::InputFile const &f)
Definition: JobReport.cc:65
def create_page(path, content)
Definition: dbfile2html.py:28
def db_list_with_releases(path='.')
Definition: app_utils.py:152
static std::string join(char **cmd)
Definition: RemoteFile.cc:18
def get_release_summary_stats(c, release_title, st_test, threshold=1e-5)
Definition: app_utils.py:165
def get_directory_summary_stats(c, url_args, file_id, threshold)
Definition: app_utils.py:285
def dbfile2html(db_name, work_path, threshold=1e-5)
Definition: dbfile2html.py:36
#define str(s)