de4dot-cex/dumpMethodsN/log.cpp
2011-09-22 04:55:30 +02:00

77 lines
1.7 KiB
C++

/*
Copyright (C) 2011 de4dot@gmail.com
This file is part of de4dot.
de4dot 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.
de4dot 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 de4dot. If not, see <http://www.gnu.org/licenses/>.
*/
#include <stdio.h>
#include <stdarg.h>
#include "log.h"
enum {
error,
warning,
normal,
verbose,
veryverbose,
};
static int logLevel = normal;
void setLogLevel(int level) {
logLevel = level;
}
static void log(int level, const char* format, va_list valist) {
if (level <= logLevel)
vprintf(format, valist);
}
void loge(const char* format, ...) {
va_list argptr;
va_start(argptr, format);
log(error, format, argptr);
va_end(argptr);
}
void logw(const char* format, ...) {
va_list argptr;
va_start(argptr, format);
log(warning, format, argptr);
va_end(argptr);
}
void logn(const char* format, ...) {
va_list argptr;
va_start(argptr, format);
log(normal, format, argptr);
va_end(argptr);
}
void logv(const char* format, ...) {
va_list argptr;
va_start(argptr, format);
log(verbose, format, argptr);
va_end(argptr);
}
void logvv(const char* format, ...) {
va_list argptr;
va_start(argptr, format);
log(veryverbose, format, argptr);
va_end(argptr);
}