summaryrefslogtreecommitdiffstats
path: root/gitlint-core/gitlint/display.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:49:10 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-28 09:49:10 +0000
commita85f3954a8fe112640c2c35da3228be29b17c97c (patch)
tree7ee43f79639ee53903e7ca389e548974e1497c3a /gitlint-core/gitlint/display.py
parentInitial commit. (diff)
downloadgitlint-a85f3954a8fe112640c2c35da3228be29b17c97c.tar.xz
gitlint-a85f3954a8fe112640c2c35da3228be29b17c97c.zip
Adding upstream version 0.18.0.upstream/0.18.0upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'gitlint-core/gitlint/display.py')
-rw-r--r--gitlint-core/gitlint/display.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/gitlint-core/gitlint/display.py b/gitlint-core/gitlint/display.py
new file mode 100644
index 0000000..d21b6c3
--- /dev/null
+++ b/gitlint-core/gitlint/display.py
@@ -0,0 +1,36 @@
+from sys import stdout, stderr
+
+
+class Display:
+ """Utility class to print stuff to an output stream (stdout by default) based on the config's verbosity"""
+
+ def __init__(self, lint_config):
+ self.config = lint_config
+
+ def _output(self, message, verbosity, exact, stream):
+ """Output a message if the config's verbosity is >= to the given verbosity. If exact == True, the message
+ will only be outputted if the given verbosity exactly matches the config's verbosity."""
+ if exact:
+ if self.config.verbosity == verbosity:
+ stream.write(message + "\n")
+ else:
+ if self.config.verbosity >= verbosity:
+ stream.write(message + "\n")
+
+ def v(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 1, exact, stdout)
+
+ def vv(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 2, exact, stdout)
+
+ def vvv(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 3, exact, stdout)
+
+ def e(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 1, exact, stderr)
+
+ def ee(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 2, exact, stderr)
+
+ def eee(self, message, exact=False): # pylint: disable=invalid-name
+ self._output(message, 3, exact, stderr)