X-Git-Url: https://git.donarmstrong.com/?p=deb_pkgs%2Fscowl.git;a=blobdiff_plain;f=debian%2Frules;h=a861e1a1b5d1169391860fd8b70ecf227a4d82d7;hp=c1a5186f8b901fb914c53c377138f69600548bc1;hb=ac4bd44e5e62039df4feb3b30fd0d6c68d21f1e7;hpb=d2e69afe66d4eba2ab1e6dfc9d329a927802f118 diff --git a/debian/rules b/debian/rules index c1a5186..a861e1a 100755 --- a/debian/rules +++ b/debian/rules @@ -16,27 +16,34 @@ export DH_OPTIONS # The medium size packages have no -size part in their names # These are the scowl extensions (complexity numbers?) that contribute to each word list (i.e. each size); # the -size parts "-small", "", "-large", and "-huge" correspond to the end of the binary package name: +empty:= +SIZES=small "" large huge insane SIZE_EXTENSIONS_small:=10 20 35 SIZE_EXTENSIONS:=$(SIZE_EXTENSIONS_small) 40 50 SIZE_EXTENSIONS_large:=$(SIZE_EXTENSIONS) 55 60 70 -SIZE_EXTENSIONS_huge:=$(SIZE_EXTENSIONS_large) 80 95 -#SIZE_EXTENSIONS-huge:=10 20 35 40 50 55 60 70 80 95 +SIZE_EXTENSIONS_huge:=$(SIZE_EXTENSIONS_large) 80 +SIZE_EXTENSIONS_insane:=$(SIZE_EXTENSIONS_huge) 95 export SIZE_EXTENSIONS_small export SIZE_EXTENSIONS export SIZE_EXTENSIONS_large export SIZE_EXTENSIONS_huge +export SIZE_EXTENSIONS_insane + +SPELLINGS:= american british canadian # These are the scowl word list classes we use: CLASSES:=words proper-names upper contractions -VARIANTS:=0 1 +VARIANTS:=1 2 -build: build-stamp -build-stamp: - dh_testdir +include /usr/share/dpkg/pkg-info.mk + +%: + dh $@ +build: set -e;\ - for SPELLING in american british canadian; do\ - for SIZE in small "" large huge; do\ + for SPELLING in $(SPELLINGS); do\ + for SIZE in $(SIZES); do\ if [ -n "$$SIZE" ]; then SIZE_NAME="_$$SIZE"; SIZE="-$$SIZE"; else SIZE_NAME=""; SIZE=""; fi; \ echo "The following SCOWL word lists were concatenated and sorted (with duplicates" > w$$SPELLING$$SIZE.scowl-word-lists-used;\ echo "removed) to create this word list (see README.Debian for more details):" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ @@ -49,12 +56,36 @@ build-stamp: echo " english-$$CLASS.$$EXT" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ fi;\ for VARIANT in $(VARIANTS); do\ - if [ -f final/variant_$$VARIANT-$$CLASS.$$EXT ]; then\ - echo "cat final/variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted";\ - cat final/variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted;\ - echo " variant_$$VARIANT-$$CLASS.$$EXT" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ + VARIANT_FILE="$${SPELLING}_"; \ + if [ "$$VARIANT_FILE" = "american_" ]; then \ + VARIANT_FILE=""; \ + fi; \ + if [ -f final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT ]; then\ + echo "cat final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted";\ + cat final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted;\ + echo " $${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ fi;\ done;\ + if [ "$$SIZE" = "insane" ]; then\ + for VARIANT in $(VARIANTS); do\ + for VARIANT_FILE in $(SPELLINGS); do \ + VARIANT_FILE="$${VARIANT_FILE}_"; \ + if [ "$$VARIANT_FILE" = "american_" ]; then \ + VARIANT_FILE=""; \ + fi; \ + if [ -f final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT ]; then\ + echo "cat final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted";\ + cat final/$${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted;\ + echo " $${VARIANT_FILE}variant_$$VARIANT-$$CLASS.$$EXT" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ + fi;\ + done; \ + done; \ + for special in final/special_*.$$CLASS; do \ + echo "cat $$special >> $$SPELLING-english$$SIZE.unsorted";\ + cat $$special >> $$SPELLING-english$$SIZE.unsorted;\ + echo " $$special" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\ + done;\ + fi;\ if [ -f final/$$SPELLING-$$CLASS.$$EXT ]; then\ echo "cat final/$$SPELLING-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted";\ cat final/$$SPELLING-$$CLASS.$$EXT >> $$SPELLING-english$$SIZE.unsorted;\ @@ -62,145 +93,62 @@ build-stamp: fi;\ done;\ done;\ - echo "cat $$SPELLING-english$$SIZE.unsorted | sort -u | iconv -t 'utf-8' > $$SPELLING-english$$SIZE; rm $$SPELLING-english$$SIZE.unsorted";\ - cat $$SPELLING-english$$SIZE.unsorted | sort -u | iconv -t 'utf-8' > $$SPELLING-english$$SIZE; rm $$SPELLING-english$$SIZE.unsorted;\ + echo "cat $$SPELLING-english$$SIZE.unsorted | LC_ALL=C sort -u | iconv -t 'utf-8' > $$SPELLING-english$$SIZE; rm $$SPELLING-english$$SIZE.unsorted";\ + cat $$SPELLING-english$$SIZE.unsorted | LC_ALL=C sort -u | iconv -f 'iso8859-1' -t 'utf-8' > $$SPELLING-english$$SIZE; rm $$SPELLING-english$$SIZE.unsorted;\ done;\ done + cd speller && $(MAKE) hunspell - touch build-stamp - - -clean: - dh_testdir - dh_testroot - rm -f build-stamp - +override_dh_auto_clean: set -e;\ - for SIZE in -small "" -large -huge; do\ - for SPELLING in american british canadian; do\ + for SIZE in $(SIZES); do\ + if [ -n "$$SIZE" ]; then SIZE="-$$SIZE"; fi; \ + for SPELLING in $(SPELLINGS); do\ rm -f $$SPELLING-english$$SIZE.unsorted $$SPELLING-english$$SIZE $$SPELLING-english$$SIZE.5 w$$SPELLING$$SIZE.scowl-word-lists-used;\ done;\ done + cd speller && $(MAKE) clean - dh_clean +INSTALL_WORDLISTS=$(patsubst %-"",%,$(foreach spelling,$(SPELLINGS),$(foreach size,$(SIZES),install-w$(spelling)-$(size)))) +override_dh_auto_install: install build -install: DH_OPTIONS= -install: install-scowl \ - install-wamerican install-wamerican-small install-wamerican-large install-wamerican-huge \ - install-wbritish install-wbritish-small install-wbritish-large install-wbritish-huge \ - install-wcanadian install-wcanadian-small install-wcanadian-large install-wcanadian-huge +override_dh_auto_build: + +install: build install-scowl $(INSTALL_WORDLISTS) installdeb-wordlist -pwamerican --noscripts - dh_installdebconf -pwamerican installdeb-wordlist --no-package=wamerican --no-package=scowl - - -.PHONY: install-scowl -install-scowl: PKG=scowl install-scowl: - dh_testdir - dh_testroot - dh_installdirs --package=$(PKG) + dh_installdirs --package=scowl - dh_install --package=$(PKG) final/*.[0-9][0-9] usr/share/dict/scowl - dh_installdocs --package=$(PKG) README debian/README.Debian + dh_install --package=scowl final/*.[0-9][0-9] usr/share/dict/scowl + dh_installdocs --package=scowl README debian/README.Debian +install-hunspell: + dh_install --package=hunspell-en-us + dh_install --package=hunspell-en-au + dh_install --package=hunspell-en-ca -.PHONY: install-wordlist -install-wordlist: -# PKG and WORDLIST must have been set to the binary package name and word list file name, respectively. - dh_testdir - dh_testroot - dh_installdirs --package=$(PKG) +override_dh_auto_test: + echo "doing nothing"; - dh_install --package=$(PKG) $(WORDLIST) usr/share/dict +override_dh_gencontrol: + dh_gencontrol -Nhunspell-en-us -Nhunspell-en-au -Nhunspell-en-ca + dh_gencontrol -phunspell-en-us -phunspell-en-au -phunspell-en-ca -- -v1:$(DEB_VERSION_UPSTREAM) - dh_installdocs --package=$(PKG) $(PKG).scowl-word-lists-used debian/README.Debian +WORDLIST=$(shell echo $(*)|sed -re 's/^w([a-z]*)(-*[a-z]*)/\1-english\2/') +$(INSTALL_WORDLISTS): install-%: install-scowl + dh_testdir + dh_testroot + dh_installdirs --package=$(*) usr/share/dict + dh_install --package=$(*) $(shell echo $(*)|sed -re \ +'s/^w([a-z]*)(-*[a-z]*)/\1-english\2/') usr/share/dict + dh_installdocs --package=$(*) $(*).scowl-word-lists-used debian/README.Debian sed "s/WORDLIST/$(WORDLIST)/g" < debian/wordlist_manpage_template > $(WORDLIST).5 - dh_installman --package=$(PKG) $(WORDLIST).5 + dh_installman --package=$(*) $(WORDLIST).5 +# this is the install-w$(SPELLING)-$(VARIANT) rule +.PHONY: $(foreach spelling,$(SPELLINGS),$(foreach size,$(SIZES),install-w$(spelling)-$(size))) -.PHONY: install-wamerican -install-wamerican: build-stamp - $(MAKE) -f debian/rules PKG=wamerican WORDLIST=american-english install-wordlist - -.PHONY: install-wamerican-small -install-wamerican-small: build-stamp - $(MAKE) -f debian/rules PKG=wamerican-small WORDLIST=american-english-small install-wordlist - -.PHONY: install-wamerican-large -install-wamerican-large: build-stamp - $(MAKE) -f debian/rules PKG=wamerican-large WORDLIST=american-english-large install-wordlist - -.PHONY: install-wamerican-huge -install-wamerican-huge: build-stamp - $(MAKE) -f debian/rules PKG=wamerican-huge WORDLIST=american-english-huge install-wordlist - - -.PHONY: install-wbritish -install-wbritish: build-stamp - $(MAKE) -f debian/rules PKG=wbritish WORDLIST=british-english install-wordlist - -.PHONY: install-wbritish-small -install-wbritish-small: build-stamp - $(MAKE) -f debian/rules PKG=wbritish-small WORDLIST=british-english-small install-wordlist - -.PHONY: install-wbritish-large -install-wbritish-large: build-stamp - $(MAKE) -f debian/rules PKG=wbritish-large WORDLIST=british-english-large install-wordlist - -.PHONY: install-wbritish-huge -install-wbritish-huge: build-stamp - $(MAKE) -f debian/rules PKG=wbritish-huge WORDLIST=british-english-huge install-wordlist - - -.PHONY: install-wcanadian -install-wcanadian: build-stamp - $(MAKE) -f debian/rules PKG=wcanadian WORDLIST=canadian-english install-wordlist - -.PHONY: install-wcanadian-small -install-wcanadian-small: build-stamp - $(MAKE) -f debian/rules PKG=wcanadian-small WORDLIST=canadian-english-small install-wordlist - -.PHONY: install-wcanadian-large -install-wcanadian-large: build-stamp - $(MAKE) -f debian/rules PKG=wcanadian-large WORDLIST=canadian-english-large install-wordlist - -.PHONY: install-wcanadian-huge -install-wcanadian-huge: build-stamp - $(MAKE) -f debian/rules PKG=wcanadian-huge WORDLIST=canadian-english-huge install-wordlist - - - -# This single target is used to build all the packages, all at once, or -# one at a time. So keep in mind: any options passed to commands here will -# affect _all_ packages. Anything you want to only affect one package -# should be put in another target, such as the install target. -binary-common: - dh_testdir - dh_testroot - dh_installchangelogs - dh_link - dh_compress - dh_fixperms - dh_installdeb - dh_shlibdeps - dh_gencontrol - dh_md5sums - dh_builddeb - -# Build architecture independant packages using the common target. -binary-indep: build install - $(MAKE) -f debian/rules DH_OPTIONS=-i binary-common - -# Build architecture dependant packages using the common target. -binary-arch: build install - -# Any other binary targets build just one binary package at a time. -binary-%: build install - make -f debian/rules binary-common DH_OPTIONS=-p$* - -binary: binary-indep binary-arch -.PHONY: build clean binary-indep binary-arch binary-common binary install