struct _ply_logger
{
int output_fd;
+ bool output_fd_is_terminal;
char *filename;
char *buffer;
logger = calloc (1, sizeof(ply_logger_t));
logger->output_fd = -1;
+ logger->output_fd_is_terminal = false;
logger->filename = NULL;
logger->is_enabled = true;
logger->tracing_is_enabled = false;
assert (logger != NULL);
logger->output_fd = fd;
+ logger->output_fd_is_terminal = isatty(fd);
}
int
return logger->tracing_is_enabled != false;
}
+
+bool
+ply_logger_is_tracing_to_terminal (ply_logger_t *logger)
+{
+ assert (logger != NULL);
+
+ return logger->tracing_is_enabled && logger->output_fd_is_terminal;
+}
+
#endif /* PLY_ENABLE_TRACING */
/* vim: set ts=4 sw=4 expandtab autoindent cindent cino={.5s,(0: */
#ifdef PLY_ENABLE_TRACING
void ply_logger_toggle_tracing (ply_logger_t *logger);
bool ply_logger_is_tracing_enabled (ply_logger_t *logger);
+bool ply_logger_is_tracing_to_terminal (ply_logger_t *logger);
#define ply_logger_trace(logger, format, args ...) \
do \
#define ply_logger_trace(logger, format, args ...)
#define ply_logger_toggle_tracing(logger)
#define ply_logger_is_tracing_enabled(logger) (false)
+#define ply_logger_is_tracing_to_terminal(logger) (false)
#endif /* PLY_ENABLE_TRACING */
/* convenience macros
ply_logger_toggle_tracing (ply_logger_get_error_default ())
#define ply_is_tracing() \
ply_logger_is_tracing_enabled (ply_logger_get_error_default ())
+#define ply_is_tracing_to_terminal() \
+ ply_logger_is_tracing_to_terminal (ply_logger_get_error_default ())
#define ply_trace(format, args ...) \
ply_logger_trace (ply_logger_get_error_default (), format, ## args)