File: prune-alphabet-functionality.sh

package info (click to toggle)
hfst 3.16.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 14,532 kB
  • sloc: cpp: 101,875; sh: 6,717; python: 5,225; yacc: 4,985; lex: 2,900; makefile: 2,017; xml: 6
file content (71 lines) | stat: -rwxr-xr-x 1,850 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#!/bin/sh
TOOLDIR=../../tools/src
TOOL=
FORMAT_TOOL=

if [ "$1" = '--python' ]; then
    TOOL="python3 ./hfst-prune-alphabet.py"
    FORMAT_TOOL="python3 ./hfst-format.py"
else
    TOOL=$TOOLDIR/hfst-prune-alphabet
    FORMAT_TOOL=$TOOLDIR/hfst-format
    for tool in $TOOL $FORMAT_TOOL; do
	if ! test -x $tool; then
	    exit 77;
	fi
    done
fi

for i in  .hfst .sfst .ofst .foma; do

if (([ ".hfst" = "$i" ]) || $FORMAT_TOOL --list-formats | grep $i > /dev/null); then

    if test -f prunable_alphabet$i -a non_prunable_alphabet_1$i -a non_prunable_alphabet_2$i; then

	# Prunable alphabet
	for arg in --safe -S --force -f ""; do 
            if ! $TOOLDIR/hfst-minimize prunable_alphabet$i | $TOOL $arg > test ; then
		exit 1
	    fi
	    if ! $TOOLDIR/hfst-summarize --verbose test 2> /dev/null | grep --after-context 1 "sigma symbols missing from transducer" | tail -1 > tmp; then
		exit 1
	    fi
	    if grep "e, f" tmp > /dev/null; then
		exit 1
	    fi
	done

	# Non-prunable alphabets #1 and #2
	for number in 1 2; do
	    # safe pruning
	    for arg in --safe -S ""; do
		if ! $TOOLDIR/hfst-minimize non_prunable_alphabet_$number$i | $TOOL $arg > test ; then
		    exit 1
		fi
		if ! $TOOLDIR/hfst-summarize --verbose test 2> /dev/null | grep --after-context 1 "sigma symbols missing from transducer" | tail -1 > tmp; then
		    exit 1
		fi
		if ! grep "e, f" tmp > /dev/null; then
		    exit 1
		fi
	    done
	    # forced pruning
	    for arg in --force -f; do
		if ! $TOOLDIR/hfst-minimize non_prunable_alphabet_$number$i | $TOOL $arg > test ; then
		    exit 1
		fi
		if ! $TOOLDIR/hfst-summarize --verbose test 2> /dev/null | grep --after-context 1 "sigma symbols missing from transducer" | tail -1 > tmp; then
		    exit 1
		fi
		if grep "e, f" tmp > /dev/null; then
		    exit 1
		fi
	    done
	done

    fi
fi

done

rm test tmp