aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/basetypes/MCLog.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/basetypes/MCLog.c')
-rw-r--r--src/core/basetypes/MCLog.c79
1 files changed, 79 insertions, 0 deletions
diff --git a/src/core/basetypes/MCLog.c b/src/core/basetypes/MCLog.c
new file mode 100644
index 00000000..8744f2dd
--- /dev/null
+++ b/src/core/basetypes/MCLog.c
@@ -0,0 +1,79 @@
+#include "MCLog.h"
+
+#include <stdarg.h>
+#include <string.h>
+#include <stdio.h>
+#include <time.h>
+#include <sys/time.h>
+#include <pthread.h>
+#include <unistd.h>
+
+static pid_t sPid = -1;
+int MCLogEnabled = 0;
+
+__attribute__((constructor))
+static void initialize() {
+ sPid = getpid();
+}
+
+static void logInternalv(FILE * file,
+ const char * user, const char * filename, unsigned int line,
+ int dumpStack, const char * format, va_list argp);
+
+void MCLogInternal(const char * user,
+ const char * filename,
+ unsigned int line,
+ int dumpStack,
+ const char * format, ...)
+{
+ va_list argp;
+
+ va_start(argp, format);
+ logInternalv(stderr, user, filename, line, dumpStack, format, argp);
+ va_end(argp);
+}
+
+static void logInternalv(FILE * file,
+ const char * user, const char * filename, unsigned int line,
+ int dumpStack, const char * format, va_list argp)
+{
+ if (!MCLogEnabled)
+ return;
+
+ while (1) {
+ const char * p = filename;
+
+ p = strchr(filename, '/');
+ if (p == NULL) {
+ break;
+ }
+ filename = p + 1;
+ }
+
+ struct timeval tv;
+ struct tm tm_value;
+ pthread_t thread_id = pthread_self();
+
+ gettimeofday(&tv, NULL);
+ localtime_r(&tv.tv_sec, &tm_value);
+ fprintf(file, "%04u-%02u-%02u %02u:%02u:%02u.%03u ", tm_value.tm_year + 1900, tm_value.tm_mon + 1, tm_value.tm_mday, tm_value.tm_hour, tm_value.tm_min, tm_value.tm_sec, (int) (tv.tv_usec / 1000));
+
+#ifdef __MACH__
+ if (pthread_main_np()) {
+#else
+ if (0) {
+#endif
+ fprintf(file, "[%i:main] %s:%i: ", sPid, filename, line);
+ }
+ else {
+ unsigned long threadValue;
+#ifdef _MACH_PORT_T
+ threadValue = pthread_mach_thread_np(thread_id);
+#else
+ threadValue = (unsigned long) thread_id;
+#endif
+ fprintf(file, "[%i:%lx] %s:%i: ", sPid, threadValue, filename, line);
+ }
+ vfprintf(file, format, argp);
+ fprintf(file, "\n");
+}