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 | 🔥 FAIL | ⚠️ WARN | ⏩ SKIP | ℹ️ INFO | ✅ PASS |
---|---|---|---|---|---|
1 | 4 | 11 | 35 | 9 | 181 |
1% | 2% | 6% | 20% | 5% | 103% |
Note: The following loglevels were omitted in this report: SKIP, INFO, PASS, DEBUG
Meaning of check results:
- 💥 An ERROR is something wrong with FontBakery itself, possibly a bug.
- 🔥 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.9.2
Section: Google Fonts
🔥🔥🔥⚠️⚠️⚠️⚠️⚠️⚠️⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩⏩ℹ️ℹ️ℹ️ℹ️ℹ️ℹ️ℹ️Does DESCRIPTION file contain broken links?
🔥 AnekLatin[wdth,wght].ttf
- 🔥 FAIL
The following links are broken in the DESCRIPTION file: /?query=Anek [code: broken-links]
DESCRIPTION.en_us.html should end in a linebreak.
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
The last characther on DESCRIPTION.en_us.html is not a line-break. Please add it. [code: missing-eof-linebreak]
Check Google Fonts glyph coverage.
🔥 AnekLatin[wdth,wght].ttf
- 🔥 FAIL
Missing required codepoints:
- 0x0132 (LATIN CAPITAL LIGATURE IJ) - 0x0133 (LATIN SMALL LIGATURE IJ)
[code: missing-codepoints]
Check for codepoints not covered by METADATA subsets.
⚠️ AnekLatin[wdth,wght].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+02B9 MODIFIER LETTER PRIME: not included in any glyphset definition
- U+02BA MODIFIER LETTER DOUBLE PRIME: not included in any glyphset definition
- U+02BE MODIFIER LETTER RIGHT HALF RING: not included in any glyphset definition
- U+02BF MODIFIER LETTER LEFT HALF RING: not included in any glyphset definition
- U+02C7 CARON: try adding one of: tifinagh, canadian-aboriginal
- U+02C8 MODIFIER LETTER VERTICAL LINE: not included in any glyphset definition
- U+02C9 MODIFIER LETTER MACRON: not included in any glyphset definition
- U+02CA MODIFIER LETTER ACUTE ACCENT: not included in any glyphset definition
- U+02CB MODIFIER LETTER GRAVE ACCENT: not included in any glyphset definition
- U+02CC MODIFIER LETTER LOW VERTICAL LINE: not included in any glyphset definition
- U+02D8 BREVE: try adding canadian-aboriginal
- U+02D9 DOT ABOVE: try adding canadian-aboriginal
- U+02DB OGONEK: try adding canadian-aboriginal
- U+02DD DOUBLE ACUTE ACCENT: not included in any glyphset definition
- U+0300 COMBINING GRAVE ACCENT: try adding one of: tai-le, cherokee, coptic
- U+0301 COMBINING ACUTE ACCENT: try adding one of: tai-le, cherokee, tifinagh, coptic
- U+0302 COMBINING CIRCUMFLEX ACCENT: try adding one of: tifinagh, cherokee, coptic
- U+0303 COMBINING TILDE: not included in any glyphset definition
- U+0304 COMBINING MACRON: try adding one of: tifinagh, cherokee, gothic, coptic
- U+0306 COMBINING BREVE: try adding tifinagh
- U+0307 COMBINING DOT ABOVE: try adding one of: malayalam, tifinagh, tai-le, canadian-aboriginal, coptic
- U+0308 COMBINING DIAERESIS: try adding one of: tai-le, gothic, coptic
- U+0309 COMBINING HOOK ABOVE: try adding tifinagh
- U+030A COMBINING RING ABOVE: not included in any glyphset definition
- U+030B COMBINING DOUBLE ACUTE ACCENT: try adding cherokee
- U+030C COMBINING CARON: try adding one of: tai-le, cherokee
- U+030F COMBINING DOUBLE GRAVE ACCENT: not included in any glyphset definition
- U+0311 COMBINING INVERTED BREVE: try adding coptic
- U+0312 COMBINING TURNED COMMA ABOVE: not included in any glyphset definition
- U+031B COMBINING HORN: not included in any glyphset definition
- U+0323 COMBINING DOT BELOW: try adding one of: tifinagh, cherokee, malayalam, coptic
- U+0324 COMBINING DIAERESIS BELOW: try adding cherokee
- U+0326 COMBINING COMMA BELOW: not included in any glyphset definition
- U+0327 COMBINING CEDILLA: not included in any glyphset definition
- U+0328 COMBINING OGONEK: not included in any glyphset definition
- U+032E COMBINING BREVE BELOW: not included in any glyphset definition
- U+0331 COMBINING MACRON BELOW: try adding one of: tifinagh, cherokee, gothic
- U+0335 COMBINING SHORT STROKE OVERLAY: not included in any glyphset definition
- U+0394 GREEK CAPITAL LETTER DELTA: try adding greek
- U+03A9 GREEK CAPITAL LETTER OMEGA: try adding greek
- U+03BC GREEK SMALL LETTER MU: try adding greek
- U+03C0 GREEK SMALL LETTER PI: try adding greek
- U+2007 FIGURE SPACE: not included in any glyphset definition
- U+2008 PUNCTUATION SPACE: not included in any glyphset definition
- U+200A HAIR SPACE: not included in any glyphset definition
- U+200C ZERO WIDTH NON-JOINER: try adding one of: tifinagh, myanmar, avestan, tamil, batak, gujarati, brahmi, telugu, tai-le, buginese, saurashtra, mandaic, cham, balinese, mongolian, arabic, lepcha, khmer, devanagari, tibetan, malayalam, rejang, tagbanwa, bengali, buhid, gurmukhi, kaithi, hanunoo, javanese, phags-pa, sundanese, meetei-mayek, tai-viet, syloti-nagri, chakma, new-tai-lue, sinhala, thai, kayah-li, oriya, limbu, tagalog, thaana, kannada, kharoshthi, tai-tham
- U+200D ZERO WIDTH JOINER: try adding one of: tifinagh, myanmar, avestan, tamil, batak, gujarati, brahmi, telugu, tai-le, buginese, saurashtra, mandaic, cham, balinese, mongolian, arabic, lepcha, tibetan, devanagari, malayalam, rejang, tagbanwa, bengali, buhid, gurmukhi, kaithi, hanunoo, javanese, phags-pa, sundanese, meetei-mayek, tai-viet, syloti-nagri, chakma, new-tai-lue, sinhala, thai, kayah-li, oriya, limbu, tagalog, thaana, kannada, kharoshthi, tai-tham
- U+2010 HYPHEN: try adding one of: kayah-li, kaithi, cham, sundanese, kharoshthi, lisu, syloti-nagri, arabic, coptic
- U+2012 FIGURE DASH: not included in any glyphset definition
- U+2015 HORIZONTAL BAR: not included in any glyphset definition
- U+2021 DOUBLE DAGGER: not included in any glyphset definition
- U+2030 PER MILLE SIGN: not included in any glyphset definition
- U+2052 COMMERCIAL MINUS SIGN: not included in any glyphset definition
- U+2070 SUPERSCRIPT ZERO: not included in any glyphset definition
- U+2075 SUPERSCRIPT FIVE: not included in any glyphset definition
- U+2076 SUPERSCRIPT SIX: not included in any glyphset definition
- U+2077 SUPERSCRIPT SEVEN: not included in any glyphset definition
- U+2078 SUPERSCRIPT EIGHT: not included in any glyphset definition
- U+2079 SUPERSCRIPT NINE: not included in any glyphset definition
- U+2080 SUBSCRIPT ZERO: not included in any glyphset definition
- U+2081 SUBSCRIPT ONE: not included in any glyphset definition
- U+2082 SUBSCRIPT TWO: not included in any glyphset definition
- U+2083 SUBSCRIPT THREE: not included in any glyphset definition
- U+2084 SUBSCRIPT FOUR: not included in any glyphset definition
- U+2085 SUBSCRIPT FIVE: not included in any glyphset definition
- U+2086 SUBSCRIPT SIX: not included in any glyphset definition
- U+2087 SUBSCRIPT SEVEN: not included in any glyphset definition
- U+2088 SUBSCRIPT EIGHT: not included in any glyphset definition
- U+2089 SUBSCRIPT NINE: not included in any glyphset definition
- U+2116 NUMERO SIGN: try adding cyrillic
- U+2126 OHM SIGN: not included in any glyphset definition
- U+212E ESTIMATED SYMBOL: not included in any glyphset definition
- U+2202 PARTIAL DIFFERENTIAL: not included in any glyphset definition
- U+2205 EMPTY SET: not included in any glyphset definition
- U+2206 INCREMENT: not included in any glyphset definition
- U+220F N-ARY PRODUCT: not included in any glyphset definition
- U+2211 N-ARY SUMMATION: not included in any glyphset definition
- U+2219 BULLET OPERATOR: try adding tai-tham
- U+221A SQUARE ROOT: not included in any glyphset definition
- U+221E INFINITY: not included in any glyphset definition
- U+222B INTEGRAL: not included in any glyphset definition
- U+2248 ALMOST EQUAL TO: not included in any glyphset definition
- U+2260 NOT EQUAL TO: not included in any glyphset definition
- U+2264 LESS-THAN OR EQUAL TO: not included in any glyphset definition
- U+2265 GREATER-THAN OR EQUAL TO: not included in any glyphset definition
- U+25CA LOZENGE: not included in any glyphset definition
- U+25CC DOTTED CIRCLE: try adding one of: lao, tifinagh, myanmar, tamil, batak, gujarati, brahmi, telugu, tai-le, buginese, mandaic, cham, balinese, mongolian, lepcha, khmer, devanagari, tibetan, malayalam, rejang, tagbanwa, bengali, buhid, gurmukhi, kaithi, hanunoo, javanese, canadian-aboriginal, phags-pa, meetei-mayek, sundanese, tai-viet, syloti-nagri, chakma, coptic, new-tai-lue, sinhala, thai, kayah-li, oriya, limbu, tagalog, hebrew, thaana, kannada, kharoshthi
- U+27E8 MATHEMATICAL LEFT ANGLE BRACKET: not included in any glyphset definition
- U+27E9 MATHEMATICAL RIGHT ANGLE BRACKET: not included in any glyphset definition
- U+FB01 LATIN SMALL LIGATURE FI: not included in any glyphset definition
- U+FB02 LATIN SMALL LIGATURE FL: not included in any glyphset definition
Or you can add the above codepoints to one of the subsets supported by the font:
latin
,latin-ext
,menu
,vietnamese
[code: unreachable-subsetting]
METADATA.pb font.name field contains font name in right format?
🔥 AnekLatin[wdth,wght].ttf
- 🔥 FAIL
METADATA.pb font.name field ("Anek Latin") does not match correct font name format ("Anek Latin Medium"). [code: mismatch]
Glyphs are similiar to Google Fonts version?
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
Following glyphs differ greatly from Google Fonts version: * AE * AEacute * Aacute * Abreve * Acircumflex * Agrave * Amacron * Aogonek * Aring * Aringacute * Atilde * B * C * Cacute * Ccaron * Ccedilla * Ccircumflex * Cdotaccent * D * Dcaron * Dcroat * E * Eacute * Ebreve * Ecaron * Ecircumflex * Edieresis * Edotaccent * Egrave * Emacron * Eng * Eogonek * Eth * Euro * F * G * Gbreve * Gcaron * Gcircumflex * Gdotaccent * Hbar * I * Iacute * Ibreve * Icircumflex * Idieresis * Idotaccent * Igrave * Imacron * Iogonek * Itilde * Jcircumflex * K * L * Lacute * Lcaron * Ldot * Lslash * M * N * Nacute * Ncaron * O * OE * Oacute * Obreve * Ocircumflex * Odieresis * Ograve * Ohorn * Ohungarumlaut * Omacron * Oslash * Oslashacute * Otilde * P * Q * R * Racute * Rcaron * S * Sacute * Scaron * Scedilla * Scircumflex * T * Tbar * Tcaron * Thorn * U * Udieresis * Uogonek * V * W * Wacute * Wcircumflex * Wdieresis * Wgrave * X * Z * Zacute * Zcaron * Zdotaccent * a * aacute * abreve * acircumflex * adieresis * ae * aeacute * agrave * amacron * ampersand * aogonek * approxequal * aring * aringacute * asciitilde * asterisk * at * atilde * b * bar * breve * brokenbar * c * cacute * ccaron * ccedilla * ccircumflex * cdotaccent * cedilla * cent * colon * colonmonetary * copyright * currency * d * dagger * dcaron * dcroat * degree * divide * dollar * dong * dotlessi * e * eacute * ebreve * ecaron * ecircumflex * edieresis * edotaccent * egrave * eight * eight.dnom * eight.numr * eight.tf * ellipsis * emacron * emdash * emptyset * endash * eng * eogonek * equal * eth * exclam * exclamdown * f * f_f * f_f_i * f_f_l * figuredash * five * five.dnom * five.numr * five.tf * four * four.dnom * four.numr * four.tf * fraction * franc * g * gbreve * gcaron * gcircumflex * gdotaccent * germandbls * greater * greaterequal * guillemotleft * guillemotright * h * hookabovecomb * hookabovecomb.case * hyphen * i * i.loclTRK * iacute * ibreve * icircumflex * idieresis * igrave * imacron * infinity * integral * iogonek * itilde * j * jcircumflex * kgreenlandic * l * lacute * lcaron * ldot * leftanglebracketmath * less * lessequal * lira * logicalnot * lozenge * lslash * macron * minus * multiply * n * nine * nine.dnom * nine.numr * nine.tf * notequal * numbersign * o * oacute * obreve * ocircumflex * odieresis * oe * ograve * ohorn * ohungarumlaut * omacron * one * one.tf * onehalf * onequarter * ordfeminine * ordmasculine * oslash * oslashacute * otilde * p * paragraph * parenleft * parenright * partialdiff * percent * perthousand * peseta * pi * plus * plusminus * product * q * question * question_alt * questiondown * r_t * radical * rcaron * registered * rightanglebracketmath * s * sacute * scaron * scedilla * scircumflex * section * semicolon * seven * seven.dnom * seven.numr * seven.tf * six * six.dnom * six.numr * six.tf * sterling * summation * t * tbar * tcaron * thorn * three * three.dnom * three.numr * three.tf * threequarters * tilde * tildecomb * tildecomb.case * tildecomb.narrow * trademark * two * two.dnom * two.numr * two.tf * u * udieresis * underscore * uni004A0301 * uni006A0301 * uni00AD * uni00B2 * uni00B3 * uni00B5 * uni0122 * uni0123 * uni0136 * uni013B * uni013C * uni0145 * uni0156 * uni0162 * uni0163 * uni018F * uni01C4 * uni01C5 * uni01C6 * uni01C7 * uni01C8 * uni01C9 * uni01CA * uni01CB * uni01CC * uni01EA * uni01EB * uni01F1 * uni01F2 * uni01F3 * uni0200 * uni0201 * uni0202 * uni0203 * uni0204 * uni0205 * uni0206 * uni0207 * uni0208 * uni0209 * uni020A * uni020B * uni020C * uni020D * uni020E * uni020F * uni0210 * uni0211 * uni0212 * uni0213 * uni0218 * uni0219 * uni021A * uni021B * uni022A * uni022B * uni022C * uni022D * uni0230 * uni0231 * uni0233 * uni0237 * uni0259 * uni02C9 * uni0302.case * uni03020300 * uni03020300.case * uni03020301 * uni03020301.case * uni03020303 * uni03020303.case * uni0304 * uni0304.case * uni0306 * uni0306.case * uni0306.narrow * uni03060300 * uni03060300.case * uni03060301 * uni03060301.case * uni03060303 * uni03060303.case * uni030C.case * uni0311 * uni0311.case * uni0311.narrow * uni031B.case * uni031B.case_O * uni0327 * uni0327.case * uni032E * uni032E.case * uni0331 * uni0331.case * uni0335 * uni0394 * uni03A9 * uni03BC * uni1E08 * uni1E09 * uni1E0C * uni1E0D * uni1E0E * uni1E0F * uni1E14 * uni1E15 * uni1E16 * uni1E17 * uni1E1C * uni1E1D * uni1E20 * uni1E21 * uni1E25 * uni1E2A * uni1E2E * uni1E2F * uni1E36 * uni1E37 * uni1E3A * uni1E3B * uni1E42 * uni1E44 * uni1E45 * uni1E46 * uni1E47 * uni1E48 * uni1E4C * uni1E4D * uni1E4E * uni1E4F * uni1E50 * uni1E51 * uni1E52 * uni1E53 * uni1E5A * uni1E5E * uni1E5F * uni1E60 * uni1E61 * uni1E62 * uni1E63 * uni1E64 * uni1E65 * uni1E66 * uni1E67 * uni1E68 * uni1E69 * uni1E6D * uni1E6E * uni1E6F * uni1E8E * uni1E8F * uni1E92 * uni1E93 * uni1E97 * uni1E9E * uni1EA1 * uni1EA3 * uni1EA4 * uni1EA5 * uni1EA6 * uni1EA7 * uni1EA8 * uni1EA9 * uni1EAA * uni1EAB * uni1EAC * uni1EAD * uni1EAE * uni1EAF * uni1EB0 * uni1EB1 * uni1EB2 * uni1EB3 * uni1EB4 * uni1EB5 * uni1EB6 * uni1EB7 * uni1EB8 * uni1EB9 * uni1EBA * uni1EBB * uni1EBC * uni1EBD * uni1EBE * uni1EBF * uni1EC0 * uni1EC1 * uni1EC2 * uni1EC3 * uni1EC4 * uni1EC5 * uni1EC6 * uni1EC7 * uni1EC8 * uni1EC9 * uni1ECA * uni1ECB * uni1ECC * uni1ECD * uni1ECE * uni1ECF * uni1ED0 * uni1ED1 * uni1ED2 * uni1ED3 * uni1ED4 * uni1ED5 * uni1ED6 * uni1ED7 * uni1ED8 * uni1ED9 * uni1EDA * uni1EDB * uni1EDC * uni1EDD * uni1EDE * uni1EDF * uni1EE0 * uni1EE1 * uni1EE2 * uni1EE3 * uni1EE4 * uni1EE5 * uni1EE6 * uni1EE7 * uni1EEC * uni1EED * uni1EEE * uni1EF4 * uni1EF5 * uni1EF6 * uni1EF7 * uni2010 * uni2015 * uni2052 * uni2070 * uni2074 * uni2075 * uni2076 * uni2077 * uni2078 * uni2079 * uni2080 * uni2082 * uni2083 * uni2084 * uni2085 * uni2086 * uni2087 * uni2088 * uni2089 * uni20A6 * uni20A9 * uni20AA * uni20AD * uni20AE * uni20B1 * uni20B2 * uni20B5 * uni20B9 * uni20BA * uni20BD * uni2113 * uni2116 * uni2126 * uni2206 * v * w * wacute * wcircumflex * wdieresis * wgrave * y * yacute * ycircumflex * ydieresis * yen * ygrave * z * zacute * zcaron * zdotaccent * zero * zero.dnom * zero.numr * zero.tf * zero.tf.zero and zero.zero
Is there kerning info for non-ligated sequences?
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
GPOS table lacks kerning info for the following non-ligated sequences:
- f + f - f + i - i + f - f + l - l + f - i + l [code: lacks-kern-info]
A static fonts directory with at least two fonts must accompany variable fonts
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
Please consider adding a subdirectory called "static/" and including in it static font files. [code: missing]
Ensure fonts have ScriptLangTags declared on the 'meta' table.
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
This font file does not have a 'meta' table. [code: lacks-meta-table]
Section: Universal
💥⚠️⚠️⚠️⚠️⏩⏩⏩⏩⏩ℹ️ℹ️Check font contains no unreachable glyphs
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
The following glyphs could not be reached by codepoint or substitution rules:
- Ek - NULL - eight.subs - five.subs - four.subs - nine.subs - one.subs - seven.subs - six.subs - three.subs - two.subs - uni030B.narrow - zero.subs
[code: unreachable-glyphs]
Does the font contain a soft hyphen?
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
This font has a 'Soft Hyphen' character. [code: softhyphen]
Detect any interpolation issues in the font.
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
Interpolation issues were found in the font: - Contour 0 start point differs in glyph 'Eng' between location <fontTools.ttLib.ttGlyphSet._TTGlyphSetGlyf object at 0x107b18d60> and location <fontTools.ttLib.ttGlyphSet._TTGlyphSetGlyf object at 0x10876db70> [code: interpolation-issues]
Check math signs have the same width.
⚠️ AnekLatin[wdth,wght].ttf
- ⚠️ WARN
The most common width is 1031 among a set of 5 math glyphs. The following math glyphs have a different width, though:
Width = 1004: divide, plus
Width = 1029: greater, less
Width = 1018: logicalnot
Width = 958: multiply
Width = 979: minus
Width = 1084: approxequal [code: width-outliers]
Check accent of Lcaron, dcaron, lcaron, tcaron (derived from com.google.fonts/check/alt_caron)
💥 AnekLatin[wdth,wght].ttf
- 💥 ERROR
Failed with TypeError: cannot unpack non-iterable float object
Section: Shaping Checks
🔥⚠️⏩⏩⏩Ensure dotted circle glyph is present and can attach marks.
🔥 AnekLatin[wdth,wght].ttf
- 🔥 FAIL
The following glyphs could not be attached to the dotted circle glyph:
- acutecomb - dotbelowcomb - gravecomb - hookabovecomb - tildecomb - uni0302 - uni0304 - uni0306 - uni0307 - uni0308 - uni030A - uni030B - uni030C - uni030F - uni0311 - uni0312 - uni031B - uni0324 - uni0326 - uni0327 - uni0328 - uni032E - uni0331 - uni0335 [code: unattached-dotted-circle-marks]
Ensure soft_dotted characters lose their dot when combined with marks that replace the dot.
⚠️ AnekLatin[wdth,wght].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: Dutch (Latn, 31,709,104 speakers).
Your font does not cover the following languages that require the soft-dotted feature: Ukrainian (Cyrl, 29,273,587 speakers), Belarusian (Cyrl, 10,064,517 speakers), Aghem (Latn, 38,843 speakers), Basaa (Latn, 332,940 speakers), Navajo (Latn, 166,319 speakers), Igbo (Latn, 27,823,640 speakers), Lithuanian (Latn, 2,357,094 speakers). [code: soft-dotted]