[voltLib] Add coverage, change group and enum
This commit is contained in:
parent
8c0a35331e
commit
c26e3228ce
@ -17,12 +17,10 @@ class GlyphDefinition(ast.Statement):
|
||||
self.components = components
|
||||
|
||||
class GroupDefinition(ast.Statement):
|
||||
def __init__(self, location, name, glyphs, groups, ranges):
|
||||
def __init__(self, location, name, enum):
|
||||
ast.Statement.__init__(self,location)
|
||||
self.name = name
|
||||
self.enum = {"glyphs": glyphs,
|
||||
"groups": groups,
|
||||
"ranges": ranges}
|
||||
self.enum = enum
|
||||
|
||||
class ScriptDefinition(ast.Statement):
|
||||
def __init__(self, location, name, tag, langs):
|
||||
|
@ -83,7 +83,7 @@ class Parser(object):
|
||||
if self.groups_.resolve(name) is not None:
|
||||
raise VoltLibError('Glyph group "%s" already defined' % name,
|
||||
location)
|
||||
def_group = ast.GroupDefinition(location, name, **enum)
|
||||
def_group = ast.GroupDefinition(location, name, enum)
|
||||
self.groups_.define(name, def_group)
|
||||
return def_group
|
||||
|
||||
@ -149,20 +149,24 @@ class Parser(object):
|
||||
return enum
|
||||
|
||||
def parse_coverage_(self):
|
||||
coverage = {'glyphs': [], 'groups': [], 'ranges': []}
|
||||
coverage = []
|
||||
while self.next_token_ in ("GLYPH", "GROUP", "RANGE"):
|
||||
if self.next_token_ == "GLYPH":
|
||||
self.expect_keyword_("GLYPH")
|
||||
name = self.expect_string_()
|
||||
coverage['glyphs'].append(name)
|
||||
coverage.append(name)
|
||||
elif self.next_token_ == "GROUP":
|
||||
self.expect_keyword_("GROUP")
|
||||
name = self.expect_string_()
|
||||
coverage['groups'].append(name)
|
||||
group = self.groups_.resolve(name)
|
||||
if group is None:
|
||||
raise VoltLibError('Glyph group "%s" is not defined' % name,
|
||||
location)
|
||||
coverage.extend(group.enum)
|
||||
elif self.next_token_ == "RANGE":
|
||||
self.expect_keyword_("RANGE")
|
||||
start, end = self.expect_string_(), self.expect_string_()
|
||||
coverage['ranges'].append((start, end))
|
||||
coverage.append((start, end))
|
||||
return coverage
|
||||
|
||||
def is_cur_keyword_(self, k):
|
||||
|
@ -60,21 +60,24 @@ class ParserTest(unittest.TestCase):
|
||||
).statements
|
||||
self.assertEqual((def_group.name, def_group.enum),
|
||||
("KERN_lc_a_2ND",
|
||||
{"glyphs": ["a", "aacute", "abreve", "acircumflex",
|
||||
"adieresis", "ae", "agrave", "amacron",
|
||||
"aogonek", "aring", "atilde"],
|
||||
"groups": [],
|
||||
"ranges": []}))
|
||||
[def_group] = self.parse(
|
||||
["a", "aacute", "abreve", "acircumflex", "adieresis",
|
||||
"ae", "agrave", "amacron", "aogonek", "aring",
|
||||
"atilde"]))
|
||||
[def_group1, def_group2] = self.parse(
|
||||
'DEF_GROUP "aaccented"\n'
|
||||
'ENUM GLYPH "aacute" GLYPH "abreve" GLYPH "acircumflex" '
|
||||
'GLYPH "adieresis" GLYPH "ae" GLYPH "agrave" GLYPH "amacron" '
|
||||
'GLYPH "aogonek" GLYPH "aring" GLYPH "atilde" END_ENUM\n'
|
||||
'END_GROUP\n'
|
||||
'DEF_GROUP "KERN_lc_a_2ND"\n'
|
||||
'ENUM GLYPH "a" GROUP "aaccented" END_ENUM\n'
|
||||
'END_GROUP'
|
||||
).statements
|
||||
self.assertEqual((def_group.name, def_group.enum),
|
||||
self.assertEqual((def_group2.name, def_group2.enum),
|
||||
("KERN_lc_a_2ND",
|
||||
{"glyphs": ["a"],
|
||||
"groups": ["aaccented"],
|
||||
"ranges": []}))
|
||||
["a", "aacute", "abreve", "acircumflex", "adieresis",
|
||||
"ae", "agrave", "amacron", "aogonek", "aring",
|
||||
"atilde"]))
|
||||
[def_group] = self.parse(
|
||||
'DEF_GROUP "KERN_lc_a_2ND"\n'
|
||||
'ENUM RANGE "a" "atilde" GLYPH "b" RANGE "c" "cdotaccent" '
|
||||
@ -83,10 +86,7 @@ class ParserTest(unittest.TestCase):
|
||||
).statements
|
||||
self.assertEqual((def_group.name, def_group.enum),
|
||||
("KERN_lc_a_2ND",
|
||||
{"glyphs": ["b"],
|
||||
"groups": [],
|
||||
"ranges": [("a", "atilde"),
|
||||
("c", "cdotaccent")]}))
|
||||
[("a", "atilde"), "b", ("c", "cdotaccent")]))
|
||||
|
||||
def test_group_duplicate(self):
|
||||
self.assertRaisesRegex(
|
||||
|
Loading…
x
Reference in New Issue
Block a user