If you think a check is flawed or have an idea for a check, please file an issue at https://github.com/fonttools/fontbakery/issues and remember to include a pointer to the repo and branch you're checking.
Summary
💥 ERROR | ☠ FATAL | 🔥 FAIL | ⚠️ WARN | ⏩ SKIP | ℹ️ INFO | ✅ PASS |
---|---|---|---|---|---|---|
0 | 0 | 2 | 7 | 117 | 6 | 119 |
0% | 0% | 1% | 3% | 47% | 2% | 47% |
Meaning of check results:
- 💥 An ERROR is something wrong with FontBakery itself, possibly a bug.
- ☠ A FATAL is an extremely severe issue that must be addressed immediately.
- 🔥 A FAIL is a problem with the font that must be fixed.
- ⚠️ A WARN is something that you should consider addressing.
- ℹ️ An INFO result simply prints something useful. Typically stats.
- ✅ A PASS means the font looks good for the given checking routine.
- ⏩ And a SKIP happens when the check does not apply to the given font.
If you get ERRORs, please help us improve the tool by reporting them at our issue tracker.
(but other kinds of bug reports and/or feature requests are also always welcome, of course!)
FontBakery version: 0.12.10
Universal Profile Checks
🔥⚠️⏩⏩⏩⏩⏩⏩⏩ℹ️Check accent of Lcaron, dcaron, lcaron, tcaron
Check that glyph for U+0675 ARABIC LETTER HIGH HAMZA is not a mark.
Check that Arabic spacing symbols U+FBB2–FBC1 aren't classified as marks.
Ensure the font supports case swapping for all its glyphs.
Does the font contain chws and vchw features?
Check if each glyph has the recommended amount of contours.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
This check inspects the glyph outlines and detects the total number of contours in each of them. The expected values are infered from the typical ammounts of contours observed in a large collection of reference font families. The divergences listed below may simply indicate a significantly different design on some of your glyphs. On the other hand, some of these may flag actual bugs in the font such as glyphs mapped to an incorrect codepoint. Please consider reviewing the design and codepoint assignment of these to make sure they are correct.
The following glyphs do not have the recommended number of contours:
[code: contour-count]- Glyph name: aogonek Contours detected: 3 Expected: 2 - Glyph name: uogonek Contours detected: 2 Expected: 1 - Glyph name: aogonek Contours detected: 3 Expected: 2 - Glyph name: uogonek Contours detected: 2 Expected: 1
Checking all files are in the same directory.
Each font in a family must have the same set of vertical metrics values.
Checking OS/2 usWinAscent & usWinDescent.
Do we have the latest version of FontBakery installed?
Ensure that the font can be rasterized by FreeType.
Ensure no GPOS7 lookups are present.
EXPERIMENTAL CHECK - Since 2024/Jun/10
Ensure 'smcp' (small caps) lookups are defined before ligature lookups in the 'GSUB' table.
Detect any interpolation issues in the font.
Check that legacy accents aren't used in composite glyphs.
Checking Vertical Metric Linegaps.
Font contains '.notdef' as its first glyph?
Check math signs have the same width.
Name table records must not have trailing spaces.
Checking OS/2 Metrics match hhea Metrics.
Checking with ots-sanitize.
Font contains all required tables?
Ensure indic fonts have the Indian Rupee Sign glyph.
Font has the proper sfntVersion value?
Does the font contain a soft hyphen?
Checking STAT table entries in static fonts.
Check correctness of STAT table strings
EXPERIMENTAL CHECK - Since 2024/Jun/04
Check tabular widths don't have kerning.
Ensure component transforms do not perform scaling or rotation.
Checking with fontTools.ttx
EXPERIMENTAL CHECK - Since 2024/Jul/17
Checking that the typoAscender exceeds the yMax of the /Agrave.
🔥 NotoSansUgaritic-Regular.ttf
-
🔥 FAIL
OS/2.sTypoAscender value should be greater than 944, but got 743 instead
[code: typoAscender]
Font contains unique glyph names?
Check font contains no unreachable glyphs
Are there unwanted tables?
Glyph names are all valid?
Font has **proper** whitespace glyph names?
Font contains glyphs for whitespace characters?
Whitespace glyphs have ink?
Space and non-breaking space have the same width?
Article Checks
⚠️Validate size, and resolution of article images, and ensure article page has minimum length and includes visual assets.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
Family metadata at fonts/NotoSansUgaritic/googlefonts/ttf does not have an article.
[code: lacks-article]
Metadata Checks
⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩Does METADATA.pb copyright field contain broken links?
METADATA.pb: Font styles are named canonically?
METADATA.pb: Check that font weight has a canonical value.
Check samples can be rendered.
Ensure METADATA.pb category field is valid.
Check if category on METADATA.pb matches what can be inferred from the family name.
Validate VF axes match the ones declared on METADATA.pb.
METADATA.pb: Check URL on copyright string is the same as in repository_url field.
METADATA.pb: Copyright notice is the same in all fonts?
EXPERIMENTAL CHECK - Since 2024/May/22
Validate 'date_added' field on METADATA.pb.
METADATA.pb: Designers are listed correctly on the Google Fonts catalog?
Multiple values in font designer field in METADATA.pb must be separated by commas.
At least one designer is declared in METADATA.pb
Ensure METADATA.pb does not use escaped strings.
Check font family directory name.
Check that METADATA.pb family values are all the same.
METADATA.pb: Font filenames match font.filename entries?
Validate METADATA.pb axes values are within gf_axisregistry bounds.
Validate METADATA.pb axes tags are defined in gf_axisregistry.
Ensure there is a regular style defined in METADATA.pb.
Check METADATA.pb includes production subsets.
Check METADATA.pb file only contains a single CJK subset.
METADATA.pb license is "APACHE2", "UFL" or "OFL"?
METADATA.pb font.filename and font.post_script_name fields have equivalent values?
METADATA.pb font.full_name and font.post_script_name fields have equivalent values ?
METADATA.pb: Check font name is the same as family name.
METADATA.pb weight matches postScriptName for static fonts.
METADATA.pb should contain at least "menu" and "latin" subsets.
METADATA.pb: Validate family.minisite_url field.
METADATA.pb font.name and font.full_name fields match the values declared on the name table?
METADATA.pb font.name value should be same as the family name declared on the name table.
Checks METADATA.pb font.post_script_name matches postscript name declared on the name table.
Check METADATA.pb font weights are correct.
Check METADATA.pb parse correctly.
METADATA.pb: Check for primary_script
METADATA.pb: Regular should be 400.
Copyright notice on METADATA.pb should not contain 'Reserved Font Name'.
METADATA.pb subsets should be alphabetically ordered.
Ensure METADATA.pb lists all font binaries.
METADATA.pb: check if fonts field only has unique "full_name" values.
METADATA.pb: check if fonts field only contains unique style:weight pairs.
Check for codepoints not covered by METADATA subsets.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
The following codepoints supported by the font are not covered by any subsets defined in the font's metadata file, and will never be served. You can solve this by either manually adding additional subset declarations to METADATA.pb, or by editing the glyphset definitions.
- U+02D8 BREVE: try adding one of: canadian-aboriginal, yi
- U+02D9 DOT ABOVE: try adding one of: canadian-aboriginal, yi
- U+02DB OGONEK: try adding one of: canadian-aboriginal, yi
- U+0302 COMBINING CIRCUMFLEX ACCENT: try adding one of: tifinagh, math, coptic, cherokee
- U+0306 COMBINING BREVE: try adding one of: old-permic, tifinagh
- U+0307 COMBINING DOT ABOVE: try adding one of: tai-le, hebrew, tifinagh, math, old-permic, duployan, coptic, canadian-aboriginal, malayalam, todhri, syriac
- U+030A COMBINING RING ABOVE: try adding one of: syriac, duployan
- U+030B COMBINING DOUBLE ACUTE ACCENT: try adding one of: osage, cherokee
- U+030C COMBINING CARON: try adding one of: tai-le, cherokee
- U+0326 COMBINING COMMA BELOW: try adding math
- U+0327 COMBINING CEDILLA: try adding math
- U+0328 COMBINING OGONEK: not included in any glyphset definition
Or you can add the above codepoints to one of the subsets supported by the font:
[code: unreachable-subsetting]latin
,latin-ext
,ugaritic
Check for METADATA subsets with zero support.
METADATA.pb font.filename field contains font name in right format?
METADATA.pb font.full_name field contains font name in right format?
Check name ID 25 to end with "Italic" for Italic VFs.
METADATA.pb font.post_script_name field contains font name in right format?
Description Checks
🔥⏩⏩⏩⏩⏩⏩⏩⏩Does DESCRIPTION file contain broken links?
DESCRIPTION.en_us.html should end in a linebreak.
On a family update, the DESCRIPTION.en_us.html file should ideally also be updated.
Does DESCRIPTION file contain a upstream Git repo URL?
Check the description doesn't contain unsupported html elements
DESCRIPTION.en_us.html must have more than 200 bytes.
Check for presence of an ARTICLE.en_us.html file
🔥 NotoSansUgaritic-Regular.ttf
-
🔥 FAIL
This is a Noto font but it lacks an ARTICLE.en_us.html file.
[code: missing-article] -
🔥 FAIL
This is a Noto font but it lacks a DESCRIPTION.en_us.html file.
[code: missing-description]
URLs on DESCRIPTION file must not display http(s) prefix.
Is this a proper HTML snippet?
Shaping Checks
⚠️⚠️⏩⏩⏩Check that texts shape as per expectation
Check that no forbidden glyphs are found while shaping
Check that no collisions are found while shaping
Ensure dotted circle glyph is present and can attach marks.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
No dotted circle glyph present
[code: missing-dotted-circle]
Ensure soft_dotted characters lose their dot when combined with marks that replace the dot.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
The dot of soft dotted characters used in orthographies must disappear in the following strings: į̀ į́ į̂ į̃ į̄ į̌
The dot of soft dotted characters should disappear in other cases, for example: į̆ į̇ į̈ į̊ į̋ į̦̀ į̦́ į̦̂ į̦̃ į̦̄ į̦̆ į̦̇ į̦̈ į̦̊ į̦̋ į̦̌ į̧̀ į̧́ į̧̂ į̧̃
Your font fully covers the following languages that require the soft-dotted feature: Lithuanian (Latn, 2,357,094 speakers), Dutch (Latn, 31,709,104 speakers).
Your font does not cover the following languages that require the soft-dotted feature: Mfumte (Latn, 79,000 speakers), Igbo (Latn, 27,823,640 speakers), Cicipu (Latn, 44,000 speakers), Vute (Latn, 21,000 speakers), Kpelle, Guinea (Latn, 622,000 speakers), Ejagham (Latn, 120,000 speakers), Dan (Latn, 1,099,244 speakers), Mundani (Latn, 34,000 speakers), Han (Latn, 6 speakers), Nzakara (Latn, 50,000 speakers), Ijo, Southeast (Latn, 2,471,000 speakers), Nateni (Latn, 100,000 speakers), Lugbara (Latn, 2,200,000 speakers), Ma’di (Latn, 584,000 speakers), Koonzime (Latn, 40,000 speakers), Heiltsuk (Latn, 300 speakers), Ukrainian (Cyrl, 29,273,587 speakers), Kaska (Latn, 125 speakers), Teke-Ebo (Latn, 260,000 speakers), Avokaya (Latn, 100,000 speakers), Bete-Bendi (Latn, 100,000 speakers), Bafut (Latn, 158,146 speakers), Navajo (Latn, 166,319 speakers), Zapotec (Latn, 490,000 speakers), Aghem (Latn, 38,843 speakers), Kom (Latn, 360,685 speakers), Dii (Latn, 71,000 speakers), South Central Banda (Latn, 244,000 speakers), Yala (Latn, 200,000 speakers), Ngbaka (Latn, 1,020,000 speakers), Belarusian (Cyrl, 10,064,517 speakers), Sar (Latn, 500,000 speakers), Ekpeye (Latn, 226,000 speakers), Mango (Latn, 77,000 speakers), Makaa (Latn, 221,000 speakers), Ebira (Latn, 2,200,000 speakers), Gulay (Latn, 250,478 speakers), Southern Kisi (Latn, 360,000 speakers), Basaa (Latn, 332,940 speakers), Fur (Latn, 1,230,163 speakers).
[code: soft-dotted]
Outline Checks
⚠️Are there any misaligned on-curve points?
Are any segments inordinately short?
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
The following glyphs have segments which seem very short:
[code: found-short-segments]* M (U+004D) contains a short segment L<<177.0,626.0>--<173.0,626.0>> * M (U+004D) contains a short segment L<<450.0,129.0>--<454.0,129.0>> * N (U+004E) contains a short segment L<<176.0,593.0>--<172.0,593.0>> * N (U+004E) contains a short segment L<<582.0,123.0>--<586.0,123.0>> * Nacute (U+0143) contains a short segment L<<176.0,593.0>--<172.0,593.0>> * Nacute (U+0143) contains a short segment L<<582.0,123.0>--<586.0,123.0>> * Ncaron (U+0147) contains a short segment L<<176.0,593.0>--<172.0,593.0>> * Ncaron (U+0147) contains a short segment L<<582.0,123.0>--<586.0,123.0>> * uni0145 (U+0145) contains a short segment L<<176.0,593.0>--<172.0,593.0>> * uni0145 (U+0145) contains a short segment L<<582.0,123.0>--<586.0,123.0>> * Ntilde (U+00D1) contains a short segment L<<176.0,593.0>--<172.0,593.0>> * Ntilde (U+00D1) contains a short segment L<<582.0,123.0>--<586.0,123.0>> * Q (U+0051) contains a short segment B<<416.0,-9.0>-<410.0,-9.0>-<403.5,-9.5>> * Q (U+0051) contains a short segment B<<403.5,-9.5>-<397.0,-10.0>-<391.0,-10.0>> * Uogonek (U+0172) contains a short segment B<<539.5,-158.5>-<551.0,-156.0>-<559.0,-155.0>> * W (U+0057) contains a short segment B<<468.0,577.5>-<463.0,600.0>-<461.0,609.0>> * Wacute (U+1E82) contains a short segment B<<468.0,577.5>-<463.0,600.0>-<461.0,609.0>> * Wcircumflex (U+0174) contains a short segment B<<468.0,577.5>-<463.0,600.0>-<461.0,609.0>> * Wdieresis (U+1E84) contains a short segment B<<468.0,577.5>-<463.0,600.0>-<461.0,609.0>> * Wgrave (U+1E80) contains a short segment B<<468.0,577.5>-<463.0,600.0>-<461.0,609.0>> * a (U+0061) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * aacute (U+00E1) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * abreve (U+0103) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * acircumflex (U+00E2) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * adieresis (U+00E4) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * agrave (U+00E0) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * amacron (U+0101) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * aogonek (U+0105) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * aring (U+00E5) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * at (U+0040) contains a short segment B<<613.0,293.0>-<612.0,275.0>-<612.0,267.5>> * at (U+0040) contains a short segment B<<612.0,267.5>-<612.0,260.0>-<612.0,257.0>> * atilde (U+00E3) contains a short segment L<<399.0,76.0>--<395.0,76.0>> * d (U+0064) contains a short segment L<<446.0,72.0>--<442.0,72.0>> * dcaron (U+010F) contains a short segment L<<446.0,72.0>--<442.0,72.0>> * dcroat (U+0111) contains a short segment L<<445.0,72.0>--<441.0,72.0>> * Euro (U+20AC) contains a short segment B<<184.0,390.0>-<183.0,380.0>-<183.0,371.0>> * Euro (U+20AC) contains a short segment B<<183.0,371.0>-<183.0,362.0>-<183.0,352.0>> * Euro (U+20AC) contains a short segment B<<183.0,352.0>-<183.0,343.0>-<183.0,332.5>> * Euro (U+20AC) contains a short segment B<<183.0,332.5>-<183.0,322.0>-<184.0,311.0>> * Euro (U+20AC) contains a short segment B<<95.0,311.0>-<94.0,323.0>-<94.0,331.0>> * Euro (U+20AC) contains a short segment B<<94.0,331.0>-<94.0,339.0>-<94.0,352.0>> * Euro (U+20AC) contains a short segment B<<94.0,352.0>-<94.0,363.0>-<94.5,373.5>> * Euro (U+20AC) contains a short segment B<<94.5,373.5>-<95.0,384.0>-<95.0,390.0>> * germandbls (U+00DF) contains a short segment B<<382.0,412.0>-<382.0,399.0>-<388.5,388.0>> * m (U+006D) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * n (U+006E) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * nacute (U+0144) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * ncaron (U+0148) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * uni0146 (U+0146) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * ntilde (U+00F1) contains a short segment L<<169.0,463.0>--<174.0,463.0>> * p (U+0070) contains a short segment L<<169.0,463.0>--<173.0,463.0>> * r (U+0072) contains a short segment L<<167.0,438.0>--<171.0,438.0>> * racute (U+0155) contains a short segment L<<167.0,438.0>--<171.0,438.0>> * rcaron (U+0159) contains a short segment L<<167.0,438.0>--<171.0,438.0>> * trademark (U+2122) contains a short segment L<<386.0,633.0>--<382.0,633.0>> * two (U+0032) contains a short segment L<<159.0,84.0>--<159.0,80.0>> * u (U+0075) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * uacute (U+00FA) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * ucircumflex (U+00FB) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * udieresis (U+00FC) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * ugrave (U+00F9) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * uhungarumlaut (U+0171) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * umacron (U+016B) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * uogonek (U+0173) contains a short segment L<<448.0,71.0>--<444.0,71.0>> * uring (U+016F) contains a short segment L<<448.0,71.0>--<444.0,71.0>>
Do any segments have colinear vectors?
Do outlines contain any jaggy segments?
Do outlines contain any semi-vertical or semi-horizontal lines?
Check the direction of the outermost contour in each glyph
Font File Checks
⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩ℹ️ℹ️ℹ️ℹ️Are there unwanted Apple tables?
Checking file is named canonically.
Does the font contain less than 150 CJK characters?
Check font follows the Google Fonts CJK vertical metric schema
Check if the vertical metrics of a CJK family are similar to the same family hosted on Google Fonts.
Color layers should have a minimum brightness
Check font has the expected color font tables.
Put an empty glyph on GID 1 right after the .notdef glyph for COLRv0 fonts.
EPAR table present in font?
Ensure files are not too large.
Copyright notices match canonical pattern in fonts
Familyname must be unique according to namecheck.fontdata.com
Check font names are correct
Checking OS/2 fsType does not impose restrictions.
Check variable font instances
All name entries referenced by fvar instances exist on the name table?
Is the Grid-fitting and Scan-conversion Procedure ('gasp') table set to optimize rendering?
Validate defaults on fvar table match registered fallback names in GFAxisRegistry.
Check glyphs do not have components which are themselves components.
Check Google Fonts glyph coverage.
Font has ttfautohint params?
Show hinting filesize impact.
PPEM must be an integer on hinted fonts.
Is there kerning info for non-ligated sequences?
Are there caret positions declared for every ligature?
Ensure variable fonts include an avar table.
Ensure fonts have ScriptLangTags declared on the 'meta' table.
⚠️ NotoSansUgaritic-Regular.ttf
-
⚠️ WARN
This font file does not have a 'meta' table.
[code: lacks-meta-table]