cascadia-code
This is a fun, new monospaced font that includes programming ligatures and is designed to enhance the modern look and feel of the Windows Terminal.
Top Related Projects
Free monospaced font with programming ligatures
JetBrains Mono – the free and open-source typeface for developers
Monospaced font family for user interface and coding environments
Versatile typeface for code, from code.
The package of IBM’s typeface, IBM Plex.
Quick Overview
Cascadia Code is a monospaced font designed by Microsoft specifically for modern development environments and terminal applications. It features programming ligatures, a wide range of Unicode symbols, and is optimized for readability in coding scenarios.
Pros
- Includes programming ligatures for improved code readability
- Supports a wide range of Unicode characters and programming symbols
- Designed with modern IDEs and terminal applications in mind
- Open-source and freely available for use
Cons
- May not be suitable for all programming styles or preferences
- Ligatures can sometimes cause confusion for beginners
- Limited customization options compared to some other programming fonts
- Requires manual installation on some systems
Getting Started
To use Cascadia Code in your development environment:
- Download the font files from the GitHub releases page.
- Install the font on your system:
- Windows: Right-click the font file and select "Install"
- macOS: Double-click the font file and click "Install Font"
- Linux: Copy the font file to
~/.local/share/fonts/
and runfc-cache -f -v
- Configure your IDE or terminal application to use Cascadia Code as the default font.
For example, in Visual Studio Code, add the following to your settings.json
:
{
"editor.fontFamily": "'Cascadia Code', Consolas, 'Courier New', monospace",
"editor.fontLigatures": true
}
Competitor Comparisons
Free monospaced font with programming ligatures
Pros of FiraCode
- Wider range of ligatures and programming symbols
- Longer development history and more established user base
- Available in multiple weights (Light, Regular, Medium, Bold)
Cons of FiraCode
- Less focus on readability at smaller sizes
- Fewer stylistic alternates and customization options
- Not specifically designed for Windows terminal environments
Code Comparison
FiraCode:
if (x => 0 && x <= 10) {
console.log("x is between 0 and 10");
}
Cascadia Code:
if (x >= 0 && x <= 10) {
console.log("x is between 0 and 10");
}
The main difference in this example is the rendering of the >=
operator. FiraCode uses a single ligature for =>
, while Cascadia Code maintains separate characters for better readability.
Both fonts offer excellent programming-focused features, but FiraCode provides a broader range of ligatures and has been around longer. Cascadia Code, on the other hand, is optimized for Windows environments and offers better readability at smaller sizes. The choice between the two often comes down to personal preference and specific use cases.
JetBrains Mono – the free and open-source typeface for developers
Pros of JetBrainsMono
- More extensive ligature support, enhancing code readability
- Wider range of supported languages and special characters
- Optimized for various IDEs and text editors beyond JetBrains products
Cons of JetBrainsMono
- Less focus on terminal-specific optimizations compared to Cascadia Code
- May not integrate as seamlessly with Windows Terminal and other Microsoft products
- Slightly narrower character width, which some developers may find less comfortable for extended coding sessions
Code Comparison
JetBrainsMono:
def example_function():
return [x for x in range(10) if x % 2 == 0]
Cascadia Code:
def example_function():
return [x for x in range(10) if x % 2 == 0]
While both fonts render code clearly, JetBrainsMono's ligatures make certain combinations like ==
more distinct, potentially improving code readability. Cascadia Code, on the other hand, maintains a slightly wider character width, which some developers prefer for extended coding sessions.
Both fonts are excellent choices for programming, with JetBrainsMono offering more extensive language support and ligatures, while Cascadia Code provides better integration with Microsoft products and a focus on terminal use.
Monospaced font family for user interface and coding environments
Pros of Source Code Pro
- Longer development history, more mature and stable
- Wider range of weights and styles available
- Extensive language support with multiple scripts
Cons of Source Code Pro
- Less focus on modern coding-specific features
- May not render as crisply on some displays
- Fewer ligatures and programming-oriented glyphs
Code Comparison
Source Code Pro:
if (condition) {
doSomething();
} else {
doSomethingElse();
}
Cascadia Code:
if (condition) {
doSomething();
} else {
doSomethingElse();
}
While the code appears identical, Cascadia Code offers programming ligatures that can transform certain character combinations (e.g., >=
, !=
, =>
) into single, more readable glyphs. Source Code Pro maintains traditional character rendering, which some developers prefer for clarity and consistency across different environments.
Both fonts are excellent choices for coding, with Source Code Pro offering a classic, widely-supported option and Cascadia Code providing a more modern, feature-rich alternative tailored specifically for programming needs.
Versatile typeface for code, from code.
Pros of Iosevka
- Highly customizable with numerous build options
- Supports a wide range of languages and scripts
- Compact design, ideal for coding in limited screen space
Cons of Iosevka
- Requires building from source for custom variants
- May have a steeper learning curve due to extensive customization options
- Less conventional appearance, which some users may find less readable
Code Comparison
Cascadia Code:
function example() {
let x = 10;
console.log(`The value is ${x}`);
}
Iosevka:
function example() {
let x = 10;
console.log(`The value is ${x}`);
}
Summary
Iosevka offers extensive customization and language support, making it versatile for various coding needs. However, it requires more setup and may not suit everyone's aesthetic preferences. Cascadia Code, while less customizable, provides a more conventional and readily usable coding font out of the box.
Both fonts are monospaced and designed for coding, but their visual styles differ. Iosevka tends to be narrower and more compact, while Cascadia Code has a more traditional appearance with optional ligatures. The choice between them often comes down to personal preference and specific use cases.
The package of IBM’s typeface, IBM Plex.
Pros of Plex
- Offers a wider variety of font styles and weights
- Supports a broader range of languages and scripts
- Provides both serif and sans-serif options
Cons of Plex
- Larger file sizes due to extensive character sets
- May require more system resources to render
Code Comparison
While both Cascadia Code and Plex are primarily font projects, they don't contain comparable code. However, here's an example of how to use each font in CSS:
Cascadia Code:
body {
font-family: 'Cascadia Code', monospace;
}
Plex:
body {
font-family: 'IBM Plex Sans', sans-serif;
}
Summary
Plex offers a more comprehensive font family with greater language support and style options, making it suitable for diverse design needs. However, this comes at the cost of larger file sizes. Cascadia Code, while more focused, excels as a monospaced font for coding environments. The choice between the two depends on specific use cases and design requirements.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
About Cascadia Code
Cascadia is a fun new coding font that comes bundled with Windows Terminal, and is now the default font in Visual Studio as well.
Font Variants
Cascadia Code
: standard version of CascadiaCascadia Mono
: a version of Cascadia that doesn't have ligaturesCascadia (Code|Mono) PL
: a version of Cascadia that has embedded Powerline symbolsCascadia (Code|Mono) NF
: a version of Cascadia that has Nerd Font symbols
For the italic, there is a standard italic
and a cursive
variant accessible via ss01
(see below).
Font features
Enabling stylistic sets will vary between applications. For example, in VS Code, you can enable stylistic sets (and other OpenType features) via settings.json
:
"editor.fontLigatures": "'ss01', 'ss02', 'ss03', 'ss19', 'ss20'"
To enable the Cursive form of the italic, here's the code you should use:
"editor.fontLigatures": "'calt', 'ss01'",
If you're using an environment that does not support the ss01
OT feature, one option to consider is opentype-feature-freezer.
Character Sets
Installation
You can download the latest version of Cascadia Code from the releases page here: https://github.com/microsoft/cascadia-code/releases
Font formats:
ttf variable
: we recommend this version for all users, and particularly those on Windows or any other OS that employs TrueType hinting. It offers the greatest diversity of weight options (anything from 200-700).ttf static
: in the rare situation where the above variable font version is not supported, or a singular weight is preferred to the entire range, static formats are supplied. However, please note they do not have the same degree of hinting quality as the variable font versions.otf static
: for users who prefer OTF format fonts, otf static instances are provided. At this time we do not have a variable font OTF version.WOFF2
: These versions are provided for the purposes of web use, and are available both as variable fonts, and static instances.
Once unzipped, right-click the font file and click Install for all users
. This will install the font onto your machine.
ð Note: If you have previously installed a version of Cascadia Code, please uninstall the previous version prior to installing a new version. Not doing so can result in improper rendering.
For more details and app-specific instructions, please check the wiki.
Get involved
Instructions on how to modify and submit an update to the Cascadia Code source is available in the wiki.
Communicating with the Team
The easiest way to communicate with the team is via GitHub Issues. Please file new issues, feature requests and suggestions, but DO search for similar open/closed pre-existing issues before you do.
Please help us keep this repository clean, inclusive, and fun! We will not tolerate any abusive, rude, disrespectful or inappropriate behavior. Read our Code of Conduct for more details.
If you would like to ask a question that you feel doesn't warrant an issue (yet), please reach out to us via Twitter:
Aaron Bell, Font Designer: @aaronbell
Christopher Nguyen, Product Manager: @nguyen_dows
Dustin Howett, Software Engineer: @DHowett
Special thanks to:
- Fira Code â OpenType code for the coding ligatures â github
- Nerd Fonts â Centralizing app iconography â github
- Viktoriya Grabowska â Designer of Cyrillic Italic and Consultant â @vika_grabowska
- Mohamad Dakak - Arabic designer - @mohamaddakak
- Liron Lavi Turkenich - Hebrew designer - @LironLaviTur
- Gerry Leonidas â Greek Consultant â @gerryleonidas
- Donny TrÆ°Æ¡ng â Vietnamese Consultant â Vietnamese Typography
Code of Conduct
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
Top Related Projects
Free monospaced font with programming ligatures
JetBrains Mono – the free and open-source typeface for developers
Monospaced font family for user interface and coding environments
Versatile typeface for code, from code.
The package of IBM’s typeface, IBM Plex.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot