261 lines
6.2 KiB
Plaintext
261 lines
6.2 KiB
Plaintext
# $Id$
|
|
|
|
INSTALL_PROD=$(PROD:%=$(INSTALL_BIN)/%)
|
|
INSTALL_LIBS=$(LIBNAME:%=$(INSTALL_LIB)/%)
|
|
INSTALL_INC=$(INC:%=$(INSTALL_INCLUDE)/%)
|
|
INSTALL_MANS+=$(MAN1:%=$(INSTALL_MAN)/man1/%)
|
|
INSTALL_MANS+=$(MAN2:%=$(INSTALL_MAN)/man2/%)
|
|
INSTALL_MANS+=$(MAN3:%=$(INSTALL_MAN)/man3/%)
|
|
INSTALL_MANS+=$(MAN4:%=$(INSTALL_MAN)/man4/%)
|
|
INSTALL_MANS+=$(MAN5:%=$(INSTALL_MAN)/man5/%)
|
|
INSTALL_MANS+=$(MAN6:%=$(INSTALL_MAN)/man6/%)
|
|
INSTALL_MANS+=$(MAN7:%=$(INSTALL_MAN)/man7/%)
|
|
INSTALL_MANS+=$(MAN8:%=$(INSTALL_MAN)/man8/%)
|
|
INSTALL_MANS+=$(MAN9:%=$(INSTALL_MAN)/man9/%)
|
|
INSTALL_DOCS=$(DOCS:%=$(INSTALL_DOC)/%)
|
|
INSTALL_SCRIPTS=$(SCRIPTS:%=$(INSTALL_BIN)/%)
|
|
INSTALL_TEMPLATE=$(TEMPLATES:%=$(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)/%)
|
|
INSTALL_TCLLIBS=$(TCLLIBNAME:%=$(INSTALL_TCLLIB)/%)
|
|
INSTALL_TCLINDEX=$(TCLINDEX:%=$(INSTALL_TCLLIB)/%)
|
|
INSTALL_CONFIGS=$(CONFIGS:%=$(INSTALL_CONFIG)/%)
|
|
|
|
all:: install
|
|
|
|
pre_build::
|
|
|
|
rebuild:: clean install
|
|
|
|
build:: pre_build $(LIBNAME) $(TARGETS) $(PROD)
|
|
|
|
inc:: $(INSTALL_INC)
|
|
|
|
install:: inc build $(INSTALL_LIBS) $(TARGETS) $(INSTALL_SCRIPTS) $(INSTALL_PROD) \
|
|
$(INSTALL_MANS) $(INSTALL_DOCS) $(INSTALL_TEMPLATE) \
|
|
$(INSTALL_TCLLIBS) $(INSTALL_TCLINDEX) $(INSTALL_CONFIGS)
|
|
|
|
depends:: $(SRCS.c) $(SRCS.cc)
|
|
ifdef SRCS
|
|
echo you have a SRCS in your Makefile
|
|
exit 2
|
|
endif
|
|
ifdef SRCS.c
|
|
$(DEPENDS_RULE.c)
|
|
endif
|
|
ifdef SRCS.cc
|
|
$(DEPENDS_RULE.cc)
|
|
endif
|
|
|
|
clean::
|
|
@echo "Cleaning"
|
|
@$(RM) *.i *.o *.a $(TARGETS) $(PROD) $(LIBNAME) $(INC)
|
|
|
|
|
|
$(TARGETS) $(PROD): $(DEPLIBS)
|
|
|
|
# The order of the following dependencies is
|
|
# VERY IMPORTANT !!!!
|
|
|
|
%: %.o
|
|
$(RM) $@
|
|
$(LINK.c) -o $@ $< $(LDLIBS)
|
|
|
|
#$(PROD): $(OBJS)
|
|
# $(RM) $@
|
|
# $(LINK.c) -o $@ ${OBJS} $(LDLIBS)
|
|
|
|
%.o: %.c
|
|
$(RM) $@
|
|
$(COMPILE.c) $<
|
|
|
|
%.o: ../%.c
|
|
$(RM) $@
|
|
$(COMPILE.c) $<
|
|
|
|
%.o: %.cc
|
|
$(RM) $@
|
|
$(COMPILE.cc) $<
|
|
|
|
%.o: ../%.cc
|
|
$(RM) $@
|
|
$(COMPILE.cc) $<
|
|
|
|
%.c: ../%.y
|
|
$(RM) y.tab.c y.tab.h
|
|
$(YACC) $(YACCOPT) $<
|
|
@if [ -f y.tab.c ]; \
|
|
then \
|
|
echo "$(MV) y.tab.c $*.c"; \
|
|
$(MV) y.tab.c $*.c; \
|
|
fi
|
|
@if [ -f y.tab.h ]; \
|
|
then \
|
|
echo "$(MV) y.tab.h $*.h"; \
|
|
$(MV) y.tab.h $*.h; \
|
|
fi
|
|
|
|
%.c: ../%.l
|
|
$(RM) lex.yy.c
|
|
$(LEX) $(LEXOPT) $<
|
|
$(RM) $@
|
|
$(MV) lex.yy.c $@
|
|
|
|
#state notation language rule
|
|
%.c: ../%.st
|
|
@echo "preprocessing $*.st"
|
|
@$(RM) $*.i
|
|
$(CPP) $(CPPFLAGS) $< $*.i
|
|
@echo "converting $*.i"
|
|
@$(RM) $@
|
|
$(SNC) $(TARGET_SNCFLAGS) $(SNCFLAGS) $*.i
|
|
|
|
%.c: %.stt
|
|
@echo "converting $<
|
|
@$(RM) $@
|
|
$(SNC) $(TARGET_SNCFLAGS) $(SNCFLAGS) $<
|
|
|
|
# Capfast Rules:
|
|
%.db: %.edf
|
|
$(E2DB) $(E2SR_SYSFLAGS) $(E2SR_FLAGS) $<
|
|
|
|
%.db: ../%.edf
|
|
$(E2DB) $(E2SR_SYSFLAGS) $(E2SR_FLAGS) $<
|
|
|
|
%.edf: ../%.sch $(DEPSCHS)
|
|
@if [ ! -f cad.rc -a -r ../cad.rc ] ; then ln -s ../cad.rc ; fi
|
|
$(SCH2EDIF) $(SCH2EDIF_SYSFLAGS) $(SCH2EDIF_FLAGS) $<
|
|
|
|
# Mangen Rule:
|
|
%.1:%
|
|
$(RM) $(<F)
|
|
$(RM) $(<F).nr
|
|
ln -s $<
|
|
$(MANGEN) -s $(<F)
|
|
$(MV) $(<F).nr $(<F).1
|
|
|
|
# Mangen Rule:
|
|
%.1:../%
|
|
$(RM) $(<F)
|
|
$(RM) $(<F).nr
|
|
ln -s $<
|
|
$(MANGEN) -s $(<F)
|
|
$(MV) $(<F).nr $(<F).1
|
|
|
|
$(LIBNAME): $(LIBOBJS)
|
|
@echo Building library $@
|
|
$(RM) $@
|
|
$(AR) $(ARFLAGS) $@ $(LIBOBJS)
|
|
@if [ ! -z "$(RANLIB)" ] ; then\
|
|
echo $(RANLIB) $@; \
|
|
$(RANLIB) $@; \
|
|
fi
|
|
|
|
$(INSTALL_BIN)/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_LOCATION_BIN) || mkdir $(INSTALL_LOCATION_BIN)
|
|
@test -d $(INSTALL_BIN) || mkdir $(INSTALL_BIN)
|
|
@$(INSTALL_PRODUCT) -m 555 $< $(INSTALL_BIN)
|
|
|
|
$(INSTALL_BIN)/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_LOCATION_BIN) || mkdir $(INSTALL_LOCATION_BIN)
|
|
@test -d $(INSTALL_BIN) || mkdir $(INSTALL_BIN)
|
|
@$(INSTALL_PRODUCT) -m 555 $< $(INSTALL_BIN)
|
|
|
|
$(INSTALL_LIB)/%.a: %.a
|
|
@echo "Installing library $@"
|
|
@test -d $(INSTALL_LOCATION_LIB) || mkdir $(INSTALL_LOCATION_LIB)
|
|
@test -d $(INSTALL_LIB) || mkdir $(INSTALL_LIB)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_LIB)
|
|
@if [ ! -z "$(RANLIB)" ] ; then\
|
|
$(RANLIB) $(RANLIBFLAGS) $@; \
|
|
fi
|
|
|
|
$(INSTALL_CONFIG)/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_CONFIG) || mkdir $(INSTALL_CONFIG)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_CONFIG)
|
|
|
|
$(INSTALL_CONFIG)/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_CONFIG) || mkdir $(INSTALL_CONFIG)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_CONFIG)
|
|
|
|
$(INSTALL_TCLLIB)/%: ../%
|
|
@echo "Installing Tcl library $@"
|
|
@test -d $(INSTALL_LOCATION_LIB) || mkdir $(INSTALL_LOCATION_LIB)
|
|
@test -d $(INSTALL_LIB) || mkdir $(INSTALL_LIB)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_LIB)
|
|
|
|
$(INSTALL_TCLLIB)/$(TCLINDEX): $(INSTALL_TCLLIBS)
|
|
@echo "Updating $@"
|
|
@echo eval auto_mkindex $(INSTALL_LIB) "$(TCLLIBNAME)" | tclsh
|
|
|
|
$(INSTALL_MAN)/man9/% \
|
|
$(INSTALL_MAN)/man8/% \
|
|
$(INSTALL_MAN)/man7/% \
|
|
$(INSTALL_MAN)/man6/% \
|
|
$(INSTALL_MAN)/man5/% \
|
|
$(INSTALL_MAN)/man4/% \
|
|
$(INSTALL_MAN)/man3/% \
|
|
$(INSTALL_MAN)/man2/% \
|
|
$(INSTALL_MAN)/man1/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_MAN) || mkdir $(INSTALL_MAN)
|
|
@test -d $(@D) || mkdir $(@D)
|
|
@$(INSTALL) -m 644 $< $(@D)
|
|
|
|
$(INSTALL_MAN)/man9/% \
|
|
$(INSTALL_MAN)/man8/% \
|
|
$(INSTALL_MAN)/man7/% \
|
|
$(INSTALL_MAN)/man6/% \
|
|
$(INSTALL_MAN)/man5/% \
|
|
$(INSTALL_MAN)/man4/% \
|
|
$(INSTALL_MAN)/man3/% \
|
|
$(INSTALL_MAN)/man2/% \
|
|
$(INSTALL_MAN)/man1/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_MAN) || mkdir $(INSTALL_MAN)
|
|
@test -d $(@D) || mkdir $(@D)
|
|
@$(INSTALL) -m 644 $< $(@D)
|
|
|
|
$(INSTALL_INCLUDE)/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_INCLUDE) || mkdir $(INSTALL_INCLUDE)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_INCLUDE)
|
|
|
|
$(INSTALL_INCLUDE)/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_INCLUDE) || mkdir $(INSTALL_INCLUDE)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_INCLUDE)
|
|
|
|
$(INSTALL_DOC)/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_DOC) || mkdir $(INSTALL_DOC)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_DOC)
|
|
|
|
$(INSTALL_DOC)/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_DOC) || mkdir $(INSTALL_DOC)
|
|
@$(INSTALL) -m 644 $< $(INSTALL_DOC)
|
|
|
|
$(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)/%: ../%
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_TEMPLATES) || mkdir $(INSTALL_TEMPLATES)
|
|
@test -d $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR) || \
|
|
mkdir $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)
|
|
@$(INSTALL) -d -m 644 $< $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)
|
|
|
|
$(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)/%: %
|
|
@echo "Installing $@"
|
|
@test -d $(INSTALL_TEMPLATES) || mkdir $(INSTALL_TEMPLATES)
|
|
@test -d $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR) || \
|
|
mkdir $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)
|
|
@$(INSTALL) -d -m 644 $< $(INSTALL_TEMPLATES)/$(TEMPLATES_DIR)
|
|
|
|
.PRECIOUS: %.o %.c
|
|
|
|
.PHONY: all inc depends build install pre-build clean rebuild
|
|
|
|
-include .DEPENDS
|
|
|