# HG changeset patch # User krauss # Date 1318931943 -7200 # Node ID 13dddf30c79209c8ff3fd0aaffeb7fdfe56ffe51 # Parent 1466037faae4caa472e266664304472a8c5038af mira: collect size of heap images diff -r 1466037faae4 -r 13dddf30c792 Admin/mira.py --- a/Admin/mira.py Mon Oct 17 21:37:38 2011 +0200 +++ b/Admin/mira.py Tue Oct 18 11:59:03 2011 +0200 @@ -18,7 +18,6 @@ from mira import schedule, misc from mira.environment import scheduler - # build and evaluation tools default_usedir_options = "$ISABELLE_USEDIR_OPTIONS -d pdf -g true -i true -t true" @@ -67,6 +66,12 @@ writer.close() +def isabelle_getenv(isabelle_home, var): + + _, out = env.run_process('%s/bin/isabelle' % isabelle_home, 'getenv', var) + return out.split('=', 1)[1].strip() + + def extract_isabelle_run_timing(logdata): def to_secs(h, m, s): @@ -99,6 +104,18 @@ return summary +def extract_image_size(isabelle_home): + + isabelle_output = isabelle_getenv(isabelle_home, 'ISABELLE_OUTPUT') + return dict((p, path.getsize(path.join(isabelle_output, p))) for p in os.listdir(isabelle_output) if p != "log") + +def extract_report_data(isabelle_home, logdata): + + return { + 'timing': extract_isabelle_run_timing(logdata), + 'image_size': extract_image_size(isabelle_home) } + + @tool def import_isatest_log(env, conf, logfile): @@ -159,8 +176,9 @@ (return_code, log) = isabelle_usedir(env, isabelle_home, '-b', base, img) result = path.join(isabelle_home, 'heaps') + return (return_code == 0, extract_isabelle_run_summary(log), - {'timing': extract_isabelle_run_timing(log)}, {'log': log}, result) + extract_report_data(isabelle_home, log), {'log': log}, result) def isabelle_make(subdir, env, case, paths, dep_paths, playground, usedir_options=default_usedir_options, @@ -175,8 +193,9 @@ (return_code, log) = env.run_process('%s/bin/isabelle' % isabelle_home, 'make', '-k', target) result = path.join(isabelle_home, 'heaps') if keep_results else None + return (return_code == 0, extract_isabelle_run_summary(log), - {'timing': extract_isabelle_run_timing(log)}, {'log': log}, result) + extract_report_data(isabelle_home, log), {'log': log}, result) def isabelle_makeall(env, case, paths, dep_paths, playground, usedir_options=default_usedir_options, @@ -204,7 +223,7 @@ (return_code, log) = env.run_process('%s/bin/isabelle' % isabelle_home, 'makeall', '-k', *(make_options + (target,))) return (return_code == 0, extract_isabelle_run_summary(log), - {'timing': extract_isabelle_run_timing(log)}, {'log': log}, None) + extract_report_data(isabelle_home, log), {'log': log}, None) def make_pure(env, case, paths, dep_paths, playground, more_settings=''):