*** empty log message ***
[libfirm] / ir / ir / Makefile
1 # Hey, emacs, this is a -*- makefile -*-
2 #
3 # Copyright (C) 1998 - 2000 by Universitaet Karlsruhe
4 # All rights reserved.
5 # Author: Goetz Lindenmaier
6 #
7 # Makefile for ir -- intermediate representation of the program
8
9 CXX         = gcc
10 CFLAGS      = -pipe -Wall # -ansi -pedantic
11 CXXFLAGS    = # -g
12 COPTFLAGS   = -O3
13 LDFLAGS     =
14 DEPENDFLAGS = -M
15 LIBPATH     =
16 LIBS        =
17 X_LIBS      =
18 INCLUDES    = -I../adt -I../common -I../debug -I../ident -I../include \
19               -I../ir -I../tr -I../tv
20 X_INCLUDES  =
21
22 SHELL       = /bin/sh
23 MAKE        = /usr/bin/make
24
25 MEMBERS  = ircons.m irdump.m irflag.m irgmod.m irgraph.m irgopt.m \
26            irgwalk.m irmode.m irnode.m irop.m iropt.m irprog.m irvrfy.m
27
28 CFILES = $(MEMBERS:.m=.c)
29
30 HFILES = $(MEMBERS:.m=.h)
31 HFILES +=  array.h common.h cookies.h debug.h entity.h gmp.h  \
32            host.h ident.h label.h misc.h obst.h pdeq.h pset.h \
33            set.h tune.h tv.h type.h xprintf.h xp_help.h irnode2.h
34
35 OFILES = $(MEMBERS:%.m=../objects/%.o)
36
37 DFILES = $(MEMBERS:.m=.d)
38
39 TARGET = all
40
41 .PHONY: default all clean realclean install depend
42 .SUFFIXES: .d .h .c .o
43 .DEFAULT: $(TARGET)
44 .SILENT: $(DFILES) clean  # hides output
45
46
47 $(TARGET): $(DFILES) $(OFILES)
48
49 # the preprocessor computes the dependencies and saves them to a file
50 # the sed script adds the path to ../objects and file.d to the dependency.
51 %.d:    %.c
52         $(SHELL) -ec '$(CXX) $(DEPENDFLAGS) $(INCLUDES) $(X_INCLUDES) $< | sed '\''s/\($*\)\.o[ :]*/\.\.\/objects\/\1.o $@ : /g'\'' > $@'
53
54
55 ../objects/%.o: %.c
56         $(CXX) $(CFLAGS) $(CXXFLAGS) $(COPTFLAGS) $(INCLUDES) $(X_INCLUDES) -c $< -o $@
57
58 clean:
59         rm -f $(OFILES) $(DFILES)
60
61 realclean:      clean
62         rm -f $(TARGET) *.flc TAGS
63
64 -include $(DFILES)