Fonts: Difference between revisions
m changed the example font configuration ('noto-fonts-cjk' has been renamed renamed to 'noto-fonts-cjk-sans') |
|||
(6 intermediate revisions by 4 users not shown) | |||
Line 12: | Line 12: | ||
fonts.packages = with pkgs; [ | fonts.packages = with pkgs; [ | ||
noto-fonts | noto-fonts | ||
noto-fonts-cjk | noto-fonts-cjk-sans | ||
noto-fonts-emoji | noto-fonts-emoji | ||
liberation_ttf | liberation_ttf | ||
Line 29: | Line 29: | ||
* <code>fonts.enableGhostscriptFonts</code>: affects the <code>ghostscript</code> package. Ghostscript packages some URW fonts for the standard PostScript typefaces. If <code>true</code>, these fonts will be visible to GUI applications. You could set it to <code>true</code> if you want these fonts, but <code>gyre-fonts</code> (part of <code>fonts.enableDefaultPackages</code>) might be higher-quality depending on your judgement. | * <code>fonts.enableGhostscriptFonts</code>: affects the <code>ghostscript</code> package. Ghostscript packages some URW fonts for the standard PostScript typefaces. If <code>true</code>, these fonts will be visible to GUI applications. You could set it to <code>true</code> if you want these fonts, but <code>gyre-fonts</code> (part of <code>fonts.enableDefaultPackages</code>) might be higher-quality depending on your judgement. | ||
=== Installing | === Installing all nerdfonts === | ||
The <code>nerdfonts</code> package includes all fonts from the [https://www.nerdfonts.com/ Nerd Fonts repository], making it quite large and resulting in a longer installation time. If you want to install the entire collection, add the following line to your system configuration:{{file|/etc/nixos/configuration.nix|nix|3=fonts.packages = with pkgs; [ nerdfonts ];}} | |||
=== Installing specific nerdfonts === | |||
If you only need a selection of fonts from the package, you can overwrite the font selection like so: | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
Line 39: | Line 42: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
This will cause NixOS to download only the [https://github.com/ryanoasis/nerd-fonts/tree/master/patched-fonts/FiraCode Fira Code] and [https://github.com/ryanoasis/nerd-fonts/tree/master/patched-fonts/DroidSansMono Droid Sans Mono] fonts from [https://github.com/ryanoasis/nerd-fonts nerd-fonts] instead of the whole package. The relevant names can be found by looking | This will cause NixOS to download only the [https://github.com/ryanoasis/nerd-fonts/tree/master/patched-fonts/FiraCode Fira Code] and [https://github.com/ryanoasis/nerd-fonts/tree/master/patched-fonts/DroidSansMono Droid Sans Mono] fonts from [https://github.com/ryanoasis/nerd-fonts nerd-fonts] instead of the whole package. The relevant names can be found by looking [https://github.com/NixOS/nixpkgs/blob/8764d898c4f365d98ef77af140b32c6396eb4e02/pkgs/data/fonts/nerdfonts/shas.nix at the list of the nerdfonts names in this commit]. | ||
For configurations using later versions of Nixpkgs (after 25.05), individual Nerd Fonts packages can be installed like so:<syntaxhighlight lang="nix"> | |||
fonts.packages = with pkgs; [ | |||
nerd-fonts.fira-code | |||
nerd-fonts.droid-sans-mono | |||
]; | |||
</syntaxhighlight> | |||
=== Let Fontconfig know the fonts within your Nix profile === | === Let Fontconfig know the fonts within your Nix profile === | ||
Line 154: | Line 164: | ||
=== Flatpak applications can't find system fonts === | === Flatpak applications can't find system fonts === | ||
To expose available fonts under <code>/run/current-system/sw/share/X11/fonts</code>, enable <code>fontDir</code> in your NixOS configuration. | |||
<syntaxhighlight lang="nix"> | <syntaxhighlight lang="nix"> | ||
fonts.fontDir.enable = true; | fonts.fontDir.enable = true; | ||
</syntaxhighlight> | </syntaxhighlight>You will then need to link/copy this folder to one of the Flatpak-supported locations - see below. | ||
==== | ==== Solution 1: Copy fonts to <code>$HOME/.local/share/fonts</code> ==== | ||
Create fonts directory <code>$HOME/.local/share/fonts</code> and copy system fonts with option <code>-L, --dereference</code> | Create fonts directory <code>$HOME/.local/share/fonts</code> and copy system fonts with option <code>-L, --dereference</code>. You will need to repeat this step whenever the fonts change.<syntaxhighlight lang="bash"> | ||
mkdir $HOME/.local/share/fonts && cp -L /run/current-system/sw/share/X11/fonts/* $HOME/.local/share/fonts/ | mkdir $HOME/.local/share/fonts && cp -L /run/current-system/sw/share/X11/fonts/* $HOME/.local/share/fonts/ | ||
</syntaxhighlight>Note: There is | </syntaxhighlight>Note: There is no need to grant flatpak applications access to <code>$HOME/.local/share/fonts</code>. | ||
Instead, if you do that, some applications (for example, steam) won't work.<blockquote>Internals: How it works? | Instead, if you do that, some applications (for example, steam) won't work.<blockquote>Internals: How it works? | ||
Line 179: | Line 189: | ||
</syntaxhighlight>Then flatpak application can read fonts from that to display contents correctly.</blockquote> | </syntaxhighlight>Then flatpak application can read fonts from that to display contents correctly.</blockquote> | ||
==== | ==== Solution 2: Symlink to system fonts at <code>$HOME/.local/share/fonts</code> ==== | ||
<blockquote>'''Note:''' this method doesn't work for some flatpak applications (for example, steam)! | <blockquote>'''Note:''' this method doesn't work for some flatpak applications (for example, steam)! | ||
Line 191: | Line 201: | ||
Now you have two options. | Now you have two options. | ||
===== Option 1: | ===== Option 1: Allow access to the fonts folder and <code>/nix/store</code> ===== | ||
By using the Flatpak CLI or the Flatseal Flatpak make the following directory available to all Flatpaks <code>$HOME/.local/share/fonts</code> and <code>$HOME/.icons</code> the appropriate commands for this are: | By using the Flatpak CLI or the Flatseal Flatpak make the following directory available to all Flatpaks <code>$HOME/.local/share/fonts</code> and <code>$HOME/.icons</code> the appropriate commands for this are: | ||
Line 206: | Line 216: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
===== Option 2: | ===== Option 2: Allow access to the WHOLE filesystem ===== | ||
Allow them access the WHOLE filesystem of yours: <code>All system files</code> in Flatseal or equivalently <code>filesystem=host</code> available to your application, the command for this is: | Allow them access the WHOLE filesystem of yours: <code>All system files</code> in Flatseal or equivalently <code>filesystem=host</code> available to your application, the command for this is: | ||
Line 215: | Line 225: | ||
It is important to keep in mind that some flatpak apps may refuse to launch if given certain permissions, such as the Steam flatpak. | It is important to keep in mind that some flatpak apps may refuse to launch if given certain permissions, such as the Steam flatpak. | ||
=== | ==== Solution 3: Configure bindfs for fonts/cursors/icons support ==== | ||
Alternatively, you can expose relevant packages directly under <code>/usr/share/...</code> paths. This will also enable Flatpak to use a custom cursor theme if you have one. This solution doesn't require <code>fonts.fontDir.enable</code> to be enabled.<syntaxhighlight lang="nix"> | |||
system.fsPackages = [ pkgs.bindfs ]; | |||
fileSystems = let | fileSystems = let | ||
mkRoSymBind = path: { | mkRoSymBind = path: { | ||
Line 225: | Line 235: | ||
options = [ "ro" "resolve-symlinks" "x-gvfs-hide" ]; | options = [ "ro" "resolve-symlinks" "x-gvfs-hide" ]; | ||
}; | }; | ||
aggregated = pkgs.buildEnv { | |||
name = "system-fonts-and-icons"; | |||
paths = config.fonts.packages ++ (with pkgs; [ | |||
# Add your cursor themes and icon packages here | |||
bibata-cursors | |||
gnome.gnome-themes-extra | |||
# etc. | |||
]); | |||
pathsToLink = [ "/share/fonts" "/share/icons" ]; | |||
}; | }; | ||
in { | in { | ||
"/usr/share/ | "/usr/share/fonts" = mkRoSymBind "${aggregated}/share/fonts"; | ||
"/usr | "/usr/share/icons" = mkRoSymBind "${aggregated}/share/icons"; | ||
}; | }; | ||
fonts | fonts.packages = with pkgs; [ | ||
noto-fonts | |||
noto-fonts-emoji | |||
noto-fonts-cjk | |||
]; | |||
</syntaxhighlight> | </syntaxhighlight> | ||
=== Noto Color Emoji doesn't render on Firefox === | === Noto Color Emoji doesn't render on Firefox === | ||
Line 264: | Line 266: | ||
[[Category:Configuration]] | [[Category:Configuration]] | ||
[[Category:Desktop]] | [[Category:Desktop]] | ||
[[Category:Fonts]] |