blob: c44fcd7f74d36a3e3047df11cd6c2b7384ea14bd [file] [log] [blame]
# -*- coding: utf-8 -*-
# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Generates a clang-tidy tarball for the clang-tidy builder."""
from __future__ import print_function
import os
import shutil
from chromite.lib import cros_build_lib
from chromite.lib import commandline
from chromite.lib import osutils
from chromite.lib import sudo
DEFAULT_NAME = 'clang_tidy_warnings.tar.xz'
TIDY_WARNINGS = 'clang_tidy_warnings'
PARSING_SCRIPT = '/usr/bin/clang-tidy-parse-build-log.py'
WORKING_DIR = '/usr/bin'
def ParseCommandLine(argv):
"""Parse args, and run environment-independent checks."""
parser = commandline.ArgumentParser(description=__doc__)
parser.add_argument('--board', required=True,
help=('The board to generate the sysroot for.'))
parser.add_argument('--logs-dir', required=True,
help=('The directory containg the logs files to '
'be parsed.'))
parser.add_argument('--out-dir', type='path', required=True,
help='Directory to place the generated tarball.')
parser.add_argument('--out-file', default=DEFAULT_NAME,
help='The name to give to the tarball. '
'Defaults to %(default)s.')
options = parser.parse_args(argv)
return options
class GenerateTidyWarnings(object):
"""Wrapper for generation functionality."""
def __init__(self, warnings_dir, options):
"""Initialize
Args:
warnings_dir: Path to warnings directory.
options: Parsed options.
"""
self.warnings_dir = warnings_dir
self.options = options
def _FindLogFiles(self, logs_dir):
files = []
filelist = os.listdir(logs_dir)
for f in filelist:
logfile = os.path.join(logs_dir, f)
files.append(logfile)
return files
def _ParseLogFiles(self):
log_files = self._FindLogFiles(self.options.logs_dir)
for f in log_files:
cmd = [PARSING_SCRIPT, '--log_file', f, '--output_dir', self.warnings_dir]
cros_build_lib.RunCommand(cmd, cwd=WORKING_DIR, enter_chroot=True)
# Copy log file to output directory. We want the log files in the
# tarball, for now, in case we ever need to re-process them. (A
# possibility, since the final dashboard details have not been worked out
# yet.)
shutil.copy2(f, self.warnings_dir)
def _CreateTarball(self):
target = os.path.join(self.options.out_dir, self.options.out_file)
cros_build_lib.CreateTarball(target, self.warnings_dir, sudo=True)
def Perform(self):
"""Generate the warnings files."""
self._ParseLogFiles()
self._CreateTarball()
def FinishParsing(options):
"""Run environment dependent checks on parsed args."""
target = os.path.join(options.out_dir, options.out_file)
if os.path.exists(target):
cros_build_lib.Die('Output file %r already exists.' % target)
if not os.path.isdir(options.out_dir):
cros_build_lib.Die(
'Non-existent directory %r specified for --out-dir' % options.out_dir)
def main(argv):
options = ParseCommandLine(argv)
FinishParsing(options)
cros_build_lib.AssertInsideChroot()
with sudo.SudoKeepAlive(ttyless_sudo=False):
with osutils.TempDir(set_global=True, sudo_rm=True) as tempdir:
warnings_dir = os.path.join(tempdir, TIDY_WARNINGS)
os.mkdir(warnings_dir)
GenerateTidyWarnings(warnings_dir, options).Perform()