vihangd / Cozette

A bitmap programming font optimized for coziness πŸ’œ

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Cozette

GitHub release (latest by date) AUR version GitHub Workflow Status GitHub All Releases GitHub license

Cozette

A bitmap programming font optimized for coziness.

Contents

About Cozette

Cozette is a 6x13px (bounding box; average 5px character width, 3px descent, 10px ascent, 8px cap height) bitmap font based on Dina, which itself is based on Proggy. It's also heavily inspired by Creep. I absolutely adore Creep, and was using it up until I got a higher-DPI screen for which it was slightly too small. That prompted me to make the bitmap font I always wished existed: Cozette; a small-but-not-tiny bitmap font with great coverage of all the glyphs you might encounter in the terminal:

glyphs in Cozette

I'm intentionally putting the emphasis on "you" - although Cozette already has all the glyphs I've seen in my CLI tools so far, you might find it's missing a glyph you wish it had. If that's the case, please file an issue! It's an important goal for Cozette to be a useful bitmap alternative to Nerd Fonts.

A nicer character map that includes the codepoints can be found at the bottom of this README!

Installation

You can get Cozette over at the Releases tab!

Cozette is distributed in two main variants: bitmap and vector.

Bitmap fonts are, effectively, just that - bitmaps. They scale terribly, but look nice and sharp (and pixel-perfect) at one specific point size. Vector fonts scale well, but in this case, might look ugly at smaller point sizes because of antialiasing issues and the like.

Linux

The preferred format is .otb (for bitmaps) or .ttf (for CozetteVector). To install the font, just throw it in your fonts directory (you probably want to follow your distro's instructions). On Ubuntu, if you don't want to reconsider your distro choice, you might need to specifically enable bitmap fonts.

If you're on Arch, ifreund made an AUR package for the .otb! Install it using your AUR helper of choice:

$ yay -S cozette-otb

Or, if you're not using an AUR helper:

$ git clone https://aur.archlinux.org/cozette-otb.git
$ cd cozette-otb
$ makepkg -si

Mac

Download the .dfont and install it with Font Book .app. Both the bitmap Cozette.dfont and the vector CozetteVector.dfont should work.

Windows

Grab CozetteVector.ttf. If you want to get the bitmap versions to work, follow the instructions from here.

BSD / Solaris / Haku /Other

You know what you're doing.

Notes on specific applications

VSCode, general GUI applications

VSCode and a lot of other GUI applications don't support bitmap fonts, so you will want to use CozetteVector there. In applications that do support bitmap fonts, you will want to use the normal, bitmap Cozette (unless it's too small for you, in which case, CozetteVector scales better).

Kitty

4e554c4c made an AUR package for kitty patched to support bitmap fonts.

if you like bitmap fonts, kitty is not for you.

According to its author, kitty doesn't, and never will, support bitmap fonts.

If you really want to get Cozette working, you can try the AUR package mentioned above, or apply the patch there yourself.

If that doesn't work, you can try the trick from here; if you explicitly set Cozette(Vector)'s spacing to 100, and scalable to true in fontconfig, kitty should accept it.

You can also make Cozette work flawlessly by uninstalling kitty and using a terminal emulator for which not rendering fonts isn't a design principle - I cannot recommend alacritty enough. it's excellent, has worked flawlessly for me for quite some time, and both configuring and getting bitmap fonts to work in it is a breeze.

(The support was discussed in slavfox/Cozette#18. Many thanks to all the participants there, especially to to Luflosi, who brought up flipping the allow_bitmapped_fonts flag in their fork, and to 4e554c4c, who made the AUR package.)

Roadmap

Check the CHANGELOG for the latest news!

Here's where Cozette is so far, in the rough order the features are going to be implemented:

  • ASCII
  • Powerline
  • Build scripts to handle exporting
  • Box-drawing (mostly)
  • Braille
  • Cyrillic!
  • Nerdfonts:
    • nf-pom-*
    • nf-seti-*
    • nf-dev-* (partial)
    • nf-weather-*
  • Glyph map generation (so I don't have to keep characters.png up to date)
  • "True" TTF version
    • Windows support
  • Full vim-airline support!
  • Full ranger_devicons support!
  • starship supported out of the box!
  • Full powerlevel10k support! (if it doesn't work, try setting POWERLEVEL9K_MODE to nerdfont-complete)
  • Charmap including the code points (to make it easier for users to report issues/request additions)
  • Bold version
  • Italic version
  • Ligatures

Recommended alternatives

Cozette is, intentionally, a very small font. If you're looking for other bitmap fonts with extra glyphs, a couple of my favorites are Tamzen and Envypn. You might also find the Tecate/bitmap-fonts repo useful.

Character map

For easy copy-pasting, the character map is provided in text form in img/charmap.txt. If you just want to see how the glyphs look in Cozette, here is a screenshot of it:

Character map

Building

If you want to build Cozette yourself, you'll need FontForge. Once you have that, just clone this repo, open Cozette/Cozette.sfd in FontForge, and go to File β†’ Generate Fonts....

To run the build scripts I use to prepare releases, first install Python 3.8 and pipenv. For generating the images, you will also need xorg-mkfontscale and xterm. Then, install the dependencies and run build.py fonts:

$ pipenv install
$ pipenv run python3.8 build.py fonts

Then install the generated fonts, and run

$ pipenv run python3.8 build.py images

Running

$ pipenv run python3.8 build.py changelog

will output the changelog between your local version and the last tag.

License

Cozette is licensed MIT πŸ’œ

Massive thanks to ym1234 for helping me figure out how to make the font tables behave nicely.

Additional thanks to autumn and cpkio for contributing characters!

About

A bitmap programming font optimized for coziness πŸ’œ

License:MIT License


Languages

Language:Python 100.0%