Skip to content

Commit

Permalink
Add editor.font option for kate (#269)
Browse files Browse the repository at this point in the history
  • Loading branch information
HeitorAugustoLN authored Jul 22, 2024
1 parent a462bca commit edef1f7
Showing 1 changed file with 209 additions and 0 deletions.
209 changes: 209 additions & 0 deletions modules/apps/kate/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,200 @@ let
'';

script = pkgs.writeScript "kate-check" (checkThemeName cfg.editor.theme.name);

qfont = import ../../../lib/qfont.nix { inherit lib; };

styleStrategyType = lib.types.submodule {
options = with qfont.styleStrategy; {
prefer = lib.mkOption {
type = prefer;
default = "default";
description = ''
Which type of font is preferred by the font when finding an appropriate default family.
`default`, `bitmap`, `device`, `outline`, `forceOutline` correspond to the
`PreferDefault`, `PreferBitmap`, `PreferDevice`, `PreferOutline`, `ForceOutline` enum flags
respectively.
'';
};
matchingPrefer = lib.mkOption {
type = matchingPrefer;
default = "default";
description = ''
Whether the font matching process prefers exact matches, of best quality matches.
`default` corresponds to not setting any enum flag, and `exact` and `quality`
correspond to `PreferMatch` and `PreferQuality` enum flags respectively.
'';
};
antialiasing = lib.mkOption {
type = antialiasing;
default = "default";
description = ''
Whether antialiasing is preferred for this font.
`default` corresponds to not setting any enum flag, and `prefer` and `disable`
correspond to `PreferAntialias` and `NoAntialias` enum flags respectively.
'';
};
noSubpixelAntialias = lib.mkOption {
type = lib.types.bool;
default = false;
description = ''
If set to true, this font will try to avoid subpixel antialiasing.
Corresponds to the `NoSubpixelAntialias` enum flag.
'';
};
noFontMerging = lib.mkOption {
type = lib.types.bool;
default = false;
description = ''
If set to true, this font will not try to find a substitute font when encountering missing glyphs.
Corresponds to the `NoFontMerging` enum flag.
'';
};
preferNoShaping = lib.mkOption {
type = lib.types.bool;
default = false;
description = ''
If set to true, this font will not try to apply shaping rules that may be required for some scripts
(e.g. Indic scripts), increasing performance if these rules are not required.
Corresponds to the `PreferNoShaping` enum flag.
'';
};
};
};

fontType = lib.types.submodule {
options = {
family = lib.mkOption {
type = lib.types.str;
description = "The font family of this font.";
example = "Noto Sans";
};
pointSize = lib.mkOption {
type = lib.types.nullOr lib.types.numbers.positive;
default = null;
description = ''
The point size of this font.
Could be a decimal, but usually an integer. Mutually exclusive with pixel size.
'';
};
pixelSize = lib.mkOption {
type = lib.types.nullOr lib.types.ints.u16;
default = null;
description = ''
The pixel size of this font.
Mutually exclusive with point size.
'';
};
styleHint = lib.mkOption {
type = qfont.styleHint;
default = "anyStyle";
description = ''
The style hint of this font.
See https://doc.qt.io/qt-6/qfont.html#StyleHint-enum for more.
'';
};
weight = lib.mkOption {
type = lib.types.either (lib.types.ints.between 1 1000) qfont.weight;
default = "normal";
description = ''
The weight of the font, either as a number between 1 to 1000 or as a pre-defined weight string.
See https://doc.qt.io/qt-6/qfont.html#Weight-enum for more.
'';
};
style = lib.mkOption {
type = qfont.style;
default = "normal";
description = "The style of the font.";
};
underline = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Whether the font is underlined.";
};
strikeOut = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Whether the font is struck out.";
};
fixedPitch = lib.mkOption {
type = lib.types.bool;
default = false;
description = "Whether the font has a fixed pitch.";
};
capitalization = lib.mkOption {
type = qfont.capitalization;
default = "mixedCase";
description = ''
The capitalization settings for this font.
See https://doc.qt.io/qt-6/qfont.html#Capitalization-enum for more.
'';
};
letterSpacingType = lib.mkOption {
type = qfont.spacingType;
default = "percentage";
description = ''
Whether to use percentage or absolute spacing for this font.
See https://doc.qt.io/qt-6/qfont.html#SpacingType-enum for more.
'';
};
letterSpacing = lib.mkOption {
type = lib.types.number;
default = 0;
description = ''
The amount of letter spacing for this font.
Could be a percentage or an absolute spacing change (positive increases spacing, negative decreases spacing),
based on the selected `letterSpacingType`.
'';
};
wordSpacing = lib.mkOption {
type = lib.types.number;
default = 0;
description = ''
The amount of word spacing for this font, in pixels.
Positive values increase spacing while negative ones decrease spacing.
'';
};
stretch = lib.mkOption {
type = lib.types.either (lib.types.ints.between 1 4000) qfont.stretch;
default = "anyStretch";
description = ''
The stretch factor for this font, as an integral percentage (i.e. 150 means a 150% stretch),
or as a pre-defined stretch factor string.
'';
};
styleStrategy = lib.mkOption {
type = styleStrategyType;
default = { };
description = ''
The strategy for matching similar fonts to this font.
See https://doc.qt.io/qt-6/qfont.html#StyleStrategy-enum for more.
'';
};
styleName = lib.mkOption {
type = lib.types.nullOr lib.types.str;
default = null;
description = ''
The style name of this font, overriding the `style` and `weight` parameters when set.
Used for special fonts that have styles beyond traditional settings.
'';
};
};
};
in
{
options.programs.kate = {
Expand Down Expand Up @@ -101,6 +295,20 @@ in
default = true;
type = lib.types.bool;
};

font = lib.mkOption {
type = fontType;
default = {
family = "Hack";
pointSize = 10;
};
example = {
family = "Fira Code";
pointSize = 11;
};
description = "The font settings for the editor.";
apply = qfont.fontToString;
};
};
};

Expand Down Expand Up @@ -244,6 +452,7 @@ in
# Do not touch the theme settings otherwise
"Auto Color Theme Selection" = lib.mkIf (cfg.editor.theme.name != "") false;
"Color Theme" = lib.mkIf (cfg.editor.theme.name != "") cfg.editor.theme.name;
"Text Font" = cfg.editor.font;
};

"KTextEditor View" = {
Expand Down

0 comments on commit edef1f7

Please sign in to comment.