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
#include <stdarg.h>

#include "loc.h"

static size_t
min(size_t a, size_t b)
{
    return a < b ? a : b;
}

static size_t
max(size_t a, size_t b)
{
    return a > b ? a : b;
}

struct Loc nullLoc;

struct Loc
combineLoc(struct Loc loc0, struct Loc loc1)
{
    struct Loc loc = { {
                         min(loc0.begin.line, loc1.begin.line),
                         min(loc0.begin.col, loc1.begin.col),
                       },
                       {
                         max(loc0.begin.line, loc1.begin.line),
                         max(loc0.begin.col, loc1.begin.col),
                       } };
    return loc;
}

void
fprintfLoc(FILE *out, const struct Loc *loc, const char *fmt, ...)
{
    va_list argp;
    va_start(argp, fmt);
    vfprintfLoc(out, loc, fmt, argp);
    va_end(argp);

    /*
    fprintf(stderr, "%s:%zu.%zu-%zu.%zu: ", loc->filename, loc->begin.line,
            loc->begin.col, loc->end.line, loc->end.col);

    va_list argp;
    va_start(argp, fmt);
    vfprintf(out, fmt, argp);
    va_end(argp);
    */
}

void
vfprintfLoc(FILE *out, const struct Loc *loc, const char *fmt, va_list ap)
{
    if (loc) {
        const char *f = loc->filename ? loc->filename : "<undefined filename>";
        fprintf(stderr, "%s:%zu.%zu-%zu.%zu: ", f, loc->begin.line,
                loc->begin.col, loc->end.line, loc->end.col);
    }
    vfprintf(out, fmt, ap);
}