# ----------------------------------------------------------------------- # Copyright: 2010-2018, imec Vision Lab, University of Antwerp # 2013-2018, CWI, Amsterdam # # Contact: astra@astra-toolbox.com # Website: http://www.astra-toolbox.com/ # # This file is part of the ASTRA Toolbox. # # # The ASTRA Toolbox is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # The ASTRA Toolbox is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with the ASTRA Toolbox. If not, see <http://www.gnu.org/licenses/>. # # ----------------------------------------------------------------------- from . import log_c as l import inspect def debug(message): """Log a debug message. :param message: Message to log. :type message: :class:`string` """ prev_f = inspect.getframeinfo(inspect.currentframe().f_back) l.log_debug(prev_f.filename,prev_f.lineno,message) def info(message): """Log an info message. :param message: Message to log. :type message: :class:`string` """ prev_f = inspect.getframeinfo(inspect.currentframe().f_back) l.log_info(prev_f.filename,prev_f.lineno,message) def warn(message): """Log a warning message. :param message: Message to log. :type message: :class:`string` """ prev_f = inspect.getframeinfo(inspect.currentframe().f_back) l.log_warn(prev_f.filename,prev_f.lineno,message) def error(message): """Log an error message. :param message: Message to log. :type message: :class:`string` """ prev_f = inspect.getframeinfo(inspect.currentframe().f_back) l.log_error(prev_f.filename,prev_f.lineno,message) def enable(): """Enable logging to screen and file.""" l.log_enable() def enableScreen(): """Enable logging to screen.""" l.log_enableScreen() def enableFile(): """Enable logging to file (note that a file has to be set).""" l.log_enableFile() def disable(): """Disable all logging.""" l.log_disable() def disableScreen(): """Disable logging to screen.""" l.log_disableScreen() def disableFile(): """Disable logging to file.""" l.log_disableFile() def setFormatFile(fmt): """Set the format string for log messages. Here are the substitutions you may use: %f: Source file name generating the log call. %n: Source line number where the log call was made. %m: The message text sent to the logger (after printf formatting). %d: The current date, formatted using the logger's date format. %t: The current time, formatted using the logger's time format. %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). %%: A literal percent sign. The default format string is "%d %t %f(%n): %l: %m\n". :param fmt: Format to use, end with "\n". :type fmt: :class:`string` """ l.log_setFormatFile(fmt) def setFormatScreen(fmt): """Set the format string for log messages. Here are the substitutions you may use: %f: Source file name generating the log call. %n: Source line number where the log call was made. %m: The message text sent to the logger (after printf formatting). %d: The current date, formatted using the logger's date format. %t: The current time, formatted using the logger's time format. %l: The log level (one of "DEBUG", "INFO", "WARN", or "ERROR"). %%: A literal percent sign. The default format string is "%d %t %f(%n): %l: %m\n". :param fmt: Format to use, end with "\n". :type fmt: :class:`string` """ l.log_setFormatScreen(fmt) STDOUT=1 STDERR=2 DEBUG=0 INFO=1 WARN=2 ERROR=3 def setOutputScreen(fd, level): """Set which screen to output to, and which level to use. :param fd: File descriptor of output screen (STDOUT or STDERR). :type fd: :class:`int` :param level: Logging level to use (DEBUG, INFO, WARN, or ERROR). :type level: :class:`int` """ l.log_setOutputScreen(fd, level) def setOutputFile(filename, level): """Set which file to output to, and which level to use. :param filename: File name of output file. :type filename: :class:`string` :param level: Logging level to use (DEBUG, INFO, WARN, or ERROR). :type level: :class:`int` """ l.log_setOutputFile(filename, level)