summaryrefslogtreecommitdiff
path: root/src/print_load.c
blob: 7ba4ae1a9534428cf3181f592b776130fe0b788f (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
// vim:ts=4:sw=4:expandtab
#include "i3status.h"
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <yajl/yajl_gen.h>
#include <yajl/yajl_version.h>

void print_load(yajl_gen json_gen, char *buffer, const char *format, const float max_threshold) {
    char *outwalk = buffer;
/* Get load */

#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(linux) || defined(__OpenBSD__) || defined(__NetBSD__) || defined(__APPLE__) || defined(sun) || defined(__DragonFly__)
    double loadavg[3];
    const char *walk;
    bool colorful_output = false;

    if (getloadavg(loadavg, 3) == -1)
        goto error;

    for (walk = format; *walk != '\0'; walk++) {
        if (*walk != '%') {
            *(outwalk++) = *walk;
            continue;
        }
        if (loadavg[0] >= max_threshold) {
            START_COLOR("color_bad");
            colorful_output = true;
        }

        if (BEGINS_WITH(walk + 1, "1min")) {
            outwalk += sprintf(outwalk, "%1.2f", loadavg[0]);
            walk += strlen("1min");
        }

        if (BEGINS_WITH(walk + 1, "5min")) {
            outwalk += sprintf(outwalk, "%1.2f", loadavg[1]);
            walk += strlen("5min");
        }

        if (BEGINS_WITH(walk + 1, "15min")) {
            outwalk += sprintf(outwalk, "%1.2f", loadavg[2]);
            walk += strlen("15min");
        }
        if (colorful_output)
            END_COLOR;
    }

    *outwalk = '\0';
    OUTPUT_FULL_TEXT(buffer);

    return;
error:
#endif
    OUTPUT_FULL_TEXT("cant read load");
    (void)fputs("i3status: Cannot read system load using getloadavg()\n", stderr);
}