diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2016-01-18 21:22:24 +0200 |
---|---|---|
committer | Jussi Pakkanen <jpakkane@gmail.com> | 2016-01-18 21:22:24 +0200 |
commit | a5528249ad353384e3c860c7207ef3eedbdcc6b7 (patch) | |
tree | 5f2a3fa61e5351231f6ffe8ca6b70d4f811093d7 /mesonbuild/mlog.py | |
parent | 2d1aa395e86848ca948d30d83cc5357777e5b490 (diff) | |
parent | f7e1d256ad78521052a41fe8f850793fa6cd4f01 (diff) | |
download | meson-a5528249ad353384e3c860c7207ef3eedbdcc6b7.zip meson-a5528249ad353384e3c860c7207ef3eedbdcc6b7.tar.gz meson-a5528249ad353384e3c860c7207ef3eedbdcc6b7.tar.bz2 |
Merge branch 'distutils'.
Diffstat (limited to 'mesonbuild/mlog.py')
-rw-r--r-- | mesonbuild/mlog.py | 81 |
1 files changed, 81 insertions, 0 deletions
diff --git a/mesonbuild/mlog.py b/mesonbuild/mlog.py new file mode 100644 index 0000000..2807c2b --- /dev/null +++ b/mesonbuild/mlog.py @@ -0,0 +1,81 @@ +# Copyright 2013-2014 The Meson development team + +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at + +# http://www.apache.org/licenses/LICENSE-2.0 + +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import sys, os, platform + +"""This is (mostly) a standalone module used to write logging +information about Meson runs. Some output goes to screen, +some to logging dir and some goes to both.""" + +colorize_console = platform.system().lower() != 'windows' and os.isatty(sys.stdout.fileno()) +log_dir = None +log_file = None + +def initialize(logdir): + global log_dir, log_file + log_dir = logdir + log_file = open(os.path.join(logdir, 'meson-log.txt'), 'w') + +def shutdown(): + global log_file + if log_file is not None: + log_file.close() + +class AnsiDecorator(): + plain_code = "\033[0m" + + def __init__(self, text, code): + self.text = text + self.code = code + + def get_text(self, with_codes): + if with_codes: + return self.code + self.text + AnsiDecorator.plain_code + return self.text + +def bold(text): + return AnsiDecorator(text, "\033[1m") + +def red(text): + return AnsiDecorator(text, "\033[1;31m") + +def green(text): + return AnsiDecorator(text, "\033[1;32m") + +def cyan(text): + return AnsiDecorator(text, "\033[1;36m") + +def process_markup(args, keep): + arr = [] + for arg in args: + if isinstance(arg, str): + arr.append(arg) + elif isinstance(arg, AnsiDecorator): + arr.append(arg.get_text(keep)) + else: + arr.append(str(arg)) + return arr + +def debug(*args, **kwargs): + arr = process_markup(args, False) + if log_file is not None: + print(*arr, file=log_file, **kwargs) # Log file never gets ANSI codes. + +def log(*args, **kwargs): + arr = process_markup(args, False) + if log_file is not None: + print(*arr, file=log_file, **kwargs) # Log file never gets ANSI codes. + if colorize_console: + arr = process_markup(args, True) + print(*arr, **kwargs) |