]> git.donarmstrong.com Git - deb_pkgs/scowl.git/blobdiff - debian/rules
Build hunspell-en-{us,au,ca} from scowl
[deb_pkgs/scowl.git] / debian / rules
index a66c8e79a9084816f8ec87f2c99b212fd34f13bc..a861e1a1b5d1169391860fd8b70ecf227a4d82d7 100755 (executable)
@@ -23,7 +23,6 @@ SIZE_EXTENSIONS:=$(SIZE_EXTENSIONS_small) 40 50
 SIZE_EXTENSIONS_large:=$(SIZE_EXTENSIONS) 55 60 70
 SIZE_EXTENSIONS_huge:=$(SIZE_EXTENSIONS_large) 80
 SIZE_EXTENSIONS_insane:=$(SIZE_EXTENSIONS_huge) 95
-#SIZE_EXTENSIONS-huge:=10 20 35 40 50 55 60 70 80 95
 export SIZE_EXTENSIONS_small
 export SIZE_EXTENSIONS
 export SIZE_EXTENSIONS_large
@@ -34,12 +33,14 @@ 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 $(SPELLINGS); do\
          for SIZE in $(SIZES); do\
@@ -55,17 +56,34 @@ 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 special in special_hacker.50; do \
-                   echo "cat final/$$special >> $$SPELLING-english$$SIZE.unsorted";\
-                   cat final/final/$$special >> $$SPELLING-english$$SIZE.unsorted;\
-                   echo "  final/$$special" >> w$$SPELLING$$SIZE.scowl-word-lists-used;\
+                 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\
@@ -75,19 +93,13 @@ 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 -f 'iso8859-1' -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 $(SIZES); do\
          if [ -n "$$SIZE" ]; then SIZE="-$$SIZE"; fi; \
@@ -95,63 +107,48 @@ clean:
            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 $(patsubst %-"",%,$(foreach spelling,$(SPELLINGS),$(foreach size,$(SIZES),install-w$(spelling)-$(size))))
+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
 
-# this is the install-w$(SPELLING)-$(VARIANT) rule
-.PHONY: $(patsubst %-"",%,$(foreach spelling,$(SPELLINGS),$(foreach size,$(SIZES),install-w$(spelling)-$(size))))
-THISPKG=$(patsubst install-%,%,$@)
-WORDLIST=$(shell echo $@|sed -re 's/^install-w([a-z]*)(-*[a-z]*)/\1-english\2/')
-$(patsubst %-"",%,$(foreach spelling,$(SPELLINGS),$(foreach size,$(SIZES),install-w$(spelling)-$(size)))): build-stamp
+override_dh_auto_test:
+       echo "doing nothing";
+
+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)
+
+
+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=$(THISPKG)
-       dh_install --package=$(THISPKG) $(WORDLIST) usr/share/dict
-       dh_installdocs --package=$(THISPKG) $(THISPKG).scowl-word-lists-used debian/README.Debian
+       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=$(THISPKG) $(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)))
 
-# 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
-
-binary: binary-indep binary-arch
-.PHONY: build clean binary-indep binary-arch binary-common binary install