-CC ?= clang
-CFLAGS += -Wall -I. -fomit-frame-pointer -fno-stack-protector
-#turn on tons of warnings if clang is present
-ifeq ($(CC), clang)
- CFLAGS += \
- -Weverything \
- -Wno-missing-prototypes \
- -Wno-unused-parameter \
- -Wno-sign-compare \
- -Wno-implicit-fallthrough \
- -Wno-sign-conversion \
- -Wno-conversion \
- -Wno-disabled-macro-expansion \
- -Wno-padded \
- -Wno-format-nonliteral
-
-endif
-ifeq ($(track), no)
- CFLAGS += -DNOTRACK
-endif
-
-OBJ = \
- util.o \
- code.o \
- ast.o \
- ir.o \
- error.o
-OBJ_A = test/ast-test.o
-OBJ_I = test/ir-test.o
-OBJ_C = main.o lexer.o parser.o
-OBJ_X = exec-standalone.o util.o
-
-#default is compiler only
-default: gmqcc
-%.o: %.c
- $(CC) -c $< -o $@ $(CFLAGS)
-
-exec-standalone.o: exec.c
- $(CC) -c $< -o $@ $(CFLAGS) -DQCVM_EXECUTOR=1
-
-# test targets
-test_ast: $(OBJ_A) $(OBJ)
- $(CC) -o $@ $^ $(CFLAGS)
-test_ir: $(OBJ_I) $(OBJ)
- $(CC) -o $@ $^ $(CFLAGS)
-qcvm: $(OBJ_X)
- $(CC) -o $@ $^ $(CFLAGS) -lm
-test: test_ast test_ir
-
-# compiler target
-gmqcc: $(OBJ_C) $(OBJ)
- $(CC) -o $@ $^ $(CFLAGS)
-
-#all target is test and all
-all: test gmqcc
+CC ?= clang
+CFLAGS = -MD -Wall -Wextra -pedantic-errors
+LDFLAGS = -lm
-clean:
- rm -f *.o gmqcc qcvm test_ast test_ir test/*.o
-
+CSRCS = ansi.c ast.c code.c conout.c fold.c fs.c ftepp.c hash.c intrin.c ir.c lexer.c main.c opts.c parser.c stat.c utf8.c util.c
+TSRCS = ansi.c conout.c fs.c hash.c opts.c stat.c test.c util.c
+
+COBJS = $(CSRCS:.c=.o)
+TOBJS = $(TSRCS:.c=.o)
+
+CDEPS = $(CSRCS:.c=.d)
+TDEPS = $(TSRCS:.c=.d)
+
+CBIN = gmqcc
+TBIN = testsuite
+
+all: $(CBIN) $(TBIN)
+$(CBIN): $(COBJS)
+ $(CC) $(LDFLAGS) $(COBJS) -o $@
+
+$(TBIN): $(TOBJS)
+ $(CC) $(LDFLAGS) $(TOBJS) -o $@
+
+.c.o:
+ $(CC) -c $(CFLAGS) $< -o $@
+
+test: $(CBIN) $(TBIN)
+ @./$(TBIN)
+
+clean:
+ rm -f *.d
+ rm -f $(COBJS) $(CDEPS) $(CBIN)
+ rm -f $(TOBJS) $(TDEPS) $(TBIN)