Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] switch from optparse to click (#236) #394

Merged
merged 2 commits into from
Sep 4, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion examples/compare.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@
sys.path.append('..')

import canmatrix.cli.compare
canmatrix.cli.compare.main()
canmatrix.cli.compare.cli_compare()
2 changes: 1 addition & 1 deletion examples/convert.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,4 @@
sys.path.append('..')

import canmatrix.cli.convert
canmatrix.cli.convert.main()
canmatrix.cli.convert.cli_convert()
86 changes: 24 additions & 62 deletions src/canmatrix/cli/compare.py
Original file line number Diff line number Diff line change
Expand Up @@ -25,75 +25,37 @@
from __future__ import print_function

import logging
import optparse
import sys
import typing
import click

import attr
import canmatrix.compare

logger = logging.getLogger(__name__)

@click.command()
@click.option('-v', '--verbose', 'verbosity', help="Output verbosity", count=True, default=1)
@click.option('-s', '--silent', is_flag=True, default=False, help="don't print status messages to stdout. (only errors)")
@click.option('-f', '--frames', is_flag=True, default=False, help="show list of frames")
@click.option('-c', '--comments', 'check_comments', is_flag=True, default=False, help="ignore changed comments")
@click.option('-a', '--attributes', 'check_attributes', is_flag=True, default=False, help="ignore changed attributes")
@click.option('-t', '--valueTable', 'ignore_valuetables', is_flag=True, default=False, help="ignore changed valuetables")
@click.argument('matrix1', required=1)
@click.argument('matrix2', required=1)
def cli_compare(matrix1, matrix2, verbosity, silent, check_comments, check_attributes, ignore_valuetables, frames): # type: () -> int
"""
canmatrix.cli.compare [options] matrix1 matrix2

matrixX can be any of *.dbc|*.dbf|*.kcd|*.arxml|*.xls(x)|*.sym
"""

def main(): # type: () -> int
import canmatrix.log
canmatrix.log.setup_logger()

usage = """
%prog [options] cancompare matrix1 matrix2

matrixX can be any of *.dbc|*.dbf|*.kcd|*.arxml
"""

parser = optparse.OptionParser(usage=usage)
parser.add_option(
"-s",
dest="silent",
action="store_true",
help="don't print status messages to stdout. (only errors)",
default=False)
parser.add_option(
"-v",
dest="verbosity",
action="count",
help="Output verbosity",
default=0)
parser.add_option(
"-f", "--frames",
dest="frames",
action="store_true",
help="show list of frames",
default=False)
parser.add_option(
"-c", "--comments",
dest="check_comments",
action="store_true",
help="check changed comments",
default=False)
parser.add_option(
"-a", "--attributes",
dest="check_attributes",
action="store_true",
help="check changed attributes",
default=False)
parser.add_option(
"-t", "--valueTable",
dest="ignore_valuetables",
action="store_true",
help="check changed valuetables",
default=False)

(cmdlineOptions, args) = parser.parse_args()

if len(args) < 2:
parser.print_help()
sys.exit(1)

matrix1 = args[0]
matrix2 = args[1]

verbosity = cmdlineOptions.verbosity
if cmdlineOptions.silent:
if silent:
# Only print ERROR messages (ignore import warnings)
verbosity = -1
canmatrix.log.set_log_level(logger, verbosity)
Expand All @@ -102,25 +64,25 @@ def main(): # type: () -> int
import canmatrix.formats # due this import we need the import alias for log module

logger.info("Importing " + matrix1 + " ... ")
db1 = next(iter(canmatrix.formats.loadp(matrix1).values()))
db1 = canmatrix.formats.loadp_flat(matrix1)
logger.info("%d Frames found" % (db1.frames.__len__()))

logger.info("Importing " + matrix2 + " ... ")
db2 = next(iter(canmatrix.formats.loadp(matrix2).values()))
db2 = canmatrix.formats.loadp_flat(matrix2)
logger.info("%d Frames found" % (db2.frames.__len__()))

ignore = {} # type: typing.Dict[str, typing.Union[str, bool]]

if not cmdlineOptions.check_comments:
if not check_comments:
ignore["comment"] = "*"

if not cmdlineOptions.check_attributes:
if not check_attributes:
ignore["ATTRIBUTE"] = "*"

if cmdlineOptions.ignore_valuetables:
if ignore_valuetables:
ignore["VALUETABLES"] = True

if cmdlineOptions.frames:
if frames:
only_in_matrix1 = [
frame.name
for frame in db1.frames
Expand All @@ -144,4 +106,4 @@ def main(): # type: () -> int

# to be run as module `python -m canmatrix.compare`, NOT as script with argument `canmatrix/compare.py`
if __name__ == '__main__':
sys.exit(main())
sys.exit(cli_compare())
Loading