summaryrefslogtreecommitdiff
path: root/src/stlink-lib/logging.c
blob: 87978230dceeff4b3eaa62231a672f53a7668ca6 (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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/*
 * UglyLogging
 *
 * Slow, yet another wheel reinvented, but enough to make the rest of our code
 * pretty enough.
 */
#include <stdarg.h>
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#include "logging.h"

static int max_level = UDEBUG;

int ugly_init(int maximum_threshold) {
  max_level = maximum_threshold;
  return (0);
}

int ugly_log(int level, const char *tag, const char *format, ...) {
  if (level > max_level) {
    return (0);
  }

  fflush(stdout); // flush to maintain order of streams

  va_list args;
  va_start(args, format);
  time_t mytt = time(NULL);
  struct tm *tt;
  tt = localtime(&mytt);
  fprintf(stderr, "%d-%02d-%02dT%02d:%02d:%02d ", tt->tm_year + 1900,
          tt->tm_mon + 1, tt->tm_mday, tt->tm_hour, tt->tm_min, tt->tm_sec);

  switch (level) {
  case UDEBUG:
    fprintf(stderr, "DEBUG %s: ", tag);
    break;
  case UINFO:
    fprintf(stderr, "INFO %s: ", tag);
    break;
  case UWARN:
    fprintf(stderr, "WARN %s: ", tag);
    break;
  case UERROR:
    fprintf(stderr, "ERROR %s: ", tag);
    break;
  default:
    fprintf(stderr, "%d %s: ", level, tag);
    break;
  }

  vfprintf(stderr, format, args);
  fflush(stderr);
  va_end(args);
  return (1);
}

/*
 *  Log message levels.
 *  - LIBUSB_LOG_LEVEL_NONE (0)    : no messages ever printed by the library
 * (default)
 *  - LIBUSB_LOG_LEVEL_ERROR (1)   : error messages are printed to stderr
 *  - LIBUSB_LOG_LEVEL_WARNING (2) : warning and error messages are printed to
 * stderr
 *  - LIBUSB_LOG_LEVEL_INFO (3)    : informational messages are printed to
 * stderr
 *  - LIBUSB_LOG_LEVEL_DEBUG (4)   : debug and informational messages are
 * printed to stderr
 */
int ugly_libusb_log_level(enum ugly_loglevel v) {
#ifdef __FreeBSD__
  // FreeBSD includes its own reimplementation of libusb.
  // Its libusb_set_debug() function expects a lib_debug_level
  // instead of a lib_log_level and is verbose enough to drown out
  // all other output.
  switch (v) {
  case UDEBUG:
    return (3); // LIBUSB_DEBUG_FUNCTION + LIBUSB_DEBUG_TRANSFER
  case UINFO:
    return (1); // LIBUSB_DEBUG_FUNCTION only
  case UWARN:
    return (0); // LIBUSB_DEBUG_NO
  case UERROR:
    return (0); // LIBUSB_DEBUG_NO
  }
  return (0);
#else
  switch (v) {
  case UDEBUG:
    return (4);
  case UINFO:
    return (3);
  case UWARN:
    return (2);
  case UERROR:
    return (1);
  }
  return (2);
#endif
}