macrofuck/Makefile

49 lines
959 B
Makefile
Raw Normal View History

2024-02-11 16:02:13 +00:00
CC = gcc
CFLAGS = -std=c11 -Wall -Wpedantic -g -I./src -I./gen
LD = gcc
LDFLAGS =
2024-02-16 11:50:13 +00:00
YACC = bison
2024-02-11 16:02:13 +00:00
YFLAGS = -d
LEX = lex
LEXFLAGS =
2024-02-16 11:50:13 +00:00
PLUGINS = obj/macros/numbers.o
2024-02-15 20:22:34 +00:00
OBJS = obj/lex.yy.o obj/y.tab.o obj/codegen.o obj/error.o \
obj/ast.o obj/alloc.o obj/dict.o obj/list.o obj/band.o \
2024-02-16 11:50:13 +00:00
obj/plugins.o $(PLUGINS) obj/main.o
2024-02-11 16:02:13 +00:00
DEPS = $(OBJS:%.o=%.d)
-include $(DEPS)
all: macrofuck test
gen/lex.yy.c: src/lexer.l gen/y.tab.c
$(LEX) $(LEXFLAGS) -o $@ $<
gen/y.tab.c: src/parser.y src/ast.h src/error.h
$(YACC) $(YFLAGS) -o $@ $<
obj/lex.yy.o: gen/lex.yy.c
$(CC) $(CFLAGS) -c -o $@ $<
obj/y.tab.o: gen/y.tab.c
$(CC) $(CFLAGS) -c -o $@ $<
obj/%.o: src/%.c obj
$(CC) $(CFLAGS) -c -o $@ $<
macrofuck: $(OBJS)
$(LD) $(LDFLAGS) -o $@ $^
2024-02-11 16:26:08 +00:00
test: macrofuck FORCE
./test/tests.sh "./macrofuck"
FORCE: ;
2024-02-11 16:02:13 +00:00
clean:
@echo "Cleaning up"
@rm -f obj/*.o
@rm -f obj/*.d
@rm -f gen/*.c
@rm -f gen/*.h
@rm macrofuck