Font Bakery Logo image/svg+xml Font Bakery Logo Robert Martinez font build service https://github.com/xen/fontbakery
Fontbakery Technical Report

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 3 15 106 6 106
0% 0% 1% 6% 45% 3% 45%

Meaning of check results:

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.13.1

OpenType Specification Checks

⚠️⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩

Check mark characters are in GDEF mark glyph class.

Check ID: <FontBakeryCheck:opentype/gdef_mark_chars>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following mark characters could be in the GDEF mark glyph class: u1193E (U+1193E)

    [code: mark-chars]

Check GDEF mark glyph class doesn't have characters that are not marks.

Check ID: <FontBakeryCheck:opentype/gdef_non_mark_chars>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following non-mark characters should not be in the GDEF mark glyph class: U+1193F

    [code: non-mark-chars]

Universal Profile Checks

🔥🔥⚠️⚠️⚠️⚠️⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩ℹ️ℹ️

EXPERIMENTAL CHECK - Since 2024/12/28
Check base characters have non-zero advance width.

Check ID: <FontBakeryCheck:base_has_width>
🔥 NotoSerifDivesAkuru-Regular.ttf
  • 🔥 FAIL

    The following glyphs had zero advance width: - u1193F (U+1193F)

    [code: zero-width-bases]

Check if uppercase glyphs are vertically centered.

Check ID: <FontBakeryCheck:caps_vertically_centered>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    Uppercase glyphs are not vertically centered in the em box.

    [code: vertical-metrics-not-centered]

Check if each glyph has the recommended amount of contours.

Check ID: <FontBakeryCheck:contour_count>
⚠️ NotoSerifDivesAkuru-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:

    - Glyph name: aogonek	Contours detected: 3	Expected: 2
    
    - Glyph name: Uogonek	Contours detected: 2	Expected: 1
    
    - Glyph name: uogonek	Contours detected: 2	Expected: 1
    
    - Glyph name: uni25CC	Contours detected: 8	Expected: 16 or 12
    
    - Glyph name: Uogonek	Contours detected: 2	Expected: 1
    
    - Glyph name: aogonek	Contours detected: 3	Expected: 2
    
    - Glyph name: uni25CC	Contours detected: 8	Expected: 16 or 12
    
    - Glyph name: uogonek	Contours detected: 2	Expected: 1
    
    [code: contour-count]

Do we have the latest version of FontBakery installed?

Check ID: <FontBakeryCheck:fontbakery_version>
🔥 NotoSerifDivesAkuru-Regular.ttf
  • 🔥 FAIL

    Current FontBakery version is 0.13.1, while a newer 0.13.2 is already available. Please upgrade it with 'pip install -U fontbakery'

    [code: outdated-fontbakery]

Check math signs have the same width.

Check ID: <FontBakeryCheck:math_signs_width>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The most common width is 559 among a set of 6 math glyphs. The following math glyphs have a different width, though:

    Width = 579: minus

    [code: width-outliers]

Check font contains no unreachable glyphs

Check ID: <FontBakeryCheck:unreachable_glyphs>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following glyphs could not be reached by codepoint or substitution rules:

    - nullmark
    
    [code: unreachable-glyphs]

Glyph names are all valid?

Check ID: <FontBakeryCheck:valid_glyphnames>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following glyph names may be too long for some legacy systems which may expect a maximum 31-characters length limit: dda_medya_iVoweldivesakuru.undera, ha_medra_aaVoweldivesakuru.undera, ha_medya_iVoweldivesakuru.undera, ka_medra_uVoweldivesakuru.undera, ka_medya_iVoweldivesakuru.undera, lla_medya_iVoweldivesakuru.undera, ma_medya_eVoweldivesakuru.undera, ma_medya_iVoweldivesakuru.undera, ma_medya_iiVoweldivesakuru.undera, na_medra_aaVoweldivesakuru.undera, na_medya_iVoweldivesakuru.undera, sa_medra_iiVoweldivesakuru.undera, ta_medra_uVoweldivesakuru.undera, ta_medya_halantadivesakuru.undera, ta_medya_iVoweldivesakuru.undera, ta_ta_medra_iVoweldivesakuru.undera, ta_tha_medra_iVoweldivesakuru.undera, va_medya_iVoweldivesakuru.undera, va_medya_uVoweldivesakuru.undera and ya_medya_iVoweldivesakuru.undera

    [code: legacy-long-names]

Article Checks

⚠️

Validate size, and resolution of article images, and ensure article page has minimum length and includes visual assets.

Check ID: <FontBakeryCheck:googlefonts/article/images>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    Family metadata at fonts/NotoSerifDivesAkuru/googlefonts/ttf does not have an article.

    [code: lacks-article]

Metadata Checks

⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩

Check for codepoints not covered by METADATA subsets.

Check ID: <FontBakeryCheck:googlefonts/metadata/unreachable_subsetting>
⚠️ NotoSerifDivesAkuru-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: coptic, cherokee, math, tifinagh
    • U+0306 COMBINING BREVE: try adding one of: old-permic, tifinagh
    • U+0307 COMBINING DOT ABOVE: try adding one of: canadian-aboriginal, tai-le, coptic, syriac, old-permic, tifinagh, todhri, duployan, malayalam, hebrew, math
    • U+030A COMBINING RING ABOVE: try adding one of: syriac, duployan
    • U+030B COMBINING DOUBLE ACUTE ACCENT: try adding one of: cherokee, osage
    • U+030C COMBINING CARON: try adding one of: cherokee, tai-le
    • 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
    • U+25CC DOTTED CIRCLE: try adding one of: buhid, cham, marchen, masaram-gondi, limbu, kaithi, kharoshthi, tibetan, zanabazar-square, tagbanwa, mahajani, myanmar, buginese, wancho, gujarati, oriya, lepcha, siddham, yi, saurashtra, mongolian, kannada, grantha, nko, tai-tham, music, syloti-nagri, takri, telugu, tamil, tagalog, brahmi, miao, gurmukhi, batak, bhaiksuki, hanifi-rohingya, hanunoo, duployan, rejang, elbasan, sundanese, javanese, thai, khojki, bassa-vah, bengali, gunjala-gondi, mandaic, osage, warang-citi, sinhala, sharada, dogra, balinese, thaana, khudawadi, caucasian-albanian, ahom, tai-le, lao, syriac, meetei-mayek, tai-viet, chakma, khmer, old-permic, sogdian, phags-pa, manichaean, tifinagh, symbols, kayah-li, math, new-tai-lue, canadian-aboriginal, tirhuta, soyombo, hebrew, newa, pahawh-hmong, psalter-pahlavi, modi, coptic, devanagari, armenian, adlam, malayalam, mende-kikakui
    • U+11939 : not included in any glyphset definition

    Or you can add the above codepoints to one of the subsets supported by the font: dives-akuru, latin, latin-ext

    [code: unreachable-subsetting]

Glyphset Checks

⚠️

Shapes languages in all GF glyphsets.

Check ID: <FontBakeryCheck:googlefonts/glyphsets/shape_languages>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    GF_TransLatin_Arabic glyphset:

    WARN messages Languages
    Some auxiliary glyphs were missing: Ŀ, ŀ ca_Latn (Catalan)
    Some auxiliary glyphs were missing: ſ de_Latn (German) and fr_Latn (French)
    Some auxiliary glyphs were missing: Ŋ, ŋ, Ŧ, ŧ, Ʒ, Ǥ, ǥ, Ǯ, ǯ, ʒ fi_Latn (Finnish)
    Some auxiliary glyphs were missing: Ŋ, ŋ, Ŧ, ŧ nb_Latn (Norwegian Bokmål)
    Some auxiliary glyphs were missing: IJ, ij nl_Latn (Dutch)
    [code: warning-language-shaping]

Description Checks

🔥⏩⏩⏩⏩⏩⏩⏩⏩

Check for presence of an ARTICLE.en_us.html file

Check ID: <FontBakeryCheck:googlefonts/description/has_article>
🔥 NotoSerifDivesAkuru-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]

Shaping Checks

⚠️⏩⏩⏩

Ensure soft_dotted characters lose their dot when combined with marks that replace the dot.

Check ID: <FontBakeryCheck:soft_dotted>
⚠️ NotoSerifDivesAkuru-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), Northern Tutchone (Latn, 85 speakers), Southern Tutchone (Latn, 65 speakers).

    Your font does not cover the following languages that require the soft-dotted feature: Longto (Latn, 5,000 speakers), Dan (Latn, 1,099,244 speakers), Kpelle, Guinea (Latn, 622,000 speakers), Southern Kisi (Latn, 360,000 speakers), Vute (Latn, 21,000 speakers), Heiltsuk (Latn, 300 speakers), Ukrainian (Cyrl, 29,273,587 speakers), Mango (Latn, 77,000 speakers), Bafut (Latn, 158,146 speakers), Han (Latn, 6 speakers), Bete-Bendi (Latn, 100,000 speakers), Ma’di (Latn, 584,000 speakers), Navajo (Latn, 166,319 speakers), Ikwere (Latn, 717,000 speakers), Teke-Ebo (Latn, 260,000 speakers), Abua (Latn, 25,000 speakers), Belarusian (Cyrl, 10,064,517 speakers), Basaa (Latn, 332,940 speakers), Makaa (Latn, 221,000 speakers), Ekpeye (Latn, 226,000 speakers), Ebira (Latn, 2,200,000 speakers), Gulay (Latn, 250,478 speakers), Ngbaka (Latn, 1,020,000 speakers), Dii (Latn, 71,000 speakers), Mfumte (Latn, 79,000 speakers), South Central Banda (Latn, 244,000 speakers), Aghem (Latn, 38,843 speakers), Yala (Latn, 200,000 speakers), Mundani (Latn, 34,000 speakers), Cicipu (Latn, 44,000 speakers), Ejagham (Latn, 120,000 speakers), Sar (Latn, 500,000 speakers), Zapotec (Latn, 490,000 speakers), Avokaya (Latn, 100,000 speakers), Nzakara (Latn, 50,000 speakers), Kom (Latn, 360,685 speakers), Kaska (Latn, 125 speakers), Koonzime (Latn, 40,000 speakers), Keliko (Latn, 63,000 speakers), Fur (Latn, 1,230,163 speakers), Western Krahn (Latn, 97,800 speakers), Ijo, Southeast (Latn, 2,471,000 speakers), Nateni (Latn, 100,000 speakers), Igbo (Latn, 27,823,640 speakers), Lugbara (Latn, 2,200,000 speakers).

    [code: soft-dotted]

Outline Checks

⚠️⚠️⚠️

Do any segments have colinear vectors?

Check ID: <FontBakeryCheck:outline_colinear_vectors>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following glyphs have colinear vectors:

    * lla_ooVoweldivesakuru.undera: L<<1445.0,32.0>--<1446.0,32.0>> -> L<<1446.0,32.0>--<1446.0,32.0>>
    
    * lla_ooVoweldivesakuru: L<<1445.0,32.0>--<1446.0,32.0>> -> L<<1446.0,32.0>--<1446.0,32.0>>
    
    * u1192E_u11931.undera: L<<449.0,32.0>--<450.0,32.0>> -> L<<450.0,32.0>--<450.0,32.0>>
    
    * u1192E_u11931: L<<449.0,32.0>--<450.0,32.0>> -> L<<450.0,32.0>--<450.0,32.0>>
    
    * u1192E_u11932.undera: L<<449.0,32.0>--<450.0,32.0>> -> L<<450.0,32.0>--<450.0,32.0>>
    
    * u1192E_u11932: L<<449.0,32.0>--<450.0,32.0>> -> L<<450.0,32.0>--<450.0,32.0>>
    
    * u1192E_u11938.undera: L<<1095.0,32.0>--<1096.0,32.0>> -> L<<1096.0,32.0>--<1096.0,32.0>>
    
    * u1192E_u11938: L<<1095.0,32.0>--<1096.0,32.0>> -> L<<1096.0,32.0>--<1096.0,32.0>>
    
    [code: found-colinear-vectors]

Do outlines contain any jaggy segments?

Check ID: <FontBakeryCheck:outline_jaggy_segments>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following glyphs have jaggy segments:

    * u11909.alt.undera: L<<753.0,127.0>--<754.0,127.0>>/B<<754.0,127.0>-<546.0,95.0>-<421.0,50.5>> = 8.746162262555211
    
    * u11909.alt: L<<753.0,127.0>--<754.0,127.0>>/B<<754.0,127.0>-<546.0,95.0>-<421.0,50.5>> = 8.746162262555211
    
    * u1190C_u1193D.0002: B<<1026.0,595.0>-<973.0,573.0>-<924.0,551.0>>/B<<924.0,551.0>-<962.0,559.0>-<993.0,559.0>> = 12.29044910706117
    
    * u1190C_u1193D.0003: B<<1218.0,666.0>-<1066.0,611.0>-<932.0,550.0>>/B<<932.0,550.0>-<968.0,558.0>-<996.0,558.0>> = 11.947353801719451
    
    * u1190C_u1193D.0004: B<<1111.0,624.0>-<1017.0,586.0>-<934.0,548.0>>/B<<934.0,548.0>-<971.0,556.0>-<1000.0,556.0>> = 12.399321877776666
    
    * u1190C_u1193D.0005: B<<1152.5,629.5>-<1048.0,590.0>-<953.0,549.0>>/B<<953.0,549.0>-<980.0,554.0>-<1002.0,554.0>> = 12.852533949245883
    
    * u1190C_u1193D.undera: B<<1021.5,688.5>-<900.0,601.0>-<797.0,514.0>>/B<<797.0,514.0>-<840.0,537.0>-<881.5,547.0>> = 12.04484787403171
    
    * va_medya_iVoweldivesakuru.undera: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    * va_medya_iVoweldivesakuru: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    * va_medya_uVoweldivesakuru.undera: B<<1366.5,198.0>-<1331.0,142.0>-<1249.0,89.0>>/B<<1249.0,89.0>-<1348.0,129.0>-<1427.5,181.0>> = 10.875563401670016
    
    * va_medya_uVoweldivesakuru.undera: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    * va_medya_uVoweldivesakuru: B<<1366.5,198.0>-<1331.0,142.0>-<1249.0,89.0>>/B<<1249.0,89.0>-<1348.0,129.0>-<1427.5,181.0>> = 10.875563401670016
    
    * va_medya_uVoweldivesakuru: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    * va_medyadivesakuru.undera: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    * va_medyadivesakuru: B<<792.5,200.0>-<749.0,138.0>-<677.0,94.0>>/B<<677.0,94.0>-<803.0,135.0>-<875.5,182.5>> = 13.404842093600015
    
    [code: found-jaggy-segments]

Do outlines contain any semi-vertical or semi-horizontal lines?

Check ID: <FontBakeryCheck:outline_semi_vertical>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    The following glyphs have semi-vertical/semi-horizontal lines:

    * u11944 (U+11944): L<<272.0,471.0>--<269.0,39.0>>
    
    * u11944 (U+11944): L<<543.0,471.0>--<540.0,39.0>>
    
    [code: found-semi-vertical]

Font File Checks

⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩ℹ️ℹ️ℹ️

Check font follows the Google Fonts vertical metric schema

Check ID: <FontBakeryCheck:googlefonts/vertical_metrics>
⚠️ NotoSerifDivesAkuru-Regular.ttf
  • ⚠️ WARN

    We recommend the absolute sum of the hhea metrics should be between 1.2-1.5x of the font's upm. This font has 1.779x (1779)

    [code: bad-hhea-range]