-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
57 lines (44 loc) · 1.34 KB
/
Makefile
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
# Compiles the AIG simulator code to libsymsimabc.a
# Doesn't compile libabc
EXTRAS = Makefile LICENSE README.md
HEADERS = include/vectype.h include/pcode_definitions.h include/queue.h
SOURCES = src/constcheck.c src/memory.c src/pcode_definitions.c src/queue.c src/aig_vectors.c
OBJECTS = $(SOURCES:src/%.c=obj/%.o)
SYMSIMLIB = symsimabc
LIBABC_DIR = lib/abc
CC = gcc
DBG = -g -Wall -fstack-protector-all -pedantic
OPT = #-march=native -O3 -DNDEBUG -ffast-math -fomit-frame-pointer
INCLUDES = -I$(LIBABC_DIR)/src -Iinclude
LIBS =
LDFLAGS = -Llib
CFLAGS = -std=gnu99 $(DBG) $(OPT) -DABC_USE_STDINT_H $(INCLUDES)
AR = ar r
RANLIB = ranlib
all: depend lib/lib$(SYMSIMLIB).a
depend: .depend
.depend: $(SOURCES)
@echo "Building dependencies"
ifneq ($(wildcard ./.depend),)
@rm -f "./.depend"
endif
@$(CC) $(CFLAGS) -MM $^ > .depend
# Make .depend use the 'obj' directory
@sed -i.bak -e :a -e '/\\$$/N; s/\\\n//; ta' .depend
@sed -i.bak 's/^/obj\//' .depend
@rm -f .depend.bak
-include .depend
$(OBJECTS): obj/%.o : src/%.c Makefile
@echo "Compiling "$<""
@[ -d obj ] || mkdir -p obj
@$(CC) $(CFLAGS) -c $< -o $@
lib/lib$(SYMSIMLIB).a: $(OBJECTS) Makefile
@echo "Creating "$@""
@[ -d lib ] || mkdir -p lib
@rm -f $@
@$(AR) $@ $(OBJECTS)
@$(RANLIB) $@
clean:
rm -rf *~ */*~ $(OBJECTS) ./.depend *.dSYM
edit:
emacs -nw $(EXTRAS) $(HEADERS) $(SOURCES)