2018-08-16 23:10:15 +08:00
|
|
|
// SPDX-License-Identifier: LGPL-2.1
|
2012-09-09 02:00:51 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2010 Red Hat Inc, Steven Rostedt <srostedt@redhat.com>
|
|
|
|
*
|
|
|
|
*/
|
2012-04-06 06:47:53 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
#include <errno.h>
|
|
|
|
|
|
|
|
#define __weak __attribute__((weak))
|
|
|
|
|
|
|
|
void __vwarning(const char *fmt, va_list ap)
|
|
|
|
{
|
|
|
|
if (errno)
|
|
|
|
perror("trace-cmd");
|
|
|
|
errno = 0;
|
|
|
|
|
|
|
|
fprintf(stderr, " ");
|
|
|
|
vfprintf(stderr, fmt, ap);
|
|
|
|
|
|
|
|
fprintf(stderr, "\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
void __warning(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, fmt);
|
|
|
|
__vwarning(fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
}
|
|
|
|
|
|
|
|
void __weak warning(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, fmt);
|
|
|
|
__vwarning(fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
}
|
|
|
|
|
|
|
|
void __vpr_stat(const char *fmt, va_list ap)
|
|
|
|
{
|
|
|
|
vprintf(fmt, ap);
|
|
|
|
printf("\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
void __pr_stat(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, fmt);
|
|
|
|
__vpr_stat(fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
}
|
|
|
|
|
|
|
|
void __weak vpr_stat(const char *fmt, va_list ap)
|
|
|
|
{
|
|
|
|
__vpr_stat(fmt, ap);
|
|
|
|
}
|
|
|
|
|
|
|
|
void __weak pr_stat(const char *fmt, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, fmt);
|
|
|
|
__vpr_stat(fmt, ap);
|
|
|
|
va_end(ap);
|
|
|
|
}
|