Jan Breuer
2015-08-05 fb2427e4c2fdf04fc13f434ff764f9679a48c770
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
LIBNAME = scpi
 
CFLAGS += -Wextra -Wmissing-prototypes -Wimplicit -g -Iinc
LDFLAGS += -Wl,--as-needed
TESTFLAGS += -lcunit $(CFLAGS)
 
OBJDIR=obj
DISTDIR=dist
TESTDIR=test
 
STATICLIBFLAGS = rcs
 
STATICLIB = lib$(LIBNAME).a
 
SRCS = $(addprefix src/, \
    error.c fifo.c ieee488.c \
    minimal.c parser.c units.c utils.c \
    lexer.c \
    )
 
OBJS = $(addprefix $(OBJDIR)/, $(notdir $(SRCS:.c=.o)))
 
HDRS = $(addprefix inc/scpi/, \
    scpi.h constants.h error.h \
    ieee488.h minimal.h parser.h types.h units.h \
    ) \
    $(addprefix src/, \
    lexer_private.h utils_private.h fifo_private.h \
    parser_private.h \
    ) \
 
 
TESTS = $(addprefix $(TESTDIR)/, \
    test_fifo.c test_scpi_utils.c test_lexer_parser.c test_parser.c\
    )
 
TESTS_OBJS = $(TESTS:.c=.o)
TESTS_BINS = $(TESTS_OBJS:.o=.test)
 
.PHONY: all clean static test
 
all: static
 
static: $(DISTDIR)/$(STATICLIB)
 
clean:
    $(RM) -r $(OBJDIR) $(DISTDIR) $(TESTS_BINS) $(TESTS_OBJS)
 
test: $(TESTS_BINS)
    for t in $(TESTS_BINS); do ./$$t; done
 
$(OBJDIR):
    mkdir -p $@
 
$(DISTDIR):
    mkdir -p $@
 
$(OBJDIR)/%.o: src/%.c
    $(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<
 
$(DISTDIR)/$(STATICLIB): $(OBJS)
    $(AR) $(STATICLIBFLAGS) $(DISTDIR)/$(STATICLIB) $(OBJS)
 
 
$(OBJS): $(HDRS) $(DISTDIR) $(OBJDIR) $(SRCS)
 
 
$(TESTDIR)/%.o: $(TESTDIR)/%.c
    $(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<
 
$(TESTDIR)/%.test: $(TESTDIR)/%.o $(DISTDIR)/$(STATICLIB)
    $(CC) $(TESTFLAGS) $< $(DISTDIR)/$(STATICLIB) -o $@ $(LDFLAGS)