diff options
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 000000000..2807c2bdc --- /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) | 
