stage1_2/Makefile
author Edouard Tisserant
Tue, 05 Apr 2011 15:14:19 +0200
changeset 279 c0453b7f99df
parent 258 d7d92b2f87e9
permissions -rwxr-xr-x
Re-generated std lib related code, with updated headers, updated all forgotten headers
# matiec - a compiler for the programming languages defined in IEC 61131-3
#
# Copyright (C) 2003-2011  Mario de Sousa (msousa@fe.up.pt)
# Copyright (C) 2007-2011  Laurent Bessard and Edouard Tisserant
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

# include the system specific Makefile
include ../Makefile.$(shell uname)



default: all

all: iec.flex.o iec.y.o stage1_2.o

clean:
	echo > Makefile.depend
	-rm -f iec.flex.c iec.y.cc iec.y.hh iec.y.output
	-rm -f iec.noerrorcheck.y
	-rm -f test_flex
	-rm -f stage1_2.o
	-rm -f iec.y.o
	-rm -f iec.flex.o
	-rm -f Makefile.depend


CFLAGS += -I. -I../* -I../../absyntax

iec.flex.c: iec.flex
	flex -oiec.flex.c iec.flex

stage1_2.cc: iec.y.hh 
stage1_2.o: stage1_2.cc

iec.flex.o: iec.y.hh iec.flex.c
	$(CXX) -c iec.flex.c -D DEFAULT_LIBDIR='"$(IECLIBDIR)"' $(CFLAGS)

iec.y.hh iec.y.cc: iec.y
	bison -d -v -o iec.y.cc iec.y

iec.y.o: iec.y.cc iec.y.hh
	$(CXX) -c iec.y.cc $(CFLAGS)

noerrorcheck: iec.y
	sed '/ERROR_CHECK_BEGIN/,/ERROR_CHECK_END/ d' iec.y > iec.noerrorcheck.y
	flex -oiec.flex.c iec.flex
	$(CXX) -c iec.flex.c -D DEFAULT_LIBDIR='"$(IECLIBDIR)"' $(CFLAGS)
	bison -d -v -o iec.y.cc iec.noerrorcheck.y
	$(CXX) -c iec.y.cc $(CFLAGS)

#how to make things from other directories if they are missing
../% /%:
	$(MAKE) -C $(@D) $(@F)


Makefile.depend depend:
	$(CXX) -MM -MG -I. *.cc \
	  | sed 's/:/ Makefile.depend:/' > Makefile.depend

include Makefile.depend