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 🔥 FAIL ⚠️ WARN ⏩ SKIP ℹ️ INFO ✅ PASS
0 16 17 66 7 135
0% 9% 9% 37% 4% 75%

Note: The following loglevels were omitted in this report: SKIP, INFO, PASS, DEBUG

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

Section: Google Fonts

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

Does DESCRIPTION file contain broken links?

Check ID: <FontBakeryCheck:com.google.fonts/check/description/broken_links>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    Found an email address: mailto:astigma@astigmatic.com [code: email]

Does DESCRIPTION file contain a upstream Git repo URL?

Check ID: <FontBakeryCheck:com.google.fonts/check/description/git_url>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    Please host your font project on a public Git repo (such as GitHub or GitLab) and place a link in the DESCRIPTION.en_us.html file. [code: lacks-git-url]

DESCRIPTION.en_us.html should end in a linebreak.

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

    The last characther on DESCRIPTION.en_us.html is not a line-break. Please add it. [code: missing-eof-linebreak]

Checking OS/2 achVendID.

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

    OS/2 VendorID value 'AOEF' is not yet recognized. If you registered it recently, then it's safe to ignore this warning message. Otherwise, you should set it to your own unique 4 character code, and register it with Microsoft at https://www.microsoft.com/typography/links/vendorlist.aspx [code: unknown]

Check Google Fonts glyph coverage.

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

    Missing required codepoints:

    - 0x0308 (COMBINING DIAERESIS)
    
    
    - 0x0300 (COMBINING GRAVE ACCENT)
    
    
    - 0x0301 (COMBINING ACUTE ACCENT)
    
    
    - 0x030B (COMBINING DOUBLE ACUTE ACCENT)
    
    
    - 0x0304 (COMBINING MACRON)
    
    
    - 0x0218 (LATIN CAPITAL LETTER S WITH COMMA BELOW)
    
    
    - 0x1E9E (LATIN CAPITAL LETTER SHARP S)
    
    
    - 0x0219 (LATIN SMALL LETTER S WITH COMMA BELOW)
    
    
    - 0x0307 (COMBINING DOT ABOVE)
    
    
    - 0x0302 (COMBINING CIRCUMFLEX ACCENT)
    
    
    - 0x030C (COMBINING CARON)
    
    
    - 0x0306 (COMBINING BREVE)
    
    
    - 0x030A (COMBINING RING ABOVE)
    
    
    - 0x0303 (COMBINING TILDE)
    
    
    - 0x0312 (COMBINING TURNED COMMA ABOVE)
    
    
    - 0x0326 (COMBINING COMMA BELOW)
    
    
    - 0x0327 (COMBINING CEDILLA)
    
    
    - 0x0328 (COMBINING OGONEK)
    

    [code: missing-codepoints]

Check for codepoints not covered by METADATA subsets.

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/unreachable_subsetting>
⚠️ Sacramento-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+02C7 CARON: try adding one of: tifinagh, canadian-aboriginal
    • 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+0315 COMBINING COMMA ABOVE RIGHT: not included in any glyphset definition
    • U+03BC GREEK SMALL LETTER MU: try adding greek
    • U+2021 DOUBLE DAGGER: not included in any glyphset definition
    • U+2030 PER MILLE SIGN: not included in any glyphset definition
    • U+2202 PARTIAL DIFFERENTIAL: not included in any glyphset definition
    • U+221A SQUARE ROOT: not included in any glyphset definition
    • U+221E INFINITY: 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+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: menu, latin, latin-ext [code: unreachable-subsetting]

Check license file has good copyright string.

Check ID: <FontBakeryCheck:com.google.fonts/check/license/OFL_copyright>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    First line in license file is:

    "copyright (c) 2012, brian j. bonislawsky dba astigmatic (aoeti) (astigma@astigmatic.com), with reserved font names 'sacramento'"

    which does not match the expected format, similar to:

    "Copyright 2022 The Familyname Project Authors (git url)" [code: bad-format]

Check copyright namerecords match license file.

Check ID: <FontBakeryCheck:com.google.fonts/check/name/license>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    License file OFL.txt exists but NameID 13 (LICENSE DESCRIPTION) value on platform 1 (MACINTOSH) is not specified for that. Value was: "This Font Software is licensed under the SIL Open Font License, Version 1.1. This license is available with a FAQ at: https://scripts.sil.org/OFL" Must be changed to "This Font Software is licensed under the SIL Open Font License, Version 1.1. This license is available with a FAQ at: https://scripts.sil.org/OFL" [code: wrong]

  • 🔥 FAIL

    License file OFL.txt exists but NameID 13 (LICENSE DESCRIPTION) value on platform 3 (WINDOWS) is not specified for that. Value was: "This Font Software is licensed under the SIL Open Font License, Version 1.1. This license is available with a FAQ at: https://scripts.sil.org/OFL" Must be changed to "This Font Software is licensed under the SIL Open Font License, Version 1.1. This license is available with a FAQ at: https://scripts.sil.org/OFL" [code: wrong]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=1, enc=0, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=3, enc=1, name=13] [code: http-in-description]

  • ⚠️ WARN

    For now we're still accepting http URLs, but you should consider using https instead. [code: http]

License URL matches License text on name table?

Check ID: <FontBakeryCheck:com.google.fonts/check/name/license_url>
⚠️ Sacramento-Regular.ttf
  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=1, enc=0, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=3, enc=1, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=1, enc=0, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=3, enc=1, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=1, enc=0, name=13] [code: http-in-description]

  • ⚠️ WARN

    Please consider using HTTPS URLs at name table entry [plat=3, enc=1, name=13] [code: http-in-description]

Is the Grid-fitting and Scan-conversion Procedure ('gasp') table set to optimize rendering?

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

    The gasp table has a range of 8 that may be unneccessary. [code: non-ffff-range]

  • ⚠️ WARN

    The gasp table has a range of 16 that may be unneccessary. [code: non-ffff-range]

  • ⚠️ WARN

    The gasp range 0xFFFF value 0x03 should be set to 0x0F. [code: unset-flags]

METADATA.pb subsets should be alphabetically ordered.

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/subsets_order>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    METADATA.pb subsets are not sorted in alphabetical order: Got ['menu', 'latin', 'latin-ext'] and expected ['latin', 'latin-ext', 'menu'] [code: not-sorted]

METADATA.pb font.full_name and font.post_script_name fields have equivalent values ?

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/match_fullname_postscript>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    METADATA.pb font full_name = "Sacramento" does not match post_script_name = "Sacramento-Regular" [code: mismatch]

Copyright notices match canonical pattern in METADATA.pb

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/valid_copyright>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    METADATA.pb: Copyright notices should match a pattern similar to: "Copyright 2020 The Familyname Project Authors (git url)" But instead we have got: "copyright (c) 2012 by brian j. bonislawsky dba astigmatic (aoeti) (astigma@astigmatic.com), with reserved font name 'sacramento'" [code: bad-notice-format]

Copyright notices match canonical pattern in fonts

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

    Name Table entry: Copyright notices should match a pattern similar to: "Copyright 2019 The Familyname Project Authors (git url)" But instead we have got: "Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name "Sacramento"" [code: bad-notice-format]

  • 🔥 FAIL

    Name Table entry: Copyright notices should match a pattern similar to: "Copyright 2019 The Familyname Project Authors (git url)" But instead we have got: "Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name "Sacramento"" [code: bad-notice-format]

Copyright notice on METADATA.pb should not contain 'Reserved Font Name'.

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/reserved_font_name>
⚠️ Sacramento-Regular.ttf
  • ⚠️ WARN

    METADATA.pb: copyright field ("Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name 'Sacramento'") contains "Reserved Font Name". This is an error except in a few specific rare cases. [code: rfn]

Check font names are correct

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

    Regular missing from full name [code: lacks-regular]

Copyright field for this font on METADATA.pb matches all copyright notice entries on the name table ?

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/nameid/copyright>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    Copyright field for this font on METADATA.pb ("Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name 'Sacramento'") differs from a copyright notice entry on the name table: "Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name "Sacramento"" [code: mismatch]

  • 🔥 FAIL

    Copyright field for this font on METADATA.pb ("Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name 'Sacramento'") differs from a copyright notice entry on the name table: "Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name "Sacramento"" [code: mismatch]

Font enables smart dropout control in "prep" table instructions?

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

    The 'prep' table does not contain TrueType instructions enabling smart dropout control. To fix, export the font with autohinting enabled, or run ttfautohint on the font, or run the gftools fix-nonhinting script. [code: lacks-smart-dropout]

Are there caret positions declared for every ligature?

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

    GDEF table is missing, but it is mandatory to declare it on fonts that provide ligature glyphs because the caret (text cursor) positioning for each ligature must be provided in this table. [code: GDEF-missing]

Is there kerning info for non-ligated sequences?

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

    GPOS table lacks kerning info for the following non-ligated sequences:

    - f + i
    
    - i + l [code: lacks-kern-info]
    

A static fonts directory with at least two fonts must accompany variable fonts

Check ID: <FontBakeryCheck:com.google.fonts/check/repo/vf_has_static_fonts>
⚠️ Sacramento-Regular.ttf
  • ⚠️ WARN

    Please consider adding a subdirectory called "static/" and including in it static font files. [code: missing]

Ensure METADATA.pb does not use escaped strings.

Check ID: <FontBakeryCheck:com.google.fonts/check/metadata/escaped_strings>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    Found escaped chars at 'Sacramento'. Please use an unicode string instead. [code: escaped-strings]

  • 🔥 FAIL

    Found escaped chars at 'Copyright (c) 2012 by Brian J. Bonislawsky DBA Astigmatic (AOETI) (astigma@astigmatic.com), with Reserved Font Name 'Sacramento''. Please use an unicode string instead. [code: escaped-strings]

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>
⚠️ Sacramento-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]

OS/2.fsSelection bit 7 (USE_TYPO_METRICS) is set in all fonts.

Check ID: <FontBakeryCheck:com.google.fonts/check/os2/use_typo_metrics>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    OS/2.fsSelection bit 7 (USE_TYPO_METRICS) wasNOT set in the following fonts: ['/Users/simon/others-repos/fonts/ofl/sacramento/Sacramento-Regular.ttf']. [code: missing-os2-fsselection-bit7]

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

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

    This font file does not have a 'meta' table. [code: lacks-meta-table]

Section: Universal

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

Font contains '.notdef' as its first glyph?

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

    The '.notdef' glyph should contain a drawing, but it is blank. [code: notdef-is-blank]

Font has **proper** whitespace glyph names?

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

    Glyph 0x00A0 is called "nonbreakingspace": Change to "uni00A0" [code: not-recommended-00a0]

Check font contains no unreachable glyphs

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

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

    - Imacron
    
    - nonmarkingreturn
    

    [code: unreachable-glyphs]

Check if each glyph has the recommended amount of contours.

Check ID: <FontBakeryCheck:com.google.fonts/check/contour_count>
⚠️ Sacramento-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: two	Contours detected: 2	Expected: 1
    
    - Glyph name: three	Contours detected: 2	Expected: 1
    
    - Glyph name: at	Contours detected: 1	Expected: 2
    
    - Glyph name: E	Contours detected: 2	Expected: 1
    
    - Glyph name: F	Contours detected: 2	Expected: 1
    
    - Glyph name: G	Contours detected: 2	Expected: 1
    
    - Glyph name: H	Contours detected: 2	Expected: 1
    
    - Glyph name: J	Contours detected: 2	Expected: 1
    
    - Glyph name: K	Contours detected: 3	Expected: 1 or 2
    
    - Glyph name: L	Contours detected: 2	Expected: 1
    
    - Glyph name: Q	Contours detected: 3	Expected: 2
    
    - Glyph name: Y	Contours detected: 2	Expected: 1
    
    - Glyph name: a	Contours detected: 1	Expected: 2
    
    - Glyph name: f	Contours detected: 3	Expected: 1
    
    - Glyph name: h	Contours detected: 2	Expected: 1
    
    - Glyph name: i	Contours detected: 3	Expected: 2
    
    - Glyph name: j	Contours detected: 4	Expected: 2
    
    - Glyph name: l	Contours detected: 2	Expected: 1
    
    - Glyph name: r	Contours detected: 2	Expected: 1
    
    - Glyph name: t	Contours detected: 4	Expected: 1
    
    - Glyph name: y	Contours detected: 2	Expected: 1
    
    - Glyph name: z	Contours detected: 2	Expected: 1
    
    - Glyph name: uni00AD	Contours detected: 1	Expected: 0
    
    - Glyph name: twosuperior	Contours detected: 2	Expected: 1
    
    - Glyph name: onehalf	Contours detected: 4	Expected: 3
    
    - Glyph name: AE	Contours detected: 3	Expected: 2
    
    - Glyph name: Egrave	Contours detected: 3	Expected: 2
    
    - Glyph name: Eacute	Contours detected: 3	Expected: 2
    
    - Glyph name: Ecircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Edieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: Oslash	Contours detected: 4	Expected: 2 or 3
    
    - Glyph name: Yacute	Contours detected: 3	Expected: 2
    
    - Glyph name: agrave	Contours detected: 2	Expected: 3
    
    - Glyph name: aacute	Contours detected: 2	Expected: 3
    
    - Glyph name: acircumflex	Contours detected: 2	Expected: 3
    
    - Glyph name: atilde	Contours detected: 2	Expected: 3
    
    - Glyph name: adieresis	Contours detected: 3	Expected: 4
    
    - Glyph name: aring	Contours detected: 3	Expected: 4
    
    - Glyph name: eth	Contours detected: 1	Expected: 2
    
    - Glyph name: oslash	Contours detected: 4	Expected: 3
    
    - Glyph name: yacute	Contours detected: 3	Expected: 2
    
    - Glyph name: ydieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: amacron	Contours detected: 2	Expected: 3
    
    - Glyph name: abreve	Contours detected: 2	Expected: 3
    
    - Glyph name: aogonek	Contours detected: 1	Expected: 2
    
    - Glyph name: dcroat	Contours detected: 3	Expected: 2
    
    - Glyph name: Emacron	Contours detected: 3	Expected: 2
    
    - Glyph name: Ebreve	Contours detected: 3	Expected: 2
    
    - Glyph name: Edotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Ecaron	Contours detected: 3	Expected: 2
    
    - Glyph name: Gcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Gbreve	Contours detected: 3	Expected: 2
    
    - Glyph name: Gdotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Gcommaaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Hcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: hcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Hbar	Contours detected: 3	Expected: 2
    
    - Glyph name: hbar	Contours detected: 3	Expected: 1
    
    - Glyph name: IJ	Contours detected: 3	Expected: 1 or 2
    
    - Glyph name: ij	Contours detected: 6	Expected: 3 or 4
    
    - Glyph name: Jcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: jcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Kcommaaccent	Contours detected: 4	Expected: 2 or 3
    
    - Glyph name: Lacute	Contours detected: 3	Expected: 2
    
    - Glyph name: lacute	Contours detected: 3	Expected: 2
    
    - Glyph name: Lcommaaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: lcommaaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Lcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: lcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: Ldot	Contours detected: 3	Expected: 2
    
    - Glyph name: ldotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Lslash	Contours detected: 2	Expected: 1
    
    - Glyph name: lslash	Contours detected: 3	Expected: 1
    
    - Glyph name: Eng	Contours detected: 2	Expected: 1
    
    - Glyph name: eng	Contours detected: 2	Expected: 1
    
    - Glyph name: OE	Contours detected: 3	Expected: 2
    
    - Glyph name: racute	Contours detected: 3	Expected: 2
    
    - Glyph name: rcommaaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: rcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: tcommaaccent	Contours detected: 5	Expected: 1 or 2
    
    - Glyph name: tcaron	Contours detected: 5	Expected: 2
    
    - Glyph name: tbar	Contours detected: 4	Expected: 1
    
    - Glyph name: Ycircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: ycircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Ydieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: zacute	Contours detected: 3	Expected: 2
    
    - Glyph name: zdotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: zcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: AEacute	Contours detected: 4	Expected: 3
    
    - Glyph name: Oslashacute	Contours detected: 5	Expected: 4
    
    - Glyph name: oslashacute	Contours detected: 5	Expected: 4
    
    - Glyph name: dotlessj	Contours detected: 2	Expected: 1
    
    - Glyph name: Ygrave	Contours detected: 3	Expected: 2
    
    - Glyph name: ygrave	Contours detected: 3	Expected: 2
    
    - Glyph name: trademark	Contours detected: 3	Expected: 2
    
    - Glyph name: partialdiff	Contours detected: 1	Expected: 2
    
    - Glyph name: fi	Contours detected: 5	Expected: 1, 2 or 3
    
    - Glyph name: fl	Contours detected: 4	Expected: 1 or 2
    
    - Glyph name: AE	Contours detected: 3	Expected: 2
    
    - Glyph name: AEacute	Contours detected: 4	Expected: 3
    
    - Glyph name: E	Contours detected: 2	Expected: 1
    
    - Glyph name: Eacute	Contours detected: 3	Expected: 2
    
    - Glyph name: Ebreve	Contours detected: 3	Expected: 2
    
    - Glyph name: Ecaron	Contours detected: 3	Expected: 2
    
    - Glyph name: Ecircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Edieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: Edotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: Egrave	Contours detected: 3	Expected: 2
    
    - Glyph name: Emacron	Contours detected: 3	Expected: 2
    
    - Glyph name: Eng	Contours detected: 2	Expected: 1
    
    - Glyph name: F	Contours detected: 2	Expected: 1
    
    - Glyph name: G	Contours detected: 2	Expected: 1
    
    - Glyph name: Gbreve	Contours detected: 3	Expected: 2
    
    - Glyph name: Gcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Gdotaccent	Contours detected: 3	Expected: 2
    
    - Glyph name: H	Contours detected: 2	Expected: 1
    
    - Glyph name: Hbar	Contours detected: 3	Expected: 2
    
    - Glyph name: Hcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: IJ	Contours detected: 3	Expected: 1 or 2
    
    - Glyph name: J	Contours detected: 2	Expected: 1
    
    - Glyph name: Jcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: K	Contours detected: 3	Expected: 1 or 2
    
    - Glyph name: L	Contours detected: 2	Expected: 1
    
    - Glyph name: Lacute	Contours detected: 3	Expected: 2
    
    - Glyph name: Lcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: Ldot	Contours detected: 3	Expected: 2
    
    - Glyph name: Lslash	Contours detected: 2	Expected: 1
    
    - Glyph name: OE	Contours detected: 3	Expected: 2
    
    - Glyph name: Oslash	Contours detected: 4	Expected: 2 or 3
    
    - Glyph name: Oslashacute	Contours detected: 5	Expected: 4
    
    - Glyph name: Q	Contours detected: 3	Expected: 2
    
    - Glyph name: Y	Contours detected: 2	Expected: 1
    
    - Glyph name: Yacute	Contours detected: 3	Expected: 2
    
    - Glyph name: Ycircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: Ydieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: Ygrave	Contours detected: 3	Expected: 2
    
    - Glyph name: a	Contours detected: 1	Expected: 2
    
    - Glyph name: aacute	Contours detected: 2	Expected: 3
    
    - Glyph name: abreve	Contours detected: 2	Expected: 3
    
    - Glyph name: acircumflex	Contours detected: 2	Expected: 3
    
    - Glyph name: adieresis	Contours detected: 3	Expected: 4
    
    - Glyph name: agrave	Contours detected: 2	Expected: 3
    
    - Glyph name: amacron	Contours detected: 2	Expected: 3
    
    - Glyph name: aogonek	Contours detected: 1	Expected: 2
    
    - Glyph name: aring	Contours detected: 3	Expected: 4
    
    - Glyph name: at	Contours detected: 1	Expected: 2
    
    - Glyph name: atilde	Contours detected: 2	Expected: 3
    
    - Glyph name: dcroat	Contours detected: 3	Expected: 2
    
    - Glyph name: eng	Contours detected: 2	Expected: 1
    
    - Glyph name: eth	Contours detected: 1	Expected: 2
    
    - Glyph name: f	Contours detected: 3	Expected: 1
    
    - Glyph name: fi	Contours detected: 5	Expected: 3
    
    - Glyph name: fl	Contours detected: 4	Expected: 2
    
    - Glyph name: h	Contours detected: 2	Expected: 1
    
    - Glyph name: hbar	Contours detected: 3	Expected: 1
    
    - Glyph name: hcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: i	Contours detected: 3	Expected: 2
    
    - Glyph name: ij	Contours detected: 6	Expected: 3 or 4
    
    - Glyph name: j	Contours detected: 4	Expected: 2
    
    - Glyph name: jcircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: l	Contours detected: 2	Expected: 1
    
    - Glyph name: lacute	Contours detected: 3	Expected: 2
    
    - Glyph name: lcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: lslash	Contours detected: 3	Expected: 1
    
    - Glyph name: onehalf	Contours detected: 4	Expected: 3
    
    - Glyph name: oslash	Contours detected: 4	Expected: 3
    
    - Glyph name: oslashacute	Contours detected: 5	Expected: 4
    
    - Glyph name: partialdiff	Contours detected: 1	Expected: 2
    
    - Glyph name: r	Contours detected: 2	Expected: 1
    
    - Glyph name: racute	Contours detected: 3	Expected: 2
    
    - Glyph name: rcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: t	Contours detected: 4	Expected: 1
    
    - Glyph name: tbar	Contours detected: 4	Expected: 1
    
    - Glyph name: tcaron	Contours detected: 5	Expected: 2
    
    - Glyph name: three	Contours detected: 2	Expected: 1
    
    - Glyph name: trademark	Contours detected: 3	Expected: 2
    
    - Glyph name: two	Contours detected: 2	Expected: 1
    
    - Glyph name: uni00AD	Contours detected: 1	Expected: 0
    
    - Glyph name: y	Contours detected: 2	Expected: 1
    
    - Glyph name: yacute	Contours detected: 3	Expected: 2
    
    - Glyph name: ycircumflex	Contours detected: 3	Expected: 2
    
    - Glyph name: ydieresis	Contours detected: 4	Expected: 3
    
    - Glyph name: ygrave	Contours detected: 3	Expected: 2
    
    - Glyph name: z	Contours detected: 2	Expected: 1
    
    - Glyph name: zacute	Contours detected: 3	Expected: 2
    
    - Glyph name: zcaron	Contours detected: 3	Expected: 2
    
    - Glyph name: zdotaccent	Contours detected: 3	Expected: 2
    

    [code: contour-count]

Does the font contain a soft hyphen?

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

    This font has a 'Soft Hyphen' character. [code: softhyphen]

Check accent of Lcaron, dcaron, lcaron, tcaron (derived from com.google.fonts/check/alt_caron)

Check ID: <FontBakeryCheck:com.google.fonts/check/alt_caron:googlefonts>
🔥 Sacramento-Regular.ttf
  • 🔥 FAIL

    dcaron uses component quoteright. [code: bad-mark]

  • 🔥 FAIL

    Lcaron uses component quoteright. [code: bad-mark]

  • 🔥 FAIL

    lcaron uses component quoteright. [code: bad-mark]

  • 🔥 FAIL

    tcaron uses component quoteright. [code: bad-mark]

Section: fontbakery.profiles.os2

⚠️⏩

Check if OS/2 xAvgCharWidth is correct.

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

    OS/2 xAvgCharWidth is 607 but it should be 1131 which corresponds to the average of the widths of all glyphs in the font. [code: xAvgCharWidth-wrong]

Section: fontbakery.profiles.kern

🔥

Is there a usable "kern" table declared in the font?

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

    The following glyphs should not be used in the "kern" table because they are not in the "cmap" table: Imacron [code: kern-non-character-glyphs]