forked from pool/kika-fixedsys-fonts
173 lines
7.9 KiB
Markdown
173 lines
7.9 KiB
Markdown
|
# Fixedsys Excelsior font with programming ligatures
|
||
|
|
||
|
## Distribution terms
|
||
|
|
||
|
The font was originally authored by Darien Valentine [@bathos](https://github.com/bathos) and provided via a now-defunct site at [fixedsysexcelsior.com](http://www.fixedsysexcelsior.com). This derivative's source code repository and issue tracker can be found at [github.com/kika/fixedsys](https://github.com/kika/fixedsys/).
|
||
|
|
||
|
The creator(s) of this content have released it to the public domain. For jurisdictions where this is not permitted, it is released under the terms of the Creative Commons Zero Dedication.
|
||
|
|
||
|
## It looks like this
|
||
|
<img src="./images/sample.png" />
|
||
|
|
||
|
## Where to get the result without compiling
|
||
|
The compiled TTF binary font is on the Releases page.
|
||
|
There are two versions provided:
|
||
|
1. Default has =< and >= ligated into "less or equal" and "greater or equal"
|
||
|
1. Alt version enables <= (replacing reverse fat arrow) and >= instead (closes #3)
|
||
|
|
||
|
### What is the ALT version in the releases about?
|
||
|
|
||
|
The fonts declare a set of ligatures that replace certain groups of adjacent characters by a combined glyph. The ALT variant has some of the ligature declarations swapped to facilitate code programming, where `<=` is almost always meant to be a less-or-equal operator, and also works for the general case too, based on the presumption that left fat arrows are seldomly used even in scientific texts.
|
||
|
|
||
|
| Input | Normal variant | ALT variant |
|
||
|
|------- | ---------------- | ---------------- |
|
||
|
| `<=` | left fat arrow | less-or-equal |
|
||
|
| `<==` | left fat arrow | left fat arrow |
|
||
|
| `=>` | right fat arrow | right fat arrow |
|
||
|
| `=<` | less-or-equal | (no ligature) |
|
||
|
| `>=` | greater-or-equal | greater-or-equal |
|
||
|
| `>==` | (no ligature) | (no ligature) |
|
||
|
|
||
|
## Rationale
|
||
|
I (Kirill Pertsev) was always jealous for folks using [Fira Code](https://github.com/tonsky/FiraCode),
|
||
|
[Hasklig](https://github.com/i-tu/Hasklig) or [Monoid](https://github.com/larsenwork/monoid)
|
||
|
fonts, but my problem is that I have a hard time reading (not even mentioning writing)
|
||
|
a computer program in anything but an 8x16 font. I probably spent too much time with older
|
||
|
computers. So after fighting and losing an uphill battle with Glyph2, Fontlab and Fontforge
|
||
|
I discovered [TTX](https://github.com/behdad/fonttools) and was able to finally stop being jealous.
|
||
|
|
||
|
This current release has almost everything I use regularly. Feel free to request in the issues. PRs are of course
|
||
|
more than welcome. I hope I'm not the only crazy guy on the internet using 8x16
|
||
|
font for consoles and text editing.
|
||
|
|
||
|
## History
|
||
|
This font is a simulated 8x16 bitmap font from old Windows and DOS. It was
|
||
|
truly monospaced and really bitmapped and initially contained only
|
||
|
windows-1250, windows-1251, a subset of windows-1252, windows-1253
|
||
|
and windows-1254.
|
||
|
Darien simulated the bitmap with TrueType outlines by building the font from
|
||
|
10x10 squares ("pixels") and then joining the squares together. As such, this font
|
||
|
only works as intended in only one size and usually with antialiasing switched
|
||
|
off. The size is 16px, or 12pt@96dpi.
|
||
|
|
||
|
He also added a lot of foreign characters and made the font Unicode.
|
||
|
|
||
|
## Tech trivia
|
||
|
The font is distributed in binary TTF format and I decompiled it with
|
||
|
[TTX](https://github.com/behdad/fonttools), added a few symbols inspired by
|
||
|
[Fira Code](https://github.com/tonsky/FiraCode) and created necessary ligatures.
|
||
|
|
||
|
To design the symbols I used quad lined paper, pencil and rubber eraser. Like
|
||
|
in good old days, you know.
|
||
|
<img src="./images/IMG_3506.jpg" />
|
||
|
|
||
|
The supported programming ligatures are listed in the `ligatures.txt` file.
|
||
|
|
||
|
To create a TTF file from TTX XML, just run `ttx -f FSEX.ttx`
|
||
|
(`-f` means overwrite) or use the OS X Makefile to also copy it to the user Fonts
|
||
|
folder and update the font cache.
|
||
|
|
||
|
## Supported software (incomplete list, send updates please)
|
||
|
|
||
|
I only tested in MacVim so far (this is the only editor I use). Comments and bug
|
||
|
reports welcome. MacVim should be quite recent for ligatures to work.
|
||
|
**Note**: Versions of MacVim above 8.1-146 seem to have a regression where ligatures are not displayed correctly. Use `brew pin` to maintain your MacVim version below this until this is fixed.
|
||
|
[Tracking issue and workaround](https://github.com/macvim-dev/macvim/issues/841)
|
||
|
|
||
|
Add the following to your `.vimrc`:
|
||
|
|
||
|
```
|
||
|
set guifont=Fixedsys\ Excelsior:h16
|
||
|
set noanti
|
||
|
set macligatures
|
||
|
```
|
||
|
Courtesy of [@ForNeVeR](https://github.com/ForNeVeR):
|
||
|
|
||
|
- Windows + IDEA (Oracle JDK): renders ligatures, but have problems rendering latin `A` letter (it occupies no space in text and gets composed with a next character). There's a warning in IDEA interface telling about incompatibilities of Oracle JDK and fonts with ligatures.
|
||
|
- Windows + IDEA (JetBrains JDK): no problems noticed.
|
||
|
- Windows + VS Code:
|
||
|
```json
|
||
|
"editor.fontFamily": "Fixedsys Excelsior",
|
||
|
"editor.fontSize": 16,
|
||
|
"editor.fontLigatures": true
|
||
|
```
|
||
|
or, for newer versions (courtesy of [@Kaffiend](https://github.com/Kaffiend))
|
||
|
|
||
|
```json
|
||
|
"editor.fontFamily": "'Fixedsys Excelsior 3.01'",
|
||
|
"editor.fontSize": 15,
|
||
|
"editor.fontLigatures": true
|
||
|
```
|
||
|
**(The following is only for VSCode on MacOS)** For many people this may look ugly because Fixedsys is not designed to be used with antialiasing. Then you may add the following option
|
||
|
|
||
|
```json
|
||
|
"workbench.fontAliasing": "none"
|
||
|
```
|
||
|
|
||
|
Which will make code editor look nice, but everything else in the VSCode UI - ugly. The solution to that is to modify the CSS for the VSCode itself.
|
||
|
[Here is the script that I keep more or less updated when VSCode changes the CSS](https://gist.github.com/kika/2b5a3ccf065a251a6a8cbcdca7d823cc)
|
||
|
|
||
|
- Windows + Visual Studio 2015: works mostly okay, but `->` ligature doesn't work. That's a [known problem of WPF text renderer](https://github.com/tonsky/FiraCode/issues/259#issuecomment-243422144).
|
||
|
- Windows + ConEmu: no ligatures at all. Powerline stuff works okay though, so font is usable even without ligatures. I'd recommend to set font cell width manually to 8 (otherwise it'll have problems determining proper places for line wrapping and rendering Far Manager UI): **Settings** → **Main** → **Main console font** group → select **Cell: 8** from the selector.
|
||
|
|
||
|
### Emacs
|
||
|
Courtesy of [@adrianparvino](https://github.com/adrianparvino)
|
||
|
|
||
|
Requires you to move the U+10001 PUA block to the first PUA block
|
||
|
|
||
|
In this example, U+10001 was moved to U+efb0.
|
||
|
|
||
|
Based on https://github.com/tonsky/FiraCode/wiki/Setting-up-Emacs
|
||
|
```
|
||
|
(set-fontset-font t '(#Xefb0 . #Xefc5) "Fixedsys Excelsior")
|
||
|
(defconst fixedsys-excelsior-font-lock-keywords-alist
|
||
|
(mapcar (lambda (regex-char-pair)
|
||
|
`(,(car regex-char-pair)
|
||
|
(0 (prog1 ()
|
||
|
(compose-region (match-beginning 1)
|
||
|
(match-end 1)
|
||
|
;; The first argument to concat is a string containing a literal tab
|
||
|
,(concat " " (list (decode-char 'ucs (cadr regex-char-pair)))))))))
|
||
|
'(("\\(>>=\\)" #Xefb0)
|
||
|
("\\(=<<\\)" #Xefb1)
|
||
|
("\\(<\\*>\\)" #Xefb2)
|
||
|
("\\(<\\$>\\)" #Xefb3)
|
||
|
("\\(::\\)" #Xefb4)
|
||
|
("\\(:=\\)" #Xefb5)
|
||
|
("\\(<<<\\)" #Xefb6)
|
||
|
("\\(>>>\\)" #Xefb7)
|
||
|
("\\(<>\\)" #Xefb8)
|
||
|
("\\(/=\\)" #Xefb9)
|
||
|
("\\({-\\)" #Xefba)
|
||
|
("\\(-}\\)" #Xefbb)
|
||
|
("\\(<|\\)" #Xefbc)
|
||
|
("\\(|>\\)" #Xefbd)
|
||
|
("\\(~>\\)" #Xefbe)
|
||
|
("\\(<~\\)" #Xefbf)
|
||
|
("\\(<~>\\)" #Xefc0)
|
||
|
("\\(<^>\\)" #Xefc1)
|
||
|
("\\(/\\\\\\)" #Xefc2)
|
||
|
("\\(<|>\\)" #Xefc3)
|
||
|
("\\(>=>\\)" #Xefc4)
|
||
|
("\\(<=<\\)" #Xefc5))))
|
||
|
|
||
|
|
||
|
(defun add-fixedsys-excelsior-symbol-keywords ()
|
||
|
(font-lock-add-keywords nil fixedsys-excelsior-font-lock-keywords-alist))
|
||
|
|
||
|
(add-hook 'prog-mode-hook
|
||
|
#'add-fixedsys-excelsior-symbol-keywords)
|
||
|
```
|
||
|
|
||
|
|
||
|
### Sublime Text 3 (build 3146+)
|
||
|
Should be defined in the user settings as so:
|
||
|
```
|
||
|
"font_face": "Fixedsys Excelsior",
|
||
|
"font_size": 16,
|
||
|
"font_options": ["gray_antialias"]
|
||
|
```
|
||
|
|
||
|
## ToDo
|
||
|
<* *> <$ $>
|