Truncate some long messages sent to a TTY.

Can be overridden with the --truncate option.
pull/36291/merge
Matt Clay 7 years ago
parent 80b55e3742
commit d2150795ba

@ -5,6 +5,7 @@ from __future__ import absolute_import, print_function
import atexit import atexit
import errno import errno
import filecmp import filecmp
import fcntl
import inspect import inspect
import json import json
import os import os
@ -20,6 +21,9 @@ import sys
import tempfile import tempfile
import time import time
from struct import unpack, pack
from termios import TIOCGWINSZ
try: try:
from abc import ABC from abc import ABC
except ImportError: except ImportError:
@ -300,7 +304,7 @@ def raw_command(cmd, capture=False, env=None, data=None, cwd=None, explain=False
escaped_cmd = ' '.join(pipes.quote(c) for c in cmd) escaped_cmd = ' '.join(pipes.quote(c) for c in cmd)
display.info('Run command: %s' % escaped_cmd, verbosity=cmd_verbosity) display.info('Run command: %s' % escaped_cmd, verbosity=cmd_verbosity, truncate=True)
display.info('Working directory: %s' % cwd, verbosity=2) display.info('Working directory: %s' % cwd, verbosity=2)
program = find_executable(cmd[0], cwd=cwd, path=env['PATH'], required='warning') program = find_executable(cmd[0], cwd=cwd, path=env['PATH'], required='warning')
@ -484,6 +488,12 @@ class Display(object):
self.warnings = [] self.warnings = []
self.warnings_unique = set() self.warnings_unique = set()
self.info_stderr = False self.info_stderr = False
self.rows = 0
self.columns = 0
self.truncate = 0
if os.isatty(0):
self.rows, self.columns = unpack('HHHH', fcntl.ioctl(0, TIOCGWINSZ, pack('HHHH', 0, 0, 0, 0)))[:2]
def __warning(self, message): def __warning(self, message):
""" """
@ -527,21 +537,27 @@ class Display(object):
""" """
self.print_message('ERROR: %s' % message, color=self.red, fd=sys.stderr) self.print_message('ERROR: %s' % message, color=self.red, fd=sys.stderr)
def info(self, message, verbosity=0): def info(self, message, verbosity=0, truncate=False):
""" """
:type message: str :type message: str
:type verbosity: int :type verbosity: int
:type truncate: bool
""" """
if self.verbosity >= verbosity: if self.verbosity >= verbosity:
color = self.verbosity_colors.get(verbosity, self.yellow) color = self.verbosity_colors.get(verbosity, self.yellow)
self.print_message(message, color=color, fd=sys.stderr if self.info_stderr else sys.stdout) self.print_message(message, color=color, fd=sys.stderr if self.info_stderr else sys.stdout, truncate=truncate)
def print_message(self, message, color=None, fd=sys.stdout): # pylint: disable=locally-disabled, invalid-name def print_message(self, message, color=None, fd=sys.stdout, truncate=False): # pylint: disable=locally-disabled, invalid-name
""" """
:type message: str :type message: str
:type color: str | None :type color: str | None
:type fd: file :type fd: file
:type truncate: bool
""" """
if truncate:
if len(message) > self.truncate > 5:
message = message[:self.truncate - 5] + ' ...'
if color and self.color: if color and self.color:
# convert color resets in message to desired color # convert color resets in message to desired color
message = message.replace(self.clear, color) message = message.replace(self.clear, color)
@ -616,6 +632,7 @@ class CommonConfig(object):
self.explain = args.explain # type: bool self.explain = args.explain # type: bool
self.verbosity = args.verbosity # type: int self.verbosity = args.verbosity # type: int
self.debug = args.debug # type: bool self.debug = args.debug # type: bool
self.truncate = args.truncate # type: int
def docker_qualify_image(name): def docker_qualify_image(name):

@ -79,6 +79,7 @@ def main():
args = parse_args() args = parse_args()
config = args.config(args) config = args.config(args)
display.verbosity = config.verbosity display.verbosity = config.verbosity
display.truncate = config.truncate
display.color = config.color display.color = config.color
display.info_stderr = (isinstance(config, SanityConfig) and config.lint) or (isinstance(config, IntegrationConfig) and config.list_targets) display.info_stderr = (isinstance(config, SanityConfig) and config.lint) or (isinstance(config, IntegrationConfig) and config.list_targets)
check_startup() check_startup()
@ -149,6 +150,13 @@ def parse_args():
action='store_true', action='store_true',
help='run ansible commands in debug mode') help='run ansible commands in debug mode')
common.add_argument('--truncate',
dest='truncate',
metavar='COLUMNS',
type=int,
default=display.columns,
help='truncate some long output (0=disabled) (default: auto)')
test = argparse.ArgumentParser(add_help=False, parents=[common]) test = argparse.ArgumentParser(add_help=False, parents=[common])
test.add_argument('include', test.add_argument('include',

Loading…
Cancel
Save