Giter Site home page Giter Site logo

firacode's Introduction

Fira Code: monospaced font with programming ligatures

Problem

Programmers use a lot of symbols, often encoded with several characters. For human brain sequences like ->, <= or := are single logical token, even if they take two or three places on the screen. Your eye spends non-zero amount of energy to scan, parse and join multiple characters into a single logical one. Ideally, all programming languages should be designed with full-fledged Unicode symbols for operators, but that’s not the case yet.

Solution

Download Fira Code v1.102 | Follow updates 📢 @FiraCode

Fira Code is a Fira Mono font extended with a set of ligatures for common programming multi-character combinations. This is just a font rendering feature: underlying code remains ASCII-compatible. This helps to read and understand code faster. For some frequent sequences like .. or // ligatures allow us to correct spacing.

Terminals support

Work Don’t work
Terminal.app (OS X default terminal) iTerm 2 (feature request)
Konsole GNOME Terminal
Termux (Android terminal emulator) rxvt
Black Screen xfce4-terminal

Editor support

Work Don’t work
Anjuta (ligatures rendered unless last char is at the end of file) Arduino IDE
Atom 1.1 or newer (instructions) Eclipse (Mac and Win, vote here)
BBEdit (instructions) Standalone Emacs (workaround)
Bracket (with this plugin) gVim
Chocolat IDLE
Coda 2 KDevelop 4
Code::Blocks IDE Monkey Studio IDE
CodeLite Notepad++
Eclipse (Linux) Spyder IDE
Geany SublimeText (vote here)
gEdit / Pluma
GNOME Builder
IntelliJ products (IDEA etc, instructions)
Kate, KWrite
Leafpad
LibreOffice
LightTable (instructions)
MacVim 7.4 or newer (instructions)
Mancy
Meld
Mousepad
Notepad (Win)
QtCreator
RStudio (instructions)
Scratch
TextAdept (Linux, Mac)
TextMate 2
Visual Studio 2015
Visual Studio Code (instructions)
Xamarin Studio/Monodevelop
Xcode (with this plugin)
Probably work: Smultron, Vico

Browser support

  • IE 10+, Edge: enable with font-feature-settings: "calt" 1;
  • Firefox
  • Safari
  • Chromium-based browsers: enable with font-variant-ligatures: contextual; or text-rendering: optimizeLegibility (see 571246)
  • ACE
  • CodeMirror

Code examples

Ruby:

JavaScript:

Erlang:

Go:

Haskell:

Alternatives

Other monospaced fonts with ligatures:

Credits

My name is Nikita Prokopov (@nikitonsky).

Official Fira Code twitter: @FiraCode (subscribe for updates & announcements)

This work is based on OFL-licensed Fira Mono font. Original Fira Mono font was not changed, only extended.

Fira Code was inspired by Hasklig font: Ligatures for Haskell code.

Thanks Georg Seifert for providing a Glyphs 2 license.

Changelog

1.102

  • Support for IntelliJ-based IDEs (instructions)
  • Turned on autohinting

1.101

  • Added Light weight
  • Adjusted rules when vertical centering of :, -, * and + occurs

1.100

  • Fixed calt table conflicts (---- would incorrectly render as <!--)
  • Added centered : (between digits, e.g. 10:40)
  • Added lowercase-aligned -, * and + (only between lowercase letters, e.g. kebab case var-name, pointers *ptr etc)

1.000

Added weights:

  • Retina (just slightly heavier than Regular)
  • Medium
  • Bold

Switched to calt instead of liga. You can now “step inside” the ligature in text editors.

Fira Code is now drawn and built in Glyps 2 app (should improve compatibility).

Added:

<-> <~~ <~ ~~~ ~> ~~>
<$ <+ <* *> +> $>
;;; ::: !!! ??? %% %%% ## ### ####
.- #_( =< **/ 0x www []

Redrawn:

{- -} ~= =~ =<< >>= <$> <=> .=

Removed: ?:

Total ligatures count: 115

0.6

Redrawn from Fira Mono 3.204 (slightly heavier weight)

Added:

** *** +++ -- --- ?:
/= /== .= ^= =~ ?= ||= |=
<<< <=< -<< -< >- >>- >=> >>>
<*> <|> <$> <+>
<!-- {- -} /** \\ \\\ ..< ?? ||| &&& <| |>

Added support for Powerline

0.5

Added: #{ ~- -~ <== ==> /// ;; </

0.4

  • Added ~= ~~ #[
  • Rolled back && and || to more traditional look
  • === and !== are now rendered with 3 horisontal bars

0.3

Added: ~@ #? =:= =<

0.2.1

Fixed width of && and ||

0.2

Added: --> <-- && || =>> =/=

0.1

>>= =<< <<= ->> -> => <<- <-
=== == <=> >= <= >> << !== != <>
:= ++ #( #_
:: ... .. !! // /* */ />

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.