Skip to content

Commit 6212295

Browse files
SnipxiText-CI
authored andcommitted
OpenType: Fix skipping glyphs for mark attachment type-specific lookup flags
In case mark attachment class is not defined for a glyph whereas the mark attachment type is defined in the lookup flag, such glyph still needs to be skipped because only the marks matching the desired mark attachment type should be considered DEVSIX-4587
1 parent 9244d92 commit 6212295

File tree

5 files changed

+155
-5
lines changed

5 files changed

+155
-5
lines changed

io/src/main/java/com/itextpdf/io/font/otf/OpenTypeGdefTableReader.java

Lines changed: 14 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -49,10 +49,11 @@ This file is part of the iText (R) project.
4949

5050
public class OpenTypeGdefTableReader implements Serializable{
5151

52+
static final int FLAG_IGNORE_BASE = 2;
53+
static final int FLAG_IGNORE_LIGATURE = 4;
54+
static final int FLAG_IGNORE_MARK = 8;
55+
5256
private static final long serialVersionUID = 1564505797329158035L;
53-
private final int FLAG_IGNORE_BASE = 2;
54-
private final int FLAG_IGNORE_LIGATURE = 4;
55-
private final int FLAG_IGNORE_MARK = 8;
5657

5758
private final int tableLocation;
5859
private final RandomAccessFileOrArray rf;
@@ -97,8 +98,16 @@ public boolean isSkip(int glyph, int flag) {
9798
return true;
9899
}
99100
}
100-
if (markAttachmentClass != null && markAttachmentClass.getOtfClass(glyph) > 0 && (flag >> 8) > 0) {
101-
return markAttachmentClass.getOtfClass(glyph) != (flag >> 8);
101+
int markAttachmentType = (flag >> 8);
102+
// If MarkAttachmentType is non-zero, then mark attachment classes must be defined in the
103+
// Mark Attachment Class Definition Table in the GDEF table. When processing glyph sequences,
104+
// a lookup must ignore any mark glyphs that are not in the specified mark attachment class;
105+
// only marks of the specified type are processed.
106+
if (markAttachmentType != 0 && glyphClass != null) {
107+
int currentGlyphClass = glyphClass.getOtfClass(glyph);
108+
// Will be 0 in case the class is not defined for this particular glyph
109+
int glyphMarkAttachmentClass = markAttachmentClass != null ? markAttachmentClass.getOtfClass(glyph) : 0;
110+
return currentGlyphClass == OtfClass.GLYPH_MARK && glyphMarkAttachmentClass != markAttachmentType;
102111
}
103112
return false;
104113
}
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
1+
package com.itextpdf.io.font.otf;
2+
3+
import com.itextpdf.io.font.FontProgramFactory;
4+
import com.itextpdf.io.font.TrueTypeFont;
5+
import com.itextpdf.test.ExtendedITextTest;
6+
import com.itextpdf.test.annotations.type.IntegrationTest;
7+
8+
import java.io.IOException;
9+
import org.junit.Assert;
10+
import org.junit.Test;
11+
import org.junit.experimental.categories.Category;
12+
13+
@Category(IntegrationTest.class)
14+
public class OpenTypeGdefTableReaderTest extends ExtendedITextTest {
15+
private static final String RESOURCE_FOLDER = "./src/test/resources/com/itextpdf/io/font/otf/OpenTypeGdefTableReaderTest/";
16+
17+
@Test
18+
public void testLookupFlagWithMarkAttachmentTypeAndMarkGlyphWithoutMarkAttachmentClass() throws IOException {
19+
String fontName = "Padauk-Regular.ttf";
20+
TrueTypeFont fontProgram = (TrueTypeFont)FontProgramFactory.createFont(RESOURCE_FOLDER + fontName);
21+
OpenTypeGdefTableReader gdef = fontProgram.getGdefTable();
22+
int glyphCode = 207;
23+
Assert.assertEquals(OtfClass.GLYPH_MARK, gdef.getGlyphClassTable().getOtfClass(glyphCode));
24+
Assert.assertTrue(gdef.isSkip(glyphCode, (1 << 8) | OpenTypeGdefTableReader.FLAG_IGNORE_BASE));
25+
}
26+
27+
@Test
28+
public void testLookupFlagWithMarkAttachmentTypeAndMarkGlyphWithSameMarkAttachmentClass() throws IOException {
29+
String fontName = "Padauk-Regular.ttf";
30+
TrueTypeFont fontProgram = (TrueTypeFont)FontProgramFactory.createFont(RESOURCE_FOLDER + fontName);
31+
OpenTypeGdefTableReader gdef = fontProgram.getGdefTable();
32+
int glyphCode = 151;
33+
Assert.assertEquals(OtfClass.GLYPH_MARK, gdef.getGlyphClassTable().getOtfClass(glyphCode));
34+
Assert.assertFalse(gdef.isSkip(glyphCode, (1 << 8) | OpenTypeGdefTableReader.FLAG_IGNORE_BASE));
35+
}
36+
37+
@Test
38+
public void testLookupFlagWithMarkAttachmentTypeAndBaseGlyph() throws IOException {
39+
String fontName = "Padauk-Regular.ttf";
40+
TrueTypeFont fontProgram = (TrueTypeFont)FontProgramFactory.createFont(RESOURCE_FOLDER + fontName);
41+
OpenTypeGdefTableReader gdef = fontProgram.getGdefTable();
42+
int glyphCode = 165;
43+
Assert.assertEquals(OtfClass.GLYPH_BASE, gdef.getGlyphClassTable().getOtfClass(glyphCode));
44+
Assert.assertFalse(gdef.isSkip(glyphCode, (1 << 8)));
45+
}
46+
47+
}
Lines changed: 92 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,92 @@
1+
This Font Software is licensed under the SIL Open Font License,
2+
Version 1.1.
3+
4+
This license is copied below, and is also available with a FAQ at:
5+
http://scripts.sil.org/OFL
6+
7+
-----------------------------------------------------------
8+
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
9+
-----------------------------------------------------------
10+
11+
PREAMBLE
12+
The goals of the Open Font License (OFL) are to stimulate worldwide
13+
development of collaborative font projects, to support the font
14+
creation efforts of academic and linguistic communities, and to
15+
provide a free and open framework in which fonts may be shared and
16+
improved in partnership with others.
17+
18+
The OFL allows the licensed fonts to be used, studied, modified and
19+
redistributed freely as long as they are not sold by themselves. The
20+
fonts, including any derivative works, can be bundled, embedded,
21+
redistributed and/or sold with any software provided that any reserved
22+
names are not used by derivative works. The fonts and derivatives,
23+
however, cannot be released under any other type of license. The
24+
requirement for fonts to remain under this license does not apply to
25+
any document created using the fonts or their derivatives.
26+
27+
DEFINITIONS
28+
"Font Software" refers to the set of files released by the Copyright
29+
Holder(s) under this license and clearly marked as such. This may
30+
include source files, build scripts and documentation.
31+
32+
"Reserved Font Name" refers to any names specified as such after the
33+
copyright statement(s).
34+
35+
"Original Version" refers to the collection of Font Software
36+
components as distributed by the Copyright Holder(s).
37+
38+
"Modified Version" refers to any derivative made by adding to,
39+
deleting, or substituting -- in part or in whole -- any of the
40+
components of the Original Version, by changing formats or by porting
41+
the Font Software to a new environment.
42+
43+
"Author" refers to any designer, engineer, programmer, technical
44+
writer or other person who contributed to the Font Software.
45+
46+
PERMISSION & CONDITIONS
47+
Permission is hereby granted, free of charge, to any person obtaining
48+
a copy of the Font Software, to use, study, copy, merge, embed,
49+
modify, redistribute, and sell modified and unmodified copies of the
50+
Font Software, subject to the following conditions:
51+
52+
1) Neither the Font Software nor any of its individual components, in
53+
Original or Modified Versions, may be sold by itself.
54+
55+
2) Original or Modified Versions of the Font Software may be bundled,
56+
redistributed and/or sold with any software, provided that each copy
57+
contains the above copyright notice and this license. These can be
58+
included either as stand-alone text files, human-readable headers or
59+
in the appropriate machine-readable metadata fields within text or
60+
binary files as long as those fields can be easily viewed by the user.
61+
62+
3) No Modified Version of the Font Software may use the Reserved Font
63+
Name(s) unless explicit written permission is granted by the
64+
corresponding Copyright Holder. This restriction only applies to the
65+
primary font name as presented to the users.
66+
67+
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
68+
Software shall not be used to promote, endorse or advertise any
69+
Modified Version, except to acknowledge the contribution(s) of the
70+
Copyright Holder(s) and the Author(s) or with their explicit written
71+
permission.
72+
73+
5) The Font Software, modified or unmodified, in part or in whole,
74+
must be distributed entirely under this license, and must not be
75+
distributed under any other license. The requirement for fonts to
76+
remain under this license does not apply to any document created using
77+
the Font Software.
78+
79+
TERMINATION
80+
This license becomes null and void if any of the above conditions are
81+
not met.
82+
83+
DISCLAIMER
84+
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
85+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
86+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
87+
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
88+
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
89+
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
90+
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
91+
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
92+
OTHER DEALINGS IN THE FONT SOFTWARE.
Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
This software uses the following test resources under the following licenses:
2+
| Padauk-Regular.ttf | OFL-1.1 | LICENSE-OFL.txt |

0 commit comments

Comments
 (0)