Use namespaces instead of full classes

This commit is contained in:
Darryl Green 2019-04-09 09:14:17 +01:00
parent 26dff8e68d
commit 30dc6d5bb9

View file

@ -24,36 +24,15 @@ import argparse
import logging import logging
import tempfile import tempfile
import fnmatch import fnmatch
from types import SimpleNamespace
import xml.etree.ElementTree as ET import xml.etree.ElementTree as ET
class RepoVersion(object):
def __init__(self, version, repository, revision,
crypto_repository, crypto_revision):
"""Class containing details for a particular revision.
version: either 'old' or 'new'
repository: repository for git revision
revision: git revision for comparison
crypto_repository: repository for git revision of crypto submodule
crypto_revision: git revision of crypto submodule
"""
self.version = version
self.repository = repository
self.revision = revision
self.crypto_repository = crypto_repository
self.crypto_revision = crypto_revision
self.abi_dumps = {}
self.modules = {}
class AbiChecker(object): class AbiChecker(object):
"""API and ABI checker.""" """API and ABI checker."""
def __init__(self, verbose, old_version, new_version, report_dir, def __init__(self, old_version, new_version, configuration):
keep_all_reports, brief, skip_file=None):
"""Instantiate the API/ABI checker. """Instantiate the API/ABI checker.
old_version: RepoVersion containing details to compare against old_version: RepoVersion containing details to compare against
@ -65,16 +44,16 @@ class AbiChecker(object):
""" """
self.repo_path = "." self.repo_path = "."
self.log = None self.log = None
self.verbose = verbose self.verbose = configuration.verbose
self._setup_logger() self._setup_logger()
self.report_dir = os.path.abspath(report_dir) self.report_dir = os.path.abspath(configuration.report_dir)
self.keep_all_reports = keep_all_reports self.keep_all_reports = configuration.keep_all_reports
self.can_remove_report_dir = not (os.path.isdir(self.report_dir) or self.can_remove_report_dir = not (os.path.isdir(self.report_dir) or
keep_all_reports) self.keep_all_reports)
self.old_version = old_version self.old_version = old_version
self.new_version = new_version self.new_version = new_version
self.skip_file = skip_file self.skip_file = configuration.skip_file
self.brief = brief self.brief = configuration.brief
self.git_command = "git" self.git_command = "git"
self.make_command = "make" self.make_command = "make"
@ -418,18 +397,32 @@ def run_main():
help="output only the list of issues to stdout, instead of a full report", help="output only the list of issues to stdout, instead of a full report",
) )
abi_args = parser.parse_args() abi_args = parser.parse_args()
old_version = RepoVersion( old_version = SimpleNamespace(
"old", abi_args.old_repo, abi_args.old_rev, version="old",
abi_args.old_crypto_repo, abi_args.old_crypto_rev repository=abi_args.old_repo,
revision=abi_args.old_rev,
crypto_repository=abi_args.old_crypto_repo,
crypto_revision=abi_args.old_crypto_rev,
abi_dumps={},
modules={}
) )
new_version = RepoVersion( new_version = SimpleNamespace(
"new", abi_args.new_repo, abi_args.new_rev, version="new",
abi_args.new_crypto_repo, abi_args.new_crypto_rev repository=abi_args.new_repo,
revision=abi_args.new_rev,
crypto_repository=abi_args.new_crypto_repo,
crypto_revision=abi_args.new_crypto_rev,
abi_dumps={},
modules={}
) )
abi_check = AbiChecker( configuration = SimpleNamespace(
abi_args.verbose, old_version, new_version, abi_args.report_dir, verbose=abi_args.verbose,
abi_args.keep_all_reports, abi_args.brief, abi_args.skip_file report_dir=abi_args.report_dir,
keep_all_reports=abi_args.keep_all_reports,
brief=abi_args.brief,
skip_file=abi_args.skip_file
) )
abi_check = AbiChecker(old_version, new_version, configuration)
return_code = abi_check.check_for_abi_changes() return_code = abi_check.check_for_abi_changes()
sys.exit(return_code) sys.exit(return_code)
except Exception: # pylint: disable=broad-except except Exception: # pylint: disable=broad-except