Merge pull request #20542 from calixteman/fontfile3

Use the CFF program directly for CID fonts wrapped in OpenType FontFile3
This commit is contained in:
calixteman 2026-05-23 21:39:13 +02:00 committed by GitHub
commit ea18e73de2
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 42 additions and 15 deletions

View File

@ -4664,9 +4664,22 @@ class PartialEvaluator {
throw new FormatError("invalid font name");
}
let fontFile, subtype, length1, length2, length3;
let fontFile, fontFileN, subtype, length1, length2, length3;
try {
fontFile = descriptor.get("FontFile", "FontFile2", "FontFile3");
fontFile = descriptor.get("FontFile");
if (fontFile) {
fontFileN = 1;
} else {
fontFile = descriptor.get("FontFile2");
if (fontFile) {
fontFileN = 2;
} else {
fontFile = descriptor.get("FontFile3");
if (fontFile) {
fontFileN = 3;
}
}
}
if (fontFile) {
if (!(fontFile instanceof BaseStream)) {
@ -4776,6 +4789,7 @@ class PartialEvaluator {
name: fontName.name,
subtype,
file: fontFile,
fontFileN,
length1,
length2,
length3,

View File

@ -2682,10 +2682,23 @@ class Font {
}
const isTrueType = !tables["CFF "];
let parsedCff = null;
if (!isTrueType) {
try {
parsedCff = new CFFParser(
new Stream(tables["CFF "].data),
properties,
SEAC_ANALYSIS_ENABLED
).parse();
} catch {
warn("Failed to parse font " + properties.loadedName);
}
// OpenType font (skip composite fonts with non-default glyph mapping).
if (
(header.version === "OTTO" && !properties.composite) ||
(header.version === "OTTO" &&
(!properties.composite ||
(properties.fontFileN === 3 && parsedCff?.isCIDFont))) ||
!tables.head ||
!tables.hhea ||
!tables.maxp ||
@ -2725,19 +2738,11 @@ class Font {
}
let numGlyphsFromCFF;
if (!isTrueType) {
if (parsedCff) {
try {
// Trying to repair CFF file
const parser = new CFFParser(
new Stream(tables["CFF "].data),
properties,
SEAC_ANALYSIS_ENABLED
);
const cff = parser.parse();
cff.duplicateFirstGlyph();
const compiler = new CFFCompiler(cff);
tables["CFF "].data = compiler.compile();
numGlyphsFromCFF = cff.charStringCount;
parsedCff.duplicateFirstGlyph();
tables["CFF "].data = new CFFCompiler(parsedCff).compile();
numGlyphsFromCFF = parsedCff.charStringCount;
} catch {
warn("Failed to compile font " + properties.loadedName);
}

View File

@ -921,3 +921,4 @@
!operator_list_cycle.pdf
!knockout_groups_test.pdf
!issue18032.pdf
!Embedded_font.pdf

BIN
test/pdfs/Embedded_font.pdf Normal file

Binary file not shown.

View File

@ -14260,5 +14260,12 @@
"rounds": 1,
"type": "eq",
"about": "Non-isolated knockout group with a nested non-isolated subgroup over existing text."
},
{
"id": "Embedded_font.pdf",
"file": "pdfs/Embedded_font.pdf",
"md5": "b68dd5a3e6833d1af94e295fe1d60285",
"rounds": 1,
"type": "eq"
}
]