diff options
author | David Henkel-Wallace <gumby@cygnus> | 1992-07-31 17:33:55 +0000 |
---|---|---|
committer | David Henkel-Wallace <gumby@cygnus> | 1992-07-31 17:33:55 +0000 |
commit | ee7c00ac958f752ba7b1114d0836f0e627ac4ac3 (patch) | |
tree | 9f5d669381364578456696335cc10e9adb0d7740 /Build-A-Release.mk | |
parent | 5898af2c4bc6a91b1430cf781eae92fef87414ce (diff) | |
download | gdb-ee7c00ac958f752ba7b1114d0836f0e627ac4ac3.zip gdb-ee7c00ac958f752ba7b1114d0836f0e627ac4ac3.tar.gz gdb-ee7c00ac958f752ba7b1114d0836f0e627ac4ac3.tar.bz2 |
didn't get propagated from progressive to devo.
Diffstat (limited to 'Build-A-Release.mk')
-rw-r--r-- | Build-A-Release.mk | 303 |
1 files changed, 303 insertions, 0 deletions
diff --git a/Build-A-Release.mk b/Build-A-Release.mk new file mode 100644 index 0000000..3b7093d --- /dev/null +++ b/Build-A-Release.mk @@ -0,0 +1,303 @@ +### Makefile for preparing a progressive release. +### + +### This makefile is distinct from test-build for several reasons. +### First, this version builds a "stage4" using src directories that +### have no CVS directories. Second, the binaries are build from +### independent copies of the source. That is, each host release will +### have it's own copy of the src directory. + +### +### This file was written and is maintained by K. Richard Pixley, +### <rich@cygnus.com>. +### + +CVS := /usr/latest/bin/cvs # using cvs-1.3 +tree := progressive +rooting := /usr/cygnus +cvs_module := progressive1 +gccflags := "-O" +release_tag := progressive-920529 +bundle := emacs +host := sun4 + +ifeq (${bundle},emacs) +fixincludes := +doc := emacs +else +fixincludes := ${host_release}/lib/fixincludes +doc := install +endif + +host_release=${host}/${release_tag} +objdir=${host_release}/objdir + +all: .${host}-done fluff + +testfile: all blockit ${host}+.Z +${host}+.Z: + (cd ${host} ; tar cf - ${release_tag} \ + | compress -vV \ + | ../blockit \ + > ../$@) + +.${host}-done: .${host}-install .${host}-install-info +# rm -rf ${objdir} +# touch $@ + +.${host}-install: .${host}-all + ${MAKE} -C ${objdir} -w install-no-fixedincludes \ + prefix=`pwd`/${host_release} \ + exec_prefix=`pwd`/${host_release}/H-${host} \ + "CC=/usr/cygnus/${tree}.${tree}/H-${host}/bin/gcc ${gccflags}" + touch $@ + +.${host}-install-info: .${host}-info + ${MAKE} -C ${objdir} -w install-info \ + prefix=`pwd`/${host_release} \ + exec_prefix=`pwd`/${host_release}/H-${host} \ + "CC=/usr/cygnus/${tree}.${tree}/H-${host}/bin/gcc \ + ${gccflags}" + touch $@ + +.${host}-all: .${host}-config + ${MAKE} -C ${objdir} -w all "CC=/usr/cygnus/${tree}.${tree}/H-${host}/bin/gcc ${gccflags}" + touch $@ + +.${host}-info: .${host}-config + ${MAKE} -C ${objdir} -w info "CC=/usr/cygnus/${tree}.${tree}/H-${host}/bin/gcc ${gccflags}" + touch $@ + +.${host}-config: .${host}-src + cd ${objdir} ; \ + ../src/configure ${host} \ + -prefix=${rooting}/${release_tag} \ + -exec_prefix=${rooting}/${release_tag}/H-${host} + touch $@ + +.${host}-src: .${release_tag}-co .${host}-dirs + rm -rf ${host_release}/src + (tar cf - ${release_tag} | (cd ${host_release} ; tar xvf -) ; true) + (cd ${host_release}/${release_tag} ; find . \( -name CVS -o -name CVS.adm \) -depth -exec rm -rf {} \; ) + mv ${host_release}/${release_tag} ${host_release}/src + touch $@ + +.${host}-dirs: + [ -d ${host} ] || mkdir ${host} + [ -d ${host_release} ] || mkdir ${host_release} + [ -d ${objdir} ] || mkdir ${objdir} + touch $@ + +.${release_tag}-co: .${release_tag}-tagged + ${CVS} co -r ${release_tag} ${cvs_module} + mv ${tree} ${release_tag} + touch $@ + +.${release_tag}-tagged: + ${CVS} rtag ${release_tag} ${cvs_module} + touch $@ + +fluff: ${host_release}/src/Build-A-Release.mk \ + ${host_release}/src/Pack-A-Progressive \ + ${fixincludes} \ + ${host_release}/src/README \ + ${fixincludes} \ + ${host}/Install \ + ${host}/install.dvi \ + ${host}/tape-labels.dvi \ + ${host_release}/CYGNUS + +${host}/tape-labels.dvi: ${host_release}/src/tape-labels.tex + cp $< ${host}/`basename $<` + (cd ${host} ; tex `basename $<`) + rm ${host}/`basename $<` + +${host}/install.dvi: ${host_release}/src/install.texinfo + cp $< ${host}/`basename $<` + (cd ${host} ; tex `basename $<`) + (cd ${host} ; tex `basename $<`) + (cd ${host} ; tex `basename $<`) + rm ${host}/`basename $<` + +print-notes: ${host}/install.dvi + lpr $^ + +print-labels: ${host}/tape-labels.dvi + lpr $^ + +clean-fluff: + rm -f ${host_release}/src/Build-A-Release.mk \ + ${host_release}/src/Pack-A-Progressive \ + ${host_release}/lib/fixincludes \ + ${host_release}/Install \ + ${host_release}/src/${doc}-texi.in \ + ${host_release}/src/tape-labels-tex.in \ + ${host_release}/src/tape-labels.tex \ + ${host_release}/src/install.texinfo \ + ${host_release}/src/Install.in \ + +${host_release}/src/Build-A-Release.mk: ${release_tag}/Build-A-Release.mk + cp $< $@ + +${host_release}/src/Pack-A-Progressive: ${release_tag}/Pack-A-Progressive + cp $< $@ + +${host_release}/src/Install.in: ${release_tag}/Install.in + cp $< $@ + +${host_release}/src/CYGNUS: ${release_tag}/CYGNUS + cp $< $@ + +${host_release}/CYGNUS: ${host_release}/src/CYGNUS + cp $< $@ + +${host_release}/src/${doc}-texi.in: ${release_tag}/${doc}-texi.in + cp $< $@ + +${host_release}/src/tape-labels-tex.in: ${release_tag}/tape-labels-tex.in + cp $< $@ + +${host_release}/lib/fixincludes: ${host_release}/src/gcc/fixincludes + cp $< $@ + chmod a+x $@ + +${host}/Install: ${host_release}/Install + cp $< $@ + chmod a+x $@ + +${host_release}/Install: ${host_release}/src/Install + cp $< $@ + chmod a+x $@ + +${host_release}/src/install.texinfo: ${host_release}/src/${doc}-texi.in + $(MAKE) process -f Build-A-Release.mk IN=$< OUT=$@ relno=`echo ${release_tag} | sed "/${tree}-/s///"` + +${host_release}/src/tape-labels.tex: ${host_release}/src/tape-labels-tex.in + $(MAKE) process -f Build-A-Release.mk IN=$< OUT=$@ relno=`echo ${release_tag} | sed "/${tree}-/s///"` + +${host_release}/src/README: ${host_release}/src/install.texinfo + -makeinfo +no-headers +no-split $< -o $@ +### remove tags table + sed -e '/^Tag Table/,$$d' $@ | sed -e '$$d' > $@.new + mv -f $@.new $@ + +${host_release}/src/Install: ${host_release}/src/Install.in + $(MAKE) process -f Build-A-Release.mk IN=$< OUT=$@ relno=`echo ${release_tag} | sed "/${tree}-/s///"` + chmod a+x $@ + +process: process-${host} + @if grep '||' ${OUT}.new ; then \ + echo $0 missed at least one of the triggers. 1>&2 ; \ + exit 1 ; \ + else \ + true ; \ + fi + mv ${OUT}.new ${OUT} + +process-sun4: + sed -e "/^@clear HOSTsun4/s::@set HOSTsun4:" \ + -e "/^@set HOSTsun3/s::@clear HOSTsun3:" \ + -e "/^@set HOSTdecstation/s::@clear HOSTdecstation:" \ + -e "/^@set HOSTiris/s::@clear HOSTiris:" \ + -e "/^@set HOSTrs6000/s::@clear HOSTrs6000:" \ + -e "/^@set FIXMES/s::@clear FIXMES:" \ + -e "/\|\|RELNO\|\|/s::${relno}:g" \ + -e "/\|\|TAPdflt\|\|/s::QIC-24:g" \ + -e "/\|\|DEVdflt\|\|/s::/dev/nrst8:g" \ + -e "/\|\|BD\|\|/s::35:g" \ + -e "/\|\|SD\|\|/s::34:g" \ + -e "/\|\|DF\|\|/s::69:g" \ + -e "/\|\|HOST\|\|/s::Sun-4:g" \ + -e "/\|\|HOSTstr\|\|/s::sun4:g" \ + -e "/\|\|TARGET\|\|/s::sun4:g" \ + -e "/\|\|GCCvn\|\|/s::cygnus-2.0.2:g" \ + -e "/\|\|BUNDLE\|\|/s::${bundle}:g" \ + < ${IN} > ${OUT}.new + +process-sun3: + sed -e "/^@set HOSTsun4/s::@clear HOSTsun4:" \ + -e "/^@clear HOSTsun3/s::@set HOSTsun3:" \ + -e "/^@set HOSTdecstation/s::@clear HOSTdecstation:" \ + -e "/^@set HOSTiris/s::@clear HOSTiris:" \ + -e "/^@set HOSTrs6000/s::@clear HOSTrs6000:" \ + -e "/^@set FIXMES/s::@clear FIXMES:" \ + -e "/\|\|RELNO\|\|/s::${relno}:g" \ + -e "/\|\|TAPdflt\|\|/s::QIC-24:g" \ + -e "/\|\|DEVdflt\|\|/s::/dev/nrst8:g" \ + -e "/\|\|BD\|\|/s::32:g" \ + -e "/\|\|SD\|\|/s::34:g" \ + -e "/\|\|DF\|\|/s::65:g" \ + -e "/\|\|HOST\|\|/s::Sun-3:g" \ + -e "/\|\|HOSTstr\|\|/s::sun3:g" \ + -e "/\|\|TARGET\|\|/s::sun3:g" \ + -e "/\|\|GCCvn\|\|/s::cygnus-2.0.2:g" \ + -e "/\|\|BUNDLE\|\|/s::${bundle}:g" \ + < ${IN} > ${OUT}.new + +process-decstation: + sed -e "/^@set HOSTsun4/s::@clear HOSTsun4:" \ + -e "/^@set HOSTsun3/s::@clear HOSTsun3:" \ + -e "/^@clear HOSTdecstation/s::@set HOSTdecstation:" \ + -e "/^@set HOSTiris/s::@clear HOSTiris:" \ + -e "/^@set HOSTrs6000/s::@clear HOSTrs6000:" \ + -e "/^@set FIXMES/s::@clear FIXMES:" \ + -e "/\|\|RELNO\|\|/s::${relno}:g" \ + -e "/\|\|TAPdflt\|\|/s::QIC-24:g" \ + -e "/\|\|DEVdflt\|\|/s::/dev/nrmt0:g" \ + -e "/\|\|BD\|\|/s::27:g" \ + -e "/\|\|SD\|\|/s::34:g" \ + -e "/\|\|DF\|\|/s::61:g" \ + -e "/\|\|HOST\|\|/s::Decstation:g" \ + -e "/\|\|HOSTstr\|\|/s::decstation:g" \ + -e "/\|\|TARGET\|\|/s::decstation:g" \ + -e "/\|\|GCCvn\|\|/s::cygnus-2.0.2:g" \ + -e "/\|\|BUNDLE\|\|/s::${bundle}:g" \ + < ${IN} > ${OUT}.new + true + +process-iris4: + sed -e "/^@set HOSTsun4/s::@clear HOSTsun4:" \ + -e "/^@set HOSTsun3/s::@clear HOSTsun3:" \ + -e "/^@set HOSTdecstation/s::@clear HOSTdecstation:" \ + -e "/^@clear HOSTiris/s::@set HOSTiris:" \ + -e "/^@set HOSTrs6000/s::@clear HOSTrs6000:" \ + -e "/^@set FIXMES/s::@clear FIXMES:" \ + -e "/\|\|RELNO\|\|/s::${relno}:g" \ + -e "/\|\|TAPdflt\|\|/s::QIC-24:g" \ + -e "/\|\|DEVdflt\|\|/s::/dev/mt/tps0d0nrns:g" \ + -e "/\|\|BD\|\|/s::25:g" \ + -e "/\|\|SD\|\|/s::34:g" \ + -e "/\|\|DF\|\|/s::59:g" \ + -e "/\|\|HOST\|\|/s::Iris:g" \ + -e "/\|\|HOSTstr\|\|/s::iris4:g" \ + -e "/\|\|TARGET\|\|/s::iris4:g" \ + -e "/\|\|GCCvn\|\|/s::cygnus-2.0.2:g" \ + -e "/\|\|BUNDLE\|\|/s::${bundle}:g" \ + < ${IN} > ${OUT}.new + +process-rs6000: + sed -e "/^@set HOSTsun4/s::@clear HOSTsun4:" \ + -e "/^@set HOSTsun3/s::@clear HOSTsun3:" \ + -e "/^@set HOSTdecstation/s::@clear HOSTdecstation:" \ + -e "/^@set HOSTiris/s::@clear HOSTiris:" \ + -e "/^@clear HOSTrs6000/s::@set HOSTrs6000:" \ + -e "/^@set FIXMES/s::@clear FIXMES:" \ + -e "/\|\|RELNO\|\|/s::${relno}:g" \ + -e "/\|\|TAPdflt\|\|/s::QIC-24:g" \ + -e "/\|\|DEVdflt\|\|/s::/dev/rmt0.1:g" \ + -e "/\|\|BD\|\|/s::36:g" \ + -e "/\|\|SD\|\|/s::34:g" \ + -e "/\|\|DF\|\|/s::70:g" \ + -e "/\|\|HOST\|\|/s::RS/6000:g" \ + -e "/\|\|HOSTstr\|\|/s::rs6000:g" \ + -e "/\|\|TARGET\|\|/s::rs6000:g" \ + -e "/\|\|GCCvn\|\|/s::cygnus-2.0.2:g" \ + -e "/\|\|BUNDLE\|\|/s::${bundle}:g" \ + < ${IN} > ${OUT}.new + +clean: + rm -rf ${host} + +blockit: blockit.c + +### EOF |