1
1
mirror of https://github.com/i-tu/Hasklig.git synced 2024-09-19 06:29:15 +03:00
Hasklig/README.md
2014-11-13 18:38:36 +02:00

3.5 KiB

N.B. This is a fork of the Source Code Pro repository

Hasklig - Ligatures for Haskell code

Programming languages are limited to relatively few characters. As a result, combined character operators surfaced quite early, such as the widely used arrow (->), comprised of a hyphen and greater sign. It looks like an arrow if you know the analogy and squint a bit.

Composite glyphs are problematic in languages such as Haskell which utilize these complicated operators (=> -< >>= etc.) extensively. The readability of such complex code improves with pretty printing. Academic articles featuring Haskell code often use lhs2tex to achieve an appealing rendering, but it is of no use when programming.

Some Haskellers have resorted to Unicode symbols (, etc.), which are valid in the ghc. However they are one-character-wide and therefore eye-strainingly small. Furthermore, when displayed as substitutes to the underlying multi-character representation, as [vim2hs] (https://github.com/dag/vim2hs) does, the characters go out of alignment.

Hasklig solves the problem the way typographers have always solved ill-fitting characters which co-occur often: ligatures. The underlying code stays the same — only the representation changes.

Not only can multi-character glyphs be rendered more vividly, other problematic things in monospaced fonts, such as spacing can be corrected.

Download Hasklig Font Family v0.4

Hasklig

Hasklig Sample

Source Code Pro

Source Code Pro Sample

Release notes

  • v0.4: New ligatures: <* <*> <+> <$> *** <|> !! || === ==>, Powerline symbol support
  • v0.3: New ligatures: <<< >>> <> and +++
  • v0.2: Lengthened == and /= to match other equals signs
  • v0.1: Ligatures <- -> => >> << >>= =<< .. ... :: -< >- -<< >>- ++ /= and ==

Editor Support

  • Atom (add text-rendering: optimizeLegibility; to your .editor css. If that doesn't work, try disabling hardware acceleration in the settings)
  • BBEdit 11 (Instructions)
  • Chocolat
  • Geany
  • gEdit
  • Kate
  • Konsole
  • KWrite
  • Leksah (x64 W8 reported not working)
  • Light Table (Instructions)
  • Smultron
  • TextEdit
  • TextMate (from version 2.0-alpha.9549 onwards)

No support

Some editors have replaced standard font rendering engines with custom ones and don't support ligatures.

  • Emacs (Support is currently under work.)
  • gVim (output corrupted. A patch exists, but it has not been incorporated into mainstream gVim.)
  • Intellij IDEA (Has feature request)
  • iTerm2 (details)
  • MacVim (Reversing this commit makes ligatures show, but advancement is borked.)
  • Sublime Text (Vote for the enhancement here)
  • Terminal (OSX)