aboutsummaryrefslogtreecommitdiff
path: root/Makefile
blob: f50b43d62d00798c56ffaa6d74648444e5754165 (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
CC ?= clang
CFLAGS ?= -Wall -Wextra -g
LDFLAGS ?= -lreadline
BISON ?= bison
FLEX ?= flex

SRC_DIR := src
INC_DIR := include
TEST_DIR := test
BUILD_DIR := build

PARSER_Y := $(SRC_DIR)/parser.y
LEXER_L := $(SRC_DIR)/lexer.l

C_SRC := $(filter-out $(PARSER_Y:.y=.c) $(LEXER_L:.l=.c), $(wildcard $(SRC_DIR)/*.c))

PARSER_C := $(BUILD_DIR)/parser.tab.c
PARSER_H := $(BUILD_DIR)/parser.tab.h
LEXER_C := $(BUILD_DIR)/lex.yy.c

C_OBJS := $(patsubst $(SRC_DIR)/%.c,$(BUILD_DIR)/%.o,$(C_SRC))
PARSER_O := $(BUILD_DIR)/parser.tab.o
LEXER_O := $(BUILD_DIR)/lex.yy.o
OBJS := $(C_OBJS) $(PARSER_O) $(LEXER_O)

TARGET := $(BUILD_DIR)/imp
TEST_TARGET := $(BUILD_DIR)/test

CFLAGS += -I$(INC_DIR) -I. -MMD -MP
DEPS := $(OBJS:.o=.d)

.PHONY: all clean example repl test

all: $(TARGET)

$(TARGET): $(OBJS)
	$(CC) $(CFLAGS) $^ -o $@ $(LDFLAGS)

$(BUILD_DIR):
	@mkdir -p $@

$(BUILD_DIR)/%.o: $(SRC_DIR)/%.c | $(BUILD_DIR)
	$(CC) $(CFLAGS) -c $< -o $@

$(PARSER_C) $(PARSER_H): $(PARSER_Y) | $(BUILD_DIR)
	$(BISON) -d --defines=$(PARSER_H) -o $(PARSER_C) $<

$(PARSER_O): $(PARSER_C)
	$(CC) $(CFLAGS) -c $< -o $@

$(LEXER_C): $(LEXER_L) $(PARSER_H) | $(BUILD_DIR)
	$(FLEX) -o $@ $<

$(LEXER_O): $(LEXER_C)
	$(CC) $(CFLAGS) -c $< -o $@

$(TEST_TARGET): $(wildcard $(TEST_DIR)/*.c) $(filter-out $(BUILD_DIR)/main.o, $(OBJS)) | $(BUILD_DIR)
	$(CC) $(CFLAGS) $^ -o $@ $(LDFLAGS)

example: $(TARGET)
	./$(TARGET) -i examples/example.imp

repl: $(TARGET)
	./$(TARGET)

test: $(BUILD_DIR)/test
	./$(BUILD_DIR)/test

clean:
	@rm -rf $(BUILD_DIR)

-include $(DEPS)