summaryrefslogtreecommitdiff
path: root/archive/src/log.c
blob: 8bb7a65d597123064c9afdab44875746d3fc0851 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include "log.h"

#include <stdarg.h>
#include <stdio.h>
#include <string.h>

#include "defines.h"

// Regular text
#define BLK "\e[0;30m"
#define RED "\e[0;31m"
#define GRN "\e[0;32m"
#define YEL "\e[0;33m"
#define BLU "\e[0;34m"
#define MAG "\e[0;35m"
#define CYN "\e[0;36m"
#define WHT "\e[0;37m"
#define CRESET "\e[0m"

static const char* level_strings[6] = { "[FATAL]: ", "[ERROR]: ", "[WARN]: ",
                                        "[INFO]: ",  "[DEBUG]: ", "[TRACE]: " };
static const char* level_colours[6] = { RED, RED, YEL, BLU, CYN, MAG };

bool logger_init() {
  // TODO: create log file
  return true;
}

void logger_shutdown() {
  // does nothing right now
}

void log_output(log_level level, const char* message, ...) {
  char out_message[32000];
  memset(out_message, 0, sizeof(out_message));

  // format original message
  __builtin_va_list arg_ptr;
  va_start(arg_ptr, message);
  vsnprintf(out_message, 32000, message, arg_ptr);
  va_end(arg_ptr);

  char out_message2[32006];
  // prepend log level string
  sprintf(out_message2, "%s%s%s%s\n", level_colours[level], level_strings[level], out_message,
          CRESET);

  // print message to console
  printf("%s", out_message2);
}

void report_assertion_failure(const char* expression, const char* message, const char* file,
                              int line) {
  log_output(LOG_LEVEL_FATAL, "Assertion failure: %s, message: '%s', in file: %s, on line %d\n",
             expression, message, file, line);
}