A typeface designed for source code
Go to file
2015-12-14 22:33:20 -05:00
build updated web font CSS, generated new minified CSS 2015-11-04 21:56:05 -05:00
img added link to Font Playground on readme 2015-10-06 20:26:40 -04:00
postbuild_processing added v2.018 web fonts 2015-11-04 21:52:03 -05:00
source adjusted width of U+259C 2015-12-14 22:33:20 -05:00
tools Add ASCII character set filter 2015-10-26 11:44:20 +01:00
.gitignore added gitignore file 2015-09-26 16:50:56 -04:00
CHANGELOG.md updated changelog 2015-11-04 21:43:04 -05:00
CONTRIBUTORS.md updated contributors list 2015-11-03 21:49:09 -05:00
LICENSE.md added updated Hack Open Font license to the source 2015-09-27 17:34:23 -04:00
README.md updated web font CDN links in README 2015-11-06 22:32:44 -05:00

Hack

A typeface designed for source code

Hack-a monospaced sans-serif font for source code
C source code example
Python source code example
JavaScript source code example
Click to Try Hack in the Font Playground

Contents

About

No frills. No gimmicks. Hack is hand groomed and optically balanced to be a workhorse face for code.

It has deep roots in the libre, open source typeface community and expands upon the contributions of the Bitstream Vera & DejaVu projects. The face has been re-designed with a larger glyph set, modifications of the original glyph shapes (including distinct point styles and semi-bold punctuation weight in the regular set to make analphabetic characters less transparent), and meticulous attention to metrics (including numerous spacing adjustments to improve the rhythm of the face and the legibility of code at small text sizes). The large x-height + wide aperture + low contrast design combined with PostScript hinting/hint replacement programs and a TrueType instruction set make it highly legible at commonly used source code text sizes with a sweet spot that runs in the 8px - 12px range on modern desktop and laptop monitors. Combine it with an HD monitor and you can comfortably work at 6 or 7px sizes. The full set of changes are available in the changelog.

The font binaries are released under a license that permits unlimited print, desktop, and web use for commercial and non-commercial applications. It may be embedded and distributed in documents and applications. The source is released in the widely supported UFO format and may be modified to derive new typeface branches. The full text of the license is available in LICENSE.md

Data

  • Typeface Name: Hack
  • Category: Monospaced
  • Powerline Support: Yes
  • Glyph Number: 1561
  • Included Styles: Regular, Bold, Italic, Bold Italic

Specimen

Hack font specimen

Click the image for the full type specimen.

Desktop Usage

The .otf or .ttf files may be used on OS X platforms.

The .ttf files are recommended for screen use on Linux and Windows platforms.

Webfont Usage

Hack webfonts are released in svg, eot, ttf, woff, and woff2 formats. They include a complete Hack character set build and a smaller basic Latin + Latin-1 supplement Unicode character block build. The latter build set is smaller in size and is intended to improve page loading times when you do not need the entire Hack character set.

You can view the rendering of the webfonts at a range of sizes on the Hack type specimen.

Hack by CDN

Thanks to the generous gang at jsDelivr, you can use a CDN to include Hack on your site with a single stylesheet link in the head of your HTML files. There is no need to download font files from the repository or serve them from your web server.

Average latency, average uptime, and total downtime data for jsDelivr vs. other popular CDN are available for http and https protocols. Please understand that this is a free CDN resource and, while it does have industry backing, it could go away at anytime. If this is a critical issue for your use scenario, please purchase your own CDN plan and host the webfonts yourself.

Include one of the following lines in the <head> section of your site's HTML:

Basic Latin + Latin-1 Supplement Character Set
<link rel="stylesheet" href="//cdn.jsdelivr.net/font-hack/2.018/css/hack.min.css">
Full Character Set
<link rel="stylesheet" href="//cdn.jsdelivr.net/font-hack/2.018/css/hack-extended.min.css">

Then style your text by including Hack in the appropriate font-family property of your CSS. For example:

code {
	font-family: Hack, monospace;
}

The bold, oblique, and bold oblique text styles are formatted with HTML using <b>text block</b>, <i>text block</i>, and <b><i>text block</i></b> HTML tags, respectively.

Host Hack Font Files on Your Server

Download the entire web font archive at this link:

Or select the fonts that you need in subdirectories of the build directory:

The web font archive download is structured like this:

.
├── css
│   ├── hack-extended.css
│   ├── hack-extended.min.css
│   ├── hack.css
│   └── hack.min.css
└── fonts
    ├── eot
    │   ├── hack-bold-webfont.eot
    │   ├── hack-bolditalic-webfont.eot
    │   ├── hack-regular-webfont.eot
    │   ├── hack-italic-webfont.eot
    │   └── latin
    │       ├── hack-bold-latin-webfont.eot
    │       ├── hack-bolditalic-latin-webfont.eot
    │       ├── hack-regular-latin-webfont.eot
    │       └── hack-italic-latin-webfont.eot
    ├── svg
    │   ├── hack-bold-webfont.svg
    │   ├── hack-bolditalic-webfont.svg
    │   ├── hack-regular-webfont.svg
    │   ├── hack-italic-webfont.svg
    │   └── latin
    │       ├── hack-bold-latin-webfont.svg
    │       ├── hack-bolditalic-latin-webfont.svg
    │       ├── hack-regular-latin-webfont.svg
    │       └── hack-italic-latin-webfont.svg
    ├── ttf
    │   ├── hack-bold-webfont.ttf
    │   ├── hack-bolditalic-webfont.ttf
    │   ├── hack-regular-webfont.ttf
    │   ├── hack-italic-webfont.ttf
    │   └── latin
    │       ├── hack-bold-latin-webfont.ttf
    │       ├── hack-bolditalic-latin-webfont.ttf
    │       ├── hack-regular-latin-webfont.ttf
    │       └── hack-italic-latin-webfont.ttf
    ├── woff
    │   ├── hack-bold-webfont.woff
    │   ├── hack-bolditalic-webfont.woff
    │   ├── hack-regular-webfont.woff
    │   ├── hack-italic-webfont.woff
    │   └── latin
    │       ├── hack-bold-latin-webfont.woff
    │       ├── hack-bolditalic-latin-webfont.woff
    │       ├── hack-regular-latin-webfont.woff
    │       └── hack-italic-latin-webfont.woff
    └── woff2
        ├── hack-bold-webfont.woff2
        ├── hack-bolditalic-webfont.woff2
        ├── hack-regular-webfont.woff2
        ├── hack-italic-webfont.woff2
        └── latin
            ├── hack-bold-latin-webfont.woff2
            ├── hack-bolditalic-latin-webfont.woff2
            ├── hack-regular-latin-webfont.woff2
            └── hack-italic-latin-webfont.woff2

Push the css and fonts directories to your web server, then import one of the included CSS files in the head section of the HTML where you would like to use it.

Replace path/to/ with the actual path to your css directory.

Basic Latin + Latin-1 Supplement Character Set
<link rel="stylesheet" href="path/to/css/hack.min.css">
Full Character Set
<link rel="stylesheet" href="path/to/css/hack-extended.min.css">

You can alter the path to the Hack files (e.g. place the files in a hack resource subdirectory); however, please make sure that you preserve the relative file paths included in the release archive (or be prepared to modify the paths to the font files).

Then style your text by including Hack in the appropriate font-family property of your CSS. For example:

code {
	font-family: Hack, monospace;
}

The bold, oblique, and bold oblique text styles are formatted with HTML using <b>text block</b>, <i>text block</i>, and <b><i>text block</i></b> HTML tags, respectively.

Webfont Caching and gzip Compression with Cloudflare

The following information applies to both paid and free accounts

If you use Cloudflare, woff files are cached by default. To cache the remaining webfont files, add a new page rule for the path to your fonts directory:

yoursite.com/path/to/fonts/

and set the rule to Cache Everything.

Cloudflare automates gzip compression of ttf, eot, woff, and svg font files. The service does not gzip compress woff2 files.

Build Binaries

Desktop Fonts

TTF Builds
  • build/ttf/Hack-Regular.ttf
  • build/ttf/Hack-Bold.ttf
  • build/ttf/Hack-Italic.ttf
  • build/ttf/Hack-BoldItalic.ttf
OTF Builds
  • build/otf/Hack-Regular.otf
  • build/otf/Hack-Bold.otf
  • build/otf/Hack-Italic.otf
  • build/otf/Hack-BoldItalic.otf

Web Fonts

EOT
  • build/webfonts/fonts/eot/hack-regular-webfont.eot
  • build/webfonts/fonts/eot/hack-bold-webfont.eot
  • build/webfonts/fonts/eot/hack-italic-webfont.eot
  • build/webfonts/fonts/eot/hack-bolditalic-webfont.eot
  • build/webfonts/fonts/eot/latin/hack-regular-latin-webfont.eot
  • build/webfonts/fonts/eot/latin/hack-bold-latin-webfont.eot
  • build/webfonts/fonts/eot/latin/hack-italic-latin-webfont.eot
  • build/webfonts/fonts/eot/latin/hack-bolditalic-latin-webfont.eot
SVG
  • build/webfonts/fonts/svg/hack-regular-webfont.svg
  • build/webfonts/fonts/svg/hack-bold-webfont.svg
  • build/webfonts/fonts/svg/hack-italic-webfont.svg
  • build/webfonts/fonts/svg/hack-bolditalic-webfont.svg
  • build/webfonts/fonts/svg/latin/hack-regular-latin-webfont.svg
  • build/webfonts/fonts/svg/latin/hack-bold-latin-webfont.svg
  • build/webfonts/fonts/svg/latin/hack-italic-latin-webfont.svg
  • build/webfonts/fonts/svg/latin/hack-bolditalic-latin-webfont.svg
Web TTF
  • build/webfonts/fonts/web-ttf/hack-regular-webfont.ttf
  • build/webfonts/fonts/web-ttf/hack-bold-webfont.ttf
  • build/webfonts/fonts/web-ttf/hack-italic-webfont.ttf
  • build/webfonts/fonts/web-ttf/hack-bolditalic-webfont.ttf
  • build/webfonts/fonts/web-ttf/latin/hack-regular-latin-webfont.ttf
  • build/webfonts/fonts/web-ttf/latin/hack-bold-latin-webfont.ttf
  • build/webfonts/fonts/web-ttf/latin/hack-italic-latin-webfont.ttf
  • build/webfonts/fonts/web-ttf/latin/hack-bolditalic-latin-webfont.ttf
WOFF
  • build/webfonts/fonts/woff/hack-regular-webfont.woff
  • build/webfonts/fonts/woff/hack-bold-webfont.woff
  • build/webfonts/fonts/woff/hack-italic-webfont.woff
  • build/webfonts/fonts/woff/hack-bolditalic-webfont.woff
  • build/webfonts/fonts/woff/latin/hack-regular-latin-webfont.woff
  • build/webfonts/fonts/woff/latin/hack-bold-latin-webfont.woff
  • build/webfonts/fonts/woff/latin/hack-italic-latin-webfont.woff
  • build/webfonts/fonts/woff/latin/hack-bolditalic-latin-webfont.woff
WOFF2
  • build/webfonts/fonts/woff2/hack-regular-webfont.woff2
  • build/webfonts/fonts/woff2/hack-bold-webfont.woff2
  • build/webfonts/fonts/woff2/hack-italic-webfont.woff2
  • build/webfonts/fonts/woff2/hack-bolditalic-webfont.woff2
  • build/webfonts/fonts/woff2/latin/hack-regular-latin-webfont.woff2
  • build/webfonts/fonts/woff2/latin/hack-bold-latin-webfont.woff2
  • build/webfonts/fonts/woff2/latin/hack-italic-latin-webfont.woff2
  • build/webfonts/fonts/woff2/latin/hack-bolditalic-latin-webfont.woff2

Changes

Changes are in the Changelog.

License

Hack Copyright 2015, Christopher Simpkins with Reserved Font Name Hack.
HACK OPEN FONT LICENSE & BITSTREAM VERA LICENSE

Bitstream Vera Sans Mono Copyright 2003 Bitstream, Inc. with Reserved Font Names Bitstream and Vera
BITSTREAM VERA LICENSE

The full text of these licenses is available in LICENSE.md