mirror of
git://projects.qi-hardware.com/fped.git
synced 2024-12-23 08:12:25 +02:00
39fef16d1c
found in the process. Also taught the regression test system a new trick: the path to "fped" can be passed in the environment variable FPED. E.g., FPED=fped.r5943 make test - fped.c (usage, main): duplicating the -T option produces a dump to stdout before exiting (like %dump would) - test/Common: new command fped_dump to invoked fped with a second -T option - test/Common: if the environment variable FPED is set, use its content to invoke fped (default is ../fped) - test/Common: if the environment variable CWD_PREFIX is set, prepend it to $FPED if the latter is a relative path - Makefile (test, tests): set CWD_PREFIX to .., so that the path given in FPED is valid at the point of invocation - fpd.y: revised grammar to make "package" optional - fpd.y: measurements were syntactically allowed inside non-root frame (test/structure) - test/structure: test various combinations of the grammatical file structure - test/tsort: removed all the now unnecessary "package" directives git-svn-id: http://svn.openmoko.org/trunk/eda/fped@5944 99fdad57-331a-0410-800a-d7fa5415bdb3
191 lines
5.4 KiB
Makefile
191 lines
5.4 KiB
Makefile
#
|
|
# Makefile - Makefile of fped, the footprint editor
|
|
#
|
|
# Written 2009, 2010 by Werner Almesberger
|
|
# Copyright 2009, 2010 by Werner Almesberger
|
|
#
|
|
# 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 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
|
|
PREFIX = /usr/local
|
|
|
|
UPLOAD = werner@sita.openmoko.org:public_html/fped/
|
|
|
|
OBJS = fped.o expr.o coord.o obj.o delete.o inst.o util.o error.o \
|
|
unparse.o file.o dump.o kicad.o postscript.o meas.o \
|
|
layer.o overlap.o hole.o tsort.o \
|
|
cpp.o lex.yy.o y.tab.o \
|
|
gui.o gui_util.o gui_style.o gui_inst.o gui_status.o gui_canvas.o \
|
|
gui_tool.o gui_over.o gui_meas.o gui_frame.o gui_frame_drag.o
|
|
|
|
XPMS = point.xpm delete.xpm delete_off.xpm \
|
|
vec.xpm frame.xpm \
|
|
line.xpm rect.xpm pad.xpm rpad.xpm hole.xpm arc.xpm circ.xpm \
|
|
meas.xpm meas_x.xpm meas_y.xpm \
|
|
stuff.xpm stuff_off.xpm meas_off.xpm \
|
|
bright.xpm bright_off.xpm all.xpm all_off.xpm
|
|
|
|
PNGS = intro-1.png intro-2.png intro-3.png intro-4.png intro-5.png \
|
|
intro-6.png concept-inst.png
|
|
|
|
SHELL = /bin/bash
|
|
CFLAGS_GTK = `pkg-config --cflags gtk+-2.0`
|
|
LIBS_GTK = `pkg-config --libs gtk+-2.0`
|
|
|
|
CFLAGS_WARN = -Wall -Wshadow -Wmissing-prototypes \
|
|
-Wmissing-declarations -Wno-format-zero-length
|
|
CFLAGS = -g -std=gnu99 $(CFLAGS_GTK) -DCPP='"cpp"' \
|
|
-DSVN_VERSION='"$(SVN_VERSION)$(SVN_STATUS)"' $(CFLAGS_WARN)
|
|
SLOPPY = -Wno-unused -Wno-implicit-function-declaration \
|
|
-Wno-missing-prototypes -Wno-missing-declarations
|
|
LDLIBS = -lm -lfl $(LIBS_GTK)
|
|
YACC = bison -y
|
|
YYFLAGS = -v
|
|
|
|
SVN_VERSION=$(shell svn info -R | sed '/Last Changed Rev: /s///p;d' | \
|
|
sort -r | sed 1q)
|
|
SVN_STATUS=$(shell [ -z "`svn status -q`" ] || echo +)
|
|
|
|
|
|
# ----- Verbosity control -----------------------------------------------------
|
|
|
|
CPP := $(CPP) # make sure changing CC won't affect CPP
|
|
|
|
CC_normal := $(CC)
|
|
YACC_normal := $(YACC)
|
|
LEX_normal := $(LEX)
|
|
DEPEND_normal := $(CPP) $(CFLAGS) -MM -MG
|
|
|
|
CC_quiet = @echo " CC " $@ && $(CC_normal)
|
|
YACC_quiet = @echo " YACC " $@ && $(YACC_normal)
|
|
LEX_quiet = @echo " LEX " $@ && $(LEX_normal)
|
|
GEN_quiet = @echo " GENERATE " $@ &&
|
|
DEPEND_quiet = @$(DEPEND_normal)
|
|
|
|
ifeq ($(V),1)
|
|
CC = $(CC_normal)
|
|
LEX = $(LEX_normal)
|
|
YACC = $(YACC_normal)
|
|
GEN =
|
|
DEPEND = $(DEPEND_normal)
|
|
else
|
|
CC = $(CC_quiet)
|
|
LEX = $(LEX_quiet)
|
|
YACC = $(YACC_quiet)
|
|
GEN = $(GEN_quiet)
|
|
DEPEND = $(DEPEND_quiet)
|
|
endif
|
|
|
|
# ----- Rules -----------------------------------------------------------------
|
|
|
|
.PHONY: all dep depend clean install uninstall manual upload-manual
|
|
.PHONY: update montage test tests valgrind
|
|
|
|
.SUFFIXES: .fig .xpm .ppm
|
|
|
|
# compile and generate dependencies, based on
|
|
# http://scottmcpeak.com/autodepend/autodepend.html
|
|
|
|
%.o: %.c
|
|
$(CC) -c $(CFLAGS) $*.c -o $*.o
|
|
$(DEPEND) $*.c | \
|
|
sed -e \
|
|
'/^\(.*:\)\? */{p;s///;s/ *\\\?$$/ /;s/ */:\n/g;H;}' \
|
|
-e '$${g;p;}' -e d >$*.d; \
|
|
[ "$${PIPESTATUS[*]}" = "0 0" ] || { rm -f $*.d; exit 1; }
|
|
|
|
# generate 26x26 pixels icons, then drop the 1-pixel frame
|
|
|
|
.fig.ppm:
|
|
$(GEN) fig2dev -L ppm -Z 0.32 -S 4 $< | \
|
|
convert -crop 24x24+1+1 - - >$@; \
|
|
[ "$${PIPESTATUS[*]}" = "0 0" ] || { rm -f $@; exit 1; }
|
|
|
|
# ppmtoxpm is very chatty, so we suppress its stderr
|
|
|
|
.ppm.xpm:
|
|
$(GEN) export TMP=_tmp$$$$; ppmcolormask white $< >$$TMP && \
|
|
ppmtoxpm -name xpm_`basename $@ .xpm` -alphamask $$TMP \
|
|
$< >$@ 2>/dev/null && rm -f $$TMP || \
|
|
{ rm -f $@ $$TMP; exit 1; }
|
|
|
|
all: fped
|
|
|
|
fped: $(OBJS)
|
|
$(CC) -o $@ $(OBJS) $(LDLIBS)
|
|
|
|
lex.yy.c: fpd.l y.tab.h
|
|
$(LEX) fpd.l
|
|
|
|
lex.yy.o: lex.yy.c y.tab.h
|
|
$(CC) -c $(CFLAGS) $(SLOPPY) lex.yy.c
|
|
|
|
y.tab.c y.tab.h: fpd.y
|
|
$(YACC) $(YYFLAGS) -d fpd.y
|
|
|
|
y.tab.o: y.tab.c
|
|
$(CC) -c $(CFLAGS) $(SLOPPY) y.tab.c
|
|
|
|
gui_tool.o gui.o: $(XPMS:%=icons/%)
|
|
|
|
# ----- Upload the GUI manual -------------------------------------------------
|
|
|
|
manual: $(XPMS:%=icons/%)
|
|
for n in $(XPMS:%.xpm=%); do \
|
|
convert icons/$$n.xpm manual/$$n.png || exit 1; done
|
|
fig2dev -L png -S 4 manual/concept-inst.fig \
|
|
>manual/concept-inst.png
|
|
|
|
upload-manual: manual
|
|
scp gui.html README $(UPLOAD)/
|
|
scp $(XPMS:%.xpm=manual/%.png) $(PNGS:%=manual/%) \
|
|
$(UPLOAD)/manual/
|
|
|
|
# ----- Debugging help --------------------------------------------------------
|
|
|
|
montage:
|
|
montage -label %f -frame 3 __dbg????.png png:- | display -
|
|
|
|
# ----- Dependencies ----------------------------------------------------------
|
|
|
|
dep depend .depend:
|
|
@echo 'no need to run "make depend" anymore' 1>&2
|
|
|
|
-include $(OBJS:.o=.d)
|
|
|
|
# ----- Tests -----------------------------------------------------------------
|
|
|
|
test tests: all
|
|
LANG= sh -c \
|
|
'passed=0 && cd test && \
|
|
for n in [a-z]*; do \
|
|
SCRIPT=$$n CWD_PREFIX=.. . ./$$n; done; \
|
|
echo "Passed all $$passed tests"'
|
|
|
|
valgrind:
|
|
VALGRIND="valgrind -q" $(MAKE) tests
|
|
|
|
# ----- Cleanup ---------------------------------------------------------------
|
|
|
|
clean:
|
|
rm -f $(OBJS) $(XPMS:%=icons/%) $(XPMS:%.xpm=icons/%.ppm)
|
|
rm -f lex.yy.c y.tab.c y.tab.h y.output .depend $(OBJS:.o=.d)
|
|
rm -f __dbg????.png _tmp*
|
|
|
|
# ----- Install / uninstall ---------------------------------------------------
|
|
|
|
install: all
|
|
install -m 755 fped $(PREFIX)/bin/
|
|
|
|
uninstall:
|
|
rm -f $(PREFIX)/bin/fped
|
|
|
|
# ----- SVN update ------------------------------------------------------------
|
|
|
|
update:
|
|
svn update
|
|
$(MAKE) dep all
|