2015-09-24 23:52:02 +03:00
|
|
|
/*
|
2018-07-30 09:07:02 +07:00
|
|
|
* This is the source code of tgnet library v. 1.1
|
2015-09-24 23:52:02 +03:00
|
|
|
* It is licensed under GNU GPL v. 2 or later.
|
|
|
|
* You should have received a copy of the license in this archive (see LICENSE).
|
|
|
|
*
|
2018-07-30 09:07:02 +07:00
|
|
|
* Copyright Nikolai Kudashov, 2015-2018.
|
2015-09-24 23:52:02 +03:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
2015-10-29 20:10:07 +03:00
|
|
|
#include <time.h>
|
2015-09-24 23:52:02 +03:00
|
|
|
#include "FileLog.h"
|
2018-07-30 09:07:02 +07:00
|
|
|
#include "ConnectionsManager.h"
|
2015-09-24 23:52:02 +03:00
|
|
|
|
|
|
|
#ifdef ANDROID
|
|
|
|
#include <android/log.h>
|
|
|
|
#endif
|
|
|
|
|
2019-01-23 20:03:33 +03:00
|
|
|
#ifdef DEBUG_VERSION
|
|
|
|
bool LOGS_ENABLED = true;
|
|
|
|
#else
|
|
|
|
bool LOGS_ENABLED = false;
|
|
|
|
#endif
|
|
|
|
|
2018-07-30 09:07:02 +07:00
|
|
|
FileLog &FileLog::getInstance() {
|
|
|
|
static FileLog instance;
|
|
|
|
return instance;
|
|
|
|
}
|
|
|
|
|
|
|
|
FileLog::FileLog() {
|
|
|
|
pthread_mutex_init(&mutex, NULL);
|
|
|
|
}
|
2015-10-29 20:10:07 +03:00
|
|
|
|
|
|
|
void FileLog::init(std::string path) {
|
2018-07-30 09:07:02 +07:00
|
|
|
pthread_mutex_lock(&mutex);
|
|
|
|
if (path.size() > 0 && logFile == nullptr) {
|
2015-11-27 00:04:02 +03:00
|
|
|
logFile = fopen(path.c_str(), "w");
|
|
|
|
}
|
2018-07-30 09:07:02 +07:00
|
|
|
pthread_mutex_unlock(&mutex);
|
2015-10-29 20:10:07 +03:00
|
|
|
}
|
|
|
|
|
2015-09-24 23:52:02 +03:00
|
|
|
void FileLog::e(const char *message, ...) {
|
2019-01-23 20:03:33 +03:00
|
|
|
if (!LOGS_ENABLED) {
|
|
|
|
return;
|
|
|
|
}
|
2015-09-24 23:52:02 +03:00
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, message);
|
2015-10-29 20:10:07 +03:00
|
|
|
time_t t = time(0);
|
|
|
|
struct tm *now = localtime(&t);
|
2015-09-24 23:52:02 +03:00
|
|
|
#ifdef ANDROID
|
|
|
|
__android_log_vprint(ANDROID_LOG_ERROR, "tgnet", message, argptr);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#else
|
2015-10-29 20:10:07 +03:00
|
|
|
printf("%d-%d %02d:%02d:%02d error: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
2015-09-24 23:52:02 +03:00
|
|
|
vprintf(message, argptr);
|
|
|
|
printf("\n");
|
|
|
|
fflush(stdout);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#endif
|
2018-07-30 09:07:02 +07:00
|
|
|
FILE *logFile = getInstance().logFile;
|
2015-10-29 20:10:07 +03:00
|
|
|
if (logFile) {
|
|
|
|
fprintf(logFile, "%d-%d %02d:%02d:%02d error: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
|
|
|
vfprintf(logFile, message, argptr);
|
|
|
|
fprintf(logFile, "\n");
|
|
|
|
fflush(logFile);
|
|
|
|
}
|
|
|
|
|
2015-09-24 23:52:02 +03:00
|
|
|
va_end(argptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FileLog::w(const char *message, ...) {
|
2019-01-23 20:03:33 +03:00
|
|
|
if (!LOGS_ENABLED) {
|
|
|
|
return;
|
|
|
|
}
|
2015-09-24 23:52:02 +03:00
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, message);
|
2015-10-29 20:10:07 +03:00
|
|
|
time_t t = time(0);
|
|
|
|
struct tm *now = localtime(&t);
|
2015-09-24 23:52:02 +03:00
|
|
|
#ifdef ANDROID
|
|
|
|
__android_log_vprint(ANDROID_LOG_WARN, "tgnet", message, argptr);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#else
|
2015-10-29 20:10:07 +03:00
|
|
|
printf("%d-%d %02d:%02d:%02d warning: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
2015-09-24 23:52:02 +03:00
|
|
|
vprintf(message, argptr);
|
|
|
|
printf("\n");
|
|
|
|
fflush(stdout);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#endif
|
2018-07-30 09:07:02 +07:00
|
|
|
FILE *logFile = getInstance().logFile;
|
2015-10-29 20:10:07 +03:00
|
|
|
if (logFile) {
|
|
|
|
fprintf(logFile, "%d-%d %02d:%02d:%02d warning: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
|
|
|
vfprintf(logFile, message, argptr);
|
|
|
|
fprintf(logFile, "\n");
|
|
|
|
fflush(logFile);
|
|
|
|
}
|
|
|
|
|
2015-09-24 23:52:02 +03:00
|
|
|
va_end(argptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FileLog::d(const char *message, ...) {
|
2019-01-23 20:03:33 +03:00
|
|
|
if (!LOGS_ENABLED) {
|
|
|
|
return;
|
|
|
|
}
|
2015-09-24 23:52:02 +03:00
|
|
|
va_list argptr;
|
|
|
|
va_start(argptr, message);
|
2015-10-29 20:10:07 +03:00
|
|
|
time_t t = time(0);
|
|
|
|
struct tm *now = localtime(&t);
|
2015-09-24 23:52:02 +03:00
|
|
|
#ifdef ANDROID
|
|
|
|
__android_log_vprint(ANDROID_LOG_DEBUG, "tgnet", message, argptr);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#else
|
2015-10-29 20:10:07 +03:00
|
|
|
printf("%d-%d %02d:%02d:%02d debug: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
2015-09-24 23:52:02 +03:00
|
|
|
vprintf(message, argptr);
|
|
|
|
printf("\n");
|
|
|
|
fflush(stdout);
|
2018-07-30 09:07:02 +07:00
|
|
|
va_end(argptr);
|
|
|
|
va_start(argptr, message);
|
2015-09-24 23:52:02 +03:00
|
|
|
#endif
|
2018-07-30 09:07:02 +07:00
|
|
|
FILE *logFile = getInstance().logFile;
|
2015-10-29 20:10:07 +03:00
|
|
|
if (logFile) {
|
|
|
|
fprintf(logFile, "%d-%d %02d:%02d:%02d debug: ", now->tm_mon + 1, now->tm_mday, now->tm_hour, now->tm_min, now->tm_sec);
|
|
|
|
vfprintf(logFile, message, argptr);
|
|
|
|
fprintf(logFile, "\n");
|
|
|
|
fflush(logFile);
|
|
|
|
}
|
|
|
|
|
2015-09-24 23:52:02 +03:00
|
|
|
va_end(argptr);
|
|
|
|
}
|