# Hspell Makefile
# Copyright (C) 2002-2004 Nadav Har'El and Dan Kenigsberg
# Locale override:
# Some of the things we do here (like sort), and Perl scripts we run can be
# distracted by the user's locale setting, which are irrelevant (Hspell's
# source and data are all in ISO-8859-8, and that has nothing to do with the
# builder's choice of locale). So we need to override them. The best would
# have been to do:
# export LANG=C
# export LC_ALL=C
# But the "export" directive is only supported by Gnu make, so let's instead
# redfine all the relevant LC_* variables the user might have set... Note that
# the following only modified environment variables that were already exported
# by the user - which is actually ok (but this makes us have to set all these
# different variables).
LANG=C
LC_ALL=C
LC_CTYPE=C
LC_COLLATE=C
# build and installation paths
prefix =
exec_prefix = ${prefix}
DESTDIR =
PREFIX =
BIN = ${exec_prefix}/bin
SHARE = ${prefix}/share/hspell
LIBEXEC = ${exec_prefix}/libexec/hspell
MAN1 = ${prefix}/man/man1
MAN3 = ${prefix}/man/man3
LIBDIR = ${exec_prefix}/lib
INCLUDEDIR = ${prefix}/include
DICTBASE = $(SHARE)/hebrew.wgz
PERL=/usr/local/bin/perl
CC=cc
DEFS=-DPACKAGE_NAME=\"\" -DPACKAGE_TARNAME=\"\" -DPACKAGE_VERSION=\"\" -DPACKAGE_STRING=\"\" -DPACKAGE_BUGREPORT=\"\" -Dinline= -Dconst= -DHAVE_ZLIB=1 -DDICTIONARY_BASE=\"$(DICTBASE)\"
CFLAGS=-fno-common
LIBS=-lz
CPPFLAGS=
LDFLAGS=
.c.o:
$(CC) -c $(CFLAGS) $(CPPFLAGS) $(DEFS) $<
# Our TARGETS variable chooses what to compile. Some things are
# optionally compiled depending on --enable-* paramters to configure.
TARGETS = hebrew.wgz.sizes hspell
all: $(TARGETS)
# SEDCMD controls on whether objective-kinuyim - about 130,000 rare verb
# forms - are left during build or removed. It is set to the appropriate
# strings when "configure" is run (depending on whether --enable-fatverb
# is given).
SEDCMD=/\+/d
# EXTRAOBJECTS - for --enable-linginfo
EXTRAOBJECTS=
clean:
rm -f out.nouns out.verbs out.nouns-shemp hspell.pl_full \
hspell.pl_wzip wunzip wordlist.wgz shemp.dat \
corlist.o dict_radix.o find_sizes.o gimatria.o \
hspell.o tclHash.o hebrew.wgz hebrew.wgz.sizes \
hebrew.wgz.prefixes dout.nouns.shemp.gz shemp.dat \
dout.nouns.wolig.gz dout.verbs.gz hspell find_sizes \
prefixes.c libhspell.o libhspell.a \
hebrew.wgz.desc hebrew.wgz.stems he_affix.dat \
he.cwl mk_he_affix linginfo.o mk_he_affix.o \
hebrew.wgz.lingsizes.tmp
distclean: clean
rm -f Makefile config.log config.status
install: all
test -d $(DESTDIR)/$(BIN) || mkdir -m 755 -p $(DESTDIR)/$(BIN)
strip hspell
-rm -f $(DESTDIR)/$(BIN)/hspell
cp hspell $(DESTDIR)/$(BIN)/hspell
chmod 755 $(DESTDIR)/$(BIN)/hspell
cp multispell $(DESTDIR)/$(BIN)/multispell
chmod 755 $(DESTDIR)/$(BIN)/multispell
test -d $(DESTDIR)/$(SHARE) || mkdir -m 755 -p $(DESTDIR)/$(SHARE)
cp hebrew.wgz hebrew.wgz.prefixes hebrew.wgz.sizes $(DESTDIR)/$(SHARE)/
gzip -9 < spellinghints > $(DESTDIR)/$(SHARE)/hebrew.wgz.hints
(cd $(DESTDIR)/$(SHARE); chmod 644 hebrew.wgz hebrew.wgz.prefixes hebrew.wgz.sizes hebrew.wgz.hints)
test ! -f hebrew.wgz.stems || cp hebrew.wgz.stems hebrew.wgz.desc $(DESTDIR)/$(SHARE)/
(cd $(DESTDIR)/$(SHARE); test ! -f hebrew.wgz.stems || chmod 644 hebrew.wgz.stems hebrew.wgz.desc)
-rm -f $(DESTDIR)/$(BIN)/hspell-i
-ln -s hspell $(DESTDIR)/$(BIN)/hspell-i
test -d $(DESTDIR)/$(MAN1) || mkdir -m 755 -p $(DESTDIR)/$(MAN1)
cp hspell.1 $(DESTDIR)/$(MAN1)/
chmod 644 $(DESTDIR)/$(MAN1)/hspell.1
test -d $(DESTDIR)/$(MAN3) || mkdir -m 755 -p $(DESTDIR)/$(MAN3)
cp hspell.3 $(DESTDIR)/$(MAN3)/
chmod 644 $(DESTDIR)/$(MAN3)/hspell.3
test -d $(DESTDIR)/$(LIBDIR) || mkdir -m 755 -p $(DESTDIR)/$(LIBDIR)
cp libhspell.a $(DESTDIR)/$(LIBDIR)/
chmod 644 $(DESTDIR)/$(LIBDIR)/libhspell.a
test -d $(DESTDIR)/$(INCLUDEDIR) || mkdir -m 755 -p $(DESTDIR)/$(INCLUDEDIR)
cp hspell.h linginfo.h $(DESTDIR)/$(INCLUDEDIR)/
chmod 644 $(DESTDIR)/$(INCLUDEDIR)/hspell.h $(DESTDIR)/$(INCLUDEDIR)/linginfo.h
################################################
# for creating an hspell distribution tar
PACKAGE = hspell
VERSION = 0.8
DISTFILES = COPYING INSTALL LICENSE README WHATSNEW TODO \
Makefile.in stats wunzip.c wzip \
hspell.1 \
wolig.pl wolig.dat biza-nouns milot extrawords \
woo woo.dat biza-verbs \
likelyerrors spellinghints \
hspell.spec \
corlist.c dict_radix.c \
dict_radix.h find_sizes.c gimatria.c hspell.c \
hspell.h libhspell.c gzbuffered.h \
pmerge PrefixBits.pl genprefixes.pl \
hash.h tclHash.c tclHash.h \
binarize-desc.pl pack-desc.pl linginfo.c linginfo.h \
multispell hspell.3 mk_he_affix.c configure.in configure
DISTDIR = $(PACKAGE)-$(VERSION)
distdir:
rm -rf ./$(DISTDIR)
mkdir -m 755 $(DISTDIR)
cp -a --parents $(DISTFILES) $(DISTDIR)
# Note that Oron Peled suggested a more eleborate version that makes hard
# links instead of copies:
# for file in $(DISTFILES); do \
# if test -d $$file; then \
# cp -pr $$file $(distdir)/$$file; \
# else \
# test -f $(distdir)/$$file \
# || ln $$file $(distdir)/$$file 2> /dev/null \
# || cp -p $$file $(distdir)/$$file || :; \
# fi; \
# done
dist: distdir
tar zcvf $(DISTDIR).tar.gz $(DISTDIR)
rm -rf ./$(DISTDIR)
############################################################################
############################################################################
# moved from c/Makefile:
#normal: hebrew.wgz.sizes hspell
libhspell.a: dict_radix.o gimatria.o corlist.o libhspell.o $(EXTRAOBJECTS)
-rm -f $@
ar cr $@ $^
-ranlib $@
hspell: hspell.o tclHash.o libhspell.a
$(CC) $(CFLAGS) $(LDFLAGS) -o hspell hspell.o tclHash.o libhspell.a $(LIBS)
# remember to update this dependency list once in a while...
libhspell.o dict_radix.o find_sizes.o: dict_radix.h
dict_radix.o linginfo.o: gzbuffered.h
libhspell.o: prefixes.c
hspell.o: hash.h tclHash.h
tclHash.o: tclHash.h
corlist.o gimatria.o hspell.o libhspell.o: hspell.h
hspell.o libhspell.o linginfo.o: linginfo.h hspell.h
linginfo.o: dmask.c
prefixes.c: genprefixes.pl
$(PERL) -w ./genprefixes.pl >prefixes.c
find_sizes: find_sizes.o dict_radix.o
$(CC) $(CFLAGS) $(LDFLAGS) -o find_sizes find_sizes.o dict_radix.o $(LIBS)
GZDICTS= dout.nouns.wolig.gz dout.verbs.gz dout.nouns.shemp.gz
DICTS=milot extrawords biza-verbs biza-nouns
# hebrew.wgz contains all the words without any prefix hints like B,L,+ we
# previously had.
# hebrew.wgz.prefixes is the prefix hints (one byte per word, compressed).
# hebrew.wgz.sizes contains the memory sizes that reading hebrew.wgz will
# require (this makes it easier for hspell to preallocate the needed sizes).
hebrew.wgz hebrew.wgz.prefixes: pmerge $(DICTS) $(GZDICTS)
(gzip -dc $(GZDICTS); cat $(DICTS)) | ./pmerge -p hebrew.wgz.tmp | ./wzip | gzip -9 > hebrew.wgz
-rm -f hebrew.wgz.prefixes
gzip -9 < hebrew.wgz.tmp >hebrew.wgz.prefixes
-rm -f hebrew.wgz.tmp
hebrew.wgz.sizes: hebrew.wgz find_sizes
gzip -dc hebrew.wgz | ./find_sizes >hebrew.wgz.sizes
###################################### optional linginfo stuff ##############
dolinginfo: linginfo_data hspell
# hebrew.wgz contains all the words without any prefix hints like B,L,+ we
# previously had.
# hebrew.wgz.prefixes is the prefix hints (one byte per word, compressed).
# hebrew.wgz.sizes contains the memory sizes that reading hebrew.wgz will
# require (this makes it easier for hspell to preallocate the needed sizes).
# dmask.c contains an array of all possible values of the description bitmask.
# It is generated by pack-desc.pl. This array is not too long (no more than
# 300 for the default dictionary).
#
# In the following long rule, the complete list of all words with linguistic
# details is concatanated and sent to binarize-desc.pl, which converts the
# detail information of each word into bitmap (called dmask), produces a
# spesifier that tell which prefixes are accepted with the word, and writes its
# stem. Then the words list is sorted, packed (a-la uniq), and the output files
# are written.
#
# OLD NOTE/TODO:
# The "linginfo_data:" target line below is ugly and un-make-like. Not only
# that, it doesn't know when it's necessary to build the files again, and
# when it is not. The better make targets (hebrew.wgz et al. and
# hebrew.wgz.sizes) are commented out because the same targets were used above
# for building the version without linginfo. When building with linginfo
# becomes the default, we should remove the following line and uncomment the
# real targets.
# TODO: make pack-desc.pl/binarize-desc.pl and pmerge into just one script
# (with options on whether to generate stems, etc.), and then we won't have
# this ugliness of two different rules generating hebrew.wgz in two ways
# (this is not only ugly, it's unsafe. If we use linginfo (--enable-linginfo
# and change, say, "extrawords", and run "make hebrew.wgz" we will get the
# wrong program run. "make" will work properly because we stick an extra
# target in front of the default targets.
linginfo_data: hebrew.wgz.stems
hebrew.wgz.desc hebrew.wgz.stems hebrew.wgz.lingsizes.tmp dmask.c: binarize-desc.pl pack-desc.pl $(DICTS) $(GZDICTS) find_sizes
#hebrew.wgz hebrew.wgz.prefixes hebrew.wgz.desc hebrew.wgz.stems hebrew.wgz.lingsizes.tmp dmask.c: binarize-desc.pl pack-desc.pl $(DICTS) $(GZDICTS)
(gzip -dc $(GZDICTS); cat $(DICTS)) | $(PERL) binarize-desc.pl | \
sort -u | $(PERL) pack-desc.pl -p hebrew.wgz.prefixes.tmp \
-d hebrew.wgz.desc.tmp -s hebrew.wgz.stems.tmp \
-l hebrew.wgz.lingsizes.tmp | \
./wzip | gzip -9 > hebrew.wgz
gzip -dc hebrew.wgz | ./find_sizes >hebrew.wgz.sizes
cat hebrew.wgz.lingsizes.tmp >> hebrew.wgz.sizes
-rm -f hebrew.wgz.lingsizes.tmp
-rm -f hebrew.wgz.prefixes
gzip -9 < hebrew.wgz.prefixes.tmp >hebrew.wgz.prefixes
-rm -f hebrew.wgz.prefixes.tmp
-rm -f hebrew.wgz.desc
gzip -9 < hebrew.wgz.desc.tmp >hebrew.wgz.desc
-rm -f hebrew.wgz.desc.tmp
-rm -f hebrew.wgz.stems
gzip -9 < hebrew.wgz.stems.tmp >hebrew.wgz.stems
-rm -f hebrew.wgz.stems.tmp
############################################################################
# dout.* are the outputs from the various word-list generators with the
# -d option (i.e., with an explanation on how each word was derived)
#
# The dout files are quite large, as much as 10MB. To lower the amount
# of temporary space needed during compilation (is this necessary nowadays?)
# we compress them.
dout.nouns.%: %.dat wolig.pl
$(PERL) -w wolig.pl -d $< > $@
dout.nouns.%.gz: %.dat wolig.pl
$(PERL) -w wolig.pl -d $< | gzip -4 > $@
dout.nouns.shemp.gz: shemp.dat wolig.pl
$(PERL) -w wolig.pl -d shemp.dat | gzip -4 > $@
dout.verbs.gz shemp.dat: woo woo.dat
$(PERL) -w woo -d woo.dat | sed "$(SEDCMD)" | gzip -4 > $@
############################################################################
# The "aspell" target generates the "he_affix.dat" and "he.cwl" files needed
# for using aspell with Hspell's Hebrew word list.
# This assumes that Aspell's "word-list-compress" utility is already installed.
aspell: wunzip he_affix.dat he.cwl
mk_he_affix.o: prefixes.c hspell.h
he_affix.dat he.cwl: mk_he_affix hebrew.wgz hebrew.wgz.prefixes
mk_he_affix | word-list-compress c > he.cwl
syntax highlighted by Code2HTML, v. 0.9.1