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
1 0 1 8 68 7 167
0% 0% 0% 3% 27% 3% 66%

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

Google Fonts

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

Check for codepoints not covered by METADATA subsets.

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/unreachable_subsetting>
⚠️ NotoSerifTodhri-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+0020 SPACE: try adding one of: medefaidrin, tagalog, nandinagari, runic, nko, duployan, ol-chiki, imperial-aramaic, lao, nag-mundari, bhaiksuki, anatolian-hieroglyphs, tangut, chinese-simplified, palmyrene, hebrew, gujarati, mayan-numerals, miao, ottoman-siyaq-numbers, javanese, hanunoo, nushu, signwriting, sinhala, mahajani, pau-cin-hau, telugu, sharada, ugaritic, oriya, gothic, tagbanwa, cyrillic-ext, tirhuta, khojki, kannada, chorasmian, kirat-rai, linear-b, korean, indic-siyaq-numbers, coptic, deseret, braille, dogra, elymaic, meroitic, old-north-arabian, garay, shavian, znamenny, tamil-supplement, makasar, lepcha, wancho, inscriptional-parthian, meroitic-cursive, phoenician, khmer, linear-a, thaana, malayalam, old-permic, rejang, vithkuqi, mro, vai, kharoshthi, gurung-khema, osmanya, syriac, japanese, psalter-pahlavi, greek, old-uyghur, symbols2, bassa-vah, zanabazar-square, cypro-minoan, music, cherokee, meroitic-hieroglyphs, tamil, chinese-traditional, sora-sompeng, ahom, old-turkic, khudawadi, phags-pa, ol-onal, khitan-small-script, saurashtra, devanagari, newa, osage, tibetan, math, arabic, nyiakeng-puachue-hmong, marchen, multani, old-persian, warang-citi, cham, lisu, sunuwar, takri, symbols, gunjala-gondi, limbu, samaritan, adlam, tangsa, vietnamese, lycian, old-italic, canadian-aboriginal, siddham, avestan, carian, ogham, toto, pahawh-hmong, cyrillic, meetei-mayek, grantha, gurmukhi, kana-extended, soyombo, manichaean, chinese-hongkong, bamum, georgian, syloti-nagri, new-tai-lue, hanifi-rohingya, tai-tham, batak, mandaic, mende-kikakui, sogdian, glagolitic, buginese, buhid, greek-ext, sundanese, ethiopic, armenian, cypriot, elbasan, modi, dives-akuru, brahmi, kawi, chakma, mongolian, inscriptional-pahlavi, lydian, masaram-gondi, thai, hatran, cuneiform, old-sogdian, old-south-arabian, tai-le, yi, yezidi, tulu-tigalari, tifinagh, myanmar, caucasian-albanian, old-hungarian, egyptian-hieroglyphs, nabataean, kaithi, tai-viet, balinese, kayah-li, bengali
    • U+00A0 NO-BREAK SPACE: try adding one of: medefaidrin, tagalog, nandinagari, runic, nko, duployan, ol-chiki, imperial-aramaic, lao, nag-mundari, bhaiksuki, anatolian-hieroglyphs, tangut, chinese-simplified, palmyrene, hebrew, gujarati, mayan-numerals, miao, ottoman-siyaq-numbers, javanese, hanunoo, nushu, signwriting, sinhala, mahajani, pau-cin-hau, telugu, sharada, ugaritic, oriya, gothic, tagbanwa, cyrillic-ext, tirhuta, khojki, kannada, chorasmian, kirat-rai, linear-b, korean, indic-siyaq-numbers, coptic, deseret, braille, dogra, elymaic, meroitic, old-north-arabian, garay, shavian, znamenny, tamil-supplement, makasar, lepcha, wancho, inscriptional-parthian, meroitic-cursive, phoenician, khmer, linear-a, thaana, malayalam, old-permic, rejang, vithkuqi, mro, vai, kharoshthi, gurung-khema, osmanya, syriac, japanese, psalter-pahlavi, greek, old-uyghur, symbols2, bassa-vah, zanabazar-square, cypro-minoan, music, cherokee, meroitic-hieroglyphs, tamil, chinese-traditional, sora-sompeng, ahom, old-turkic, khudawadi, phags-pa, ol-onal, khitan-small-script, saurashtra, devanagari, newa, osage, tibetan, math, arabic, nyiakeng-puachue-hmong, marchen, multani, old-persian, warang-citi, cham, lisu, sunuwar, takri, symbols, gunjala-gondi, limbu, samaritan, adlam, tangsa, vietnamese, lycian, old-italic, canadian-aboriginal, siddham, avestan, carian, ogham, toto, pahawh-hmong, cyrillic, meetei-mayek, grantha, gurmukhi, kana-extended, soyombo, manichaean, chinese-hongkong, bamum, georgian, syloti-nagri, new-tai-lue, hanifi-rohingya, tai-tham, batak, mandaic, mende-kikakui, sogdian, glagolitic, buginese, buhid, greek-ext, sundanese, ethiopic, armenian, cypriot, elbasan, modi, dives-akuru, brahmi, kawi, chakma, mongolian, inscriptional-pahlavi, lydian, masaram-gondi, thai, hatran, cuneiform, old-sogdian, old-south-arabian, tai-le, yi, yezidi, tulu-tigalari, tifinagh, myanmar, caucasian-albanian, old-hungarian, egyptian-hieroglyphs, nabataean, kaithi, tai-viet, balinese, kayah-li, bengali
    • U+02D8 BREVE: try adding one of: yi, canadian-aboriginal
    • U+02D9 DOT ABOVE: try adding one of: yi, canadian-aboriginal
    • U+02DB OGONEK: try adding one of: yi, canadian-aboriginal
    • U+0302 COMBINING CIRCUMFLEX ACCENT: try adding one of: math, tifinagh, coptic, cherokee
    • U+0305 COMBINING OVERLINE: try adding one of: coptic, elbasan, gothic, glagolitic, math
    • U+0306 COMBINING BREVE: try adding one of: tifinagh, old-permic
    • 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
    • U+0361 COMBINING DOUBLE INVERTED BREVE: try adding coptic
    • U+25CC DOTTED CIRCLE: try adding one of: tagalog, nko, duployan, lao, bhaiksuki, hebrew, gujarati, miao, javanese, hanunoo, sinhala, mahajani, telugu, sharada, oriya, tagbanwa, tirhuta, khojki, kannada, coptic, dogra, lepcha, wancho, khmer, thaana, malayalam, old-permic, rejang, kharoshthi, syriac, psalter-pahlavi, bassa-vah, zanabazar-square, music, tamil, ahom, khudawadi, phags-pa, saurashtra, devanagari, newa, osage, tibetan, math, marchen, warang-citi, cham, takri, symbols, gunjala-gondi, limbu, adlam, canadian-aboriginal, siddham, pahawh-hmong, meetei-mayek, grantha, gurmukhi, soyombo, manichaean, syloti-nagri, new-tai-lue, hanifi-rohingya, tai-tham, batak, mandaic, mende-kikakui, sogdian, buginese, buhid, sundanese, armenian, elbasan, modi, brahmi, mongolian, chakma, masaram-gondi, thai, tai-le, yi, tifinagh, myanmar, caucasian-albanian, kaithi, tai-viet, balinese, kayah-li, bengali

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

    [code: unreachable-subsetting]

Shapes languages in all GF glyphsets.

Check ID: <FontBakeryCheck:com.google.fonts/check/glyphsets/shape_languages>
⚠️ NotoSerifTodhri-Regular.ttf
  • ⚠️ WARN

    GF_Latin_Core glyphset:

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

    OK.

On a family update, the DESCRIPTION.en_us.html file should ideally also be updated.

Check ID: <FontBakeryCheck:com.google.fonts/check/description/family_update>
⚠️ NotoSerifTodhri-Regular.ttf
  • ⚠️ WARN

    The DESCRIPTION.en_us.html file in this family has not changed in comparison to the latest font release on the google/fonts github repo. Please consider mentioning note-worthy improvements made to the family recently.

    [code: description-not-updated]

Ensure fonts have ScriptLangTags declared on the 'meta' table.

Check ID: <FontBakeryCheck:com.google.fonts/check/meta/script_lang_tags>
⚠️ NotoSerifTodhri-Regular.ttf
  • ⚠️ WARN

    This font file does not have a 'meta' table.

    [code: lacks-meta-table]

The font has tags in the GF Tags spreadsheet

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/has_tags>
💥 NotoSerifTodhri-Regular.ttf
  • 💥 ERROR

    Failed with ReadTimeout: HTTPSConnectionPool(host='doc-08-b8-sheets.googleusercontent.com', port=443): Read timed out. (read timeout=10)

      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/fontbakery/checkrunner.py", line 170, in _exec_check
        results.extend(list(result))
                       ^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/fontbakery/profiles/googlefonts.py", line 7476, in com_google_fonts_check_metadata_has_tags
        tags = gf_tags()
               ^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/fontbakery/profiles/googlefonts_conditions.py", line 752, in gf_tags
        req = requests.get(GF_TAGS_SHEET_URL, timeout=10)
              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/api.py", line 73, in get
        return request("get", url, params=params, **kwargs)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/api.py", line 59, in request
        return session.request(method=method, url=url, **kwargs)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/sessions.py", line 589, in request
        resp = self.send(prep, **send_kwargs)
               ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/sessions.py", line 724, in send
        history = [resp for resp in gen]
                  ^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/sessions.py", line 724, in <listcomp>
        history = [resp for resp in gen]
                  ^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/sessions.py", line 265, in resolve_redirects
        resp = self.send(
               ^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/sessions.py", line 703, in send
        r = adapter.send(request, **kwargs)
            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/opt/hostedtoolcache/Python/3.11.10/x64/lib/python3.11/site-packages/requests/adapters.py", line 713, in send
        raise ReadTimeout(e, request=request)
    
    
    [code: failed-check]

Universal

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

Do we have the latest version of FontBakery installed?

Check ID: <FontBakeryCheck:com.google.fonts/check/fontbakery_version>
🔥 NotoSerifTodhri-Regular.ttf
  • 🔥 FAIL

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

    [code: outdated-fontbakery]

Check that legacy accents aren't used in composite glyphs.

Check ID: <FontBakeryCheck:com.google.fonts/check/legacy_accents>
⚠️ NotoSerifTodhri-Regular.ttf
  • ⚠️ WARN

    Glyph "eitodhri" has a legacy accent component (dotabovemod). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "utodhri" has a legacy accent component (dotabovemod). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "acutecomb" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "dotabovecomb" has a legacy accent component (dotabovemod). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Aacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Abreve" has a legacy accent component (breve). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Acircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Adieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Agrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Aogonek" has a legacy accent component (ogonek). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Atilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Cacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ccaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Dcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Eacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ecaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ecircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Edieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Egrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Gbreve" has a legacy accent component (breve). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Iacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Icircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Idieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Igrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Lacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Nacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ncaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ntilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Oacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ocircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Odieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ograve" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ohungarumlaut" has a legacy accent component (hungarumlaut). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Otilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Racute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Rcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Sacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Scaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Scedilla" has a legacy accent component (cedilla). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Tcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Uacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ucircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Udieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ugrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Uhungarumlaut" has a legacy accent component (hungarumlaut). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Uring" has a legacy accent component (ring). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Wacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Wcircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Wdieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Wgrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Yacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ycircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ydieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Ygrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Zacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "Zcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "aacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "abreve" has a legacy accent component (breve). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "acircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "adieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "agrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "aogonek" has a legacy accent component (ogonek). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "aring" has a legacy accent component (ring). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "atilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uni0306" has a legacy accent component (breve). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "cacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uni030C" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ccaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ccedilla" has a legacy accent component (cedilla). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uni0302" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "eacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ecaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ecircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "edieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "egrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "gbreve" has a legacy accent component (breve). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uni030B" has a legacy accent component (hungarumlaut). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "iacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "icircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "idieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "igrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "lacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "nacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ncaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ntilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "oacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ocircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "odieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ograve" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ohungarumlaut" has a legacy accent component (hungarumlaut). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "otilde" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "racute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "rcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uni030A" has a legacy accent component (ring). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "sacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "scaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "scedilla" has a legacy accent component (cedilla). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "tildecomb" has a legacy accent component (tilde). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ucircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "udieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ugrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uhungarumlaut" has a legacy accent component (hungarumlaut). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uogonek" has a legacy accent component (ogonek). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "uring" has a legacy accent component (ring). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "wacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "wcircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "wdieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "wgrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "yacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ycircumflex" has a legacy accent component (circumflex). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ydieresis" has a legacy accent component (dieresis). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "ygrave" has a legacy accent component (grave). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "zacute" has a legacy accent component (acute). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]
  • ⚠️ WARN

    Glyph "zcaron" has a legacy accent component (caron). It needs to be replaced by a combining mark.

    [code: legacy-accents-component]

Check if each glyph has the recommended amount of contours.

Check ID: <FontBakeryCheck:com.google.fonts/check/contour_count>
⚠️ NotoSerifTodhri-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: Euro	Contours detected: 3	Expected: 1 or 2
    
    - Glyph name: Euro	Contours detected: 3	Expected: 1 or 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
    
    [code: contour-count]

Check math signs have the same width.

Check ID: <FontBakeryCheck:com.google.fonts/check/math_signs_width>
⚠️ NotoSerifTodhri-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]

Shaping Checks

⚠️⏩⏩⏩

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

Check ID: <FontBakeryCheck:com.google.fonts/check/soft_dotted>
⚠️ NotoSerifTodhri-Regular.ttf
  • ⚠️ WARN

    The dot of soft dotted characters used in orthographies must disappear in the following strings: j̈ j̑ į̀ į́ į̂ į̃ į̄ į̌

    The dot of soft dotted characters should disappear in other cases, for example: i̇ ȋ ị̇ ị̑ i̦̇ ȋ̦ i̧̇ ȋ̧ j̇ j̣̇ j̣̈ j̣̑ j̦̇ j̦̈ j̦̑ j̧̇ j̧̈ j̧̑ j̨̇ j̨̈

    Your font fully covers the following languages that require the soft-dotted feature: Dutch (Latn, 31,709,104 speakers), Igbo (Latn, 27,823,640 speakers), Ebira (Latn, 2,200,000 speakers), Lithuanian (Latn, 2,357,094 speakers), Ekpeye (Latn, 226,000 speakers).

    Your font does not cover the following languages that require the soft-dotted feature: Vute (Latn, 21,000 speakers), Avokaya (Latn, 100,000 speakers), South Central Banda (Latn, 244,000 speakers), Nateni (Latn, 100,000 speakers), Belarusian (Cyrl, 10,064,517 speakers), Ukrainian (Cyrl, 29,273,587 speakers), Cicipu (Latn, 44,000 speakers), Dii (Latn, 71,000 speakers), Ngbaka (Latn, 1,020,000 speakers), Navajo (Latn, 166,319 speakers), Makaa (Latn, 221,000 speakers), Yala (Latn, 200,000 speakers), Zapotec (Latn, 490,000 speakers), Mundani (Latn, 34,000 speakers), Fur (Latn, 1,230,163 speakers), Koonzime (Latn, 40,000 speakers), Sar (Latn, 500,000 speakers), Lugbara (Latn, 2,200,000 speakers), Bafut (Latn, 158,146 speakers), Dan (Latn, 1,099,244 speakers), Ijo, Southeast (Latn, 2,471,000 speakers), Kom (Latn, 360,685 speakers), Gulay (Latn, 250,478 speakers), Bete-Bendi (Latn, 100,000 speakers), Ejagham (Latn, 120,000 speakers), Nzakara (Latn, 50,000 speakers), Kpelle, Guinea (Latn, 622,000 speakers), Mango (Latn, 77,000 speakers), Mfumte (Latn, 79,000 speakers), Southern Kisi (Latn, 360,000 speakers), Aghem (Latn, 38,843 speakers), Basaa (Latn, 332,940 speakers), Ma’di (Latn, 584,000 speakers).

    [code: soft-dotted]