52 lines
1.2 KiB
Makefile
52 lines
1.2 KiB
Makefile
#
|
|
# Simple Makefile
|
|
# Mike Lam, James Madison University, August 2016
|
|
#
|
|
# This makefile builds a simple application that contains a main module
|
|
# (specified by the EXE variable) and a predefined list of additional modules
|
|
# (specified by the MODS variable). If there are any external library
|
|
# dependencies (e.g., the math library, "-lm"), list them in the LIBS variable.
|
|
# If there are any precompiled object files, list them in the OBJS variable.
|
|
#
|
|
# By default, this makefile will build the project with debugging symbols and
|
|
# without optimization. To change this, edit or remove the "-g" and "-O0"
|
|
# options in CFLAGS and LDFLAGS accordingly.
|
|
#
|
|
# By default, this makefile build the application using the GNU C compiler,
|
|
# adhering to the C99 standard with all warnings enabled.
|
|
|
|
|
|
# application-specific settings and run target
|
|
|
|
EXE=y86
|
|
MODS=p4-interp.o
|
|
OBJS=p1-check.o p2-load.o p3-disas.o
|
|
LIBS=
|
|
|
|
default: $(EXE)
|
|
|
|
test: $(EXE)
|
|
TPREFIX=tests/ make -C tests test
|
|
|
|
# compiler/linker settings
|
|
|
|
CC=gcc
|
|
CFLAGS=-g -O0 -Wall --std=c99 -pedantic
|
|
LDFLAGS=-g -O0
|
|
|
|
|
|
# build targets
|
|
|
|
$(EXE): main.o $(MODS) $(OBJS)
|
|
$(CC) $(LDFLAGS) -o $(EXE) $^ $(LIBS)
|
|
|
|
%.o: %.c
|
|
$(CC) -c $(CFLAGS) $<
|
|
|
|
clean:
|
|
rm -f $(EXE) main.o $(MODS)
|
|
make -C tests clean
|
|
|
|
.PHONY: default clean
|
|
|