File: test_fontdame.py

package info (click to toggle)
python-fontfeatures 1.9.0%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,096 kB
  • sloc: python: 9,112; makefile: 22
file content (41 lines) | stat: -rw-r--r-- 1,211 bytes parent folder | download
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
from fontFeatures.fontDameLib import unparse
import re


def assertSufficientlyEqual(s1, s2):
    def alltrim(a):
        a = re.sub("lookupflag 0;", "", a)
        a = re.sub("#.*", "", a)
        a = re.sub("\\s+", " ", a)
        a = re.sub("table GDEF.*GDEF;", "", a)
        a = re.sub(" ; ", " ", a)
        return a.strip()

    assert alltrim(s1) == alltrim(s2)


def test_noto_sharada():
    ff = unparse("tests/data/Noto Sans Sharada GSUB.txt")
    assert "abvs" in ff.features
    assert "akhn" in ff.features
    assert "blws" in ff.features
    assert len(ff.routines) == 12
    r1 = ff.features["abvs"][0].routine.asFea()
    assertSufficientlyEqual(
        r1,
        """
    sub Jihvamuliya by Jihvamuliya.ns;
    sub Upadhmaniya by Upadhmaniya.ns;
""",
    )
    r2 = ff.features["blws"][1].routine.asFea()
    assertSufficientlyEqual(
        r2,
        """
sub [KKa NgKa RKa RGa JNya TtKa NnSha Sa]' [U UU]' lookup lookup_9;
sub [KKa NgKa RKa RGa JNya TtKa NnSha Sa]' [UU.alt U.alt]' lookup lookup_9;
sub [KTa RTa U UU]' [U UU]' lookup lookup_11;
sub [KTa RTa U UU]' [UU.alt U.alt]' lookup lookup_11;
sub [KKa NgKa RKa RGa JNya TtKa NnSha Sa]' [KTa RTa U UU]' lookup lookup_10;
""",
    )