Merge pull request #125704 from zanculmarktum/fix/kbd-search-paths

kbd: update search-paths.patch

Changed files
+109 -1
nixos
pkgs
os-specific
+1
nixos/tests/all-tests.nix
···
k3s = handleTest ./k3s.nix {};
kafka = handleTest ./kafka.nix {};
kbd-setfont-decompress = handleTest ./kbd-setfont-decompress.nix {};
+
kbd-update-search-paths-patch = handleTest ./kbd-update-search-paths-patch.nix {};
kea = handleTest ./kea.nix {};
keepalived = handleTest ./keepalived.nix {};
keepassxc = handleTest ./keepassxc.nix {};
+18
nixos/tests/kbd-update-search-paths-patch.nix
···
+
import ./make-test-python.nix ({ pkgs, ... }: {
+
name = "kbd-update-search-paths-patch";
+
+
machine = { pkgs, options, ... }: {
+
console = {
+
packages = options.console.packages.default ++ [ pkgs.terminus_font ];
+
};
+
};
+
+
testScript = ''
+
command = "${pkgs.kbd}/bin/setfont ter-112n 2>&1"
+
(status, out) = machine.execute(command)
+
pattern = re.compile(r".*Unable to find file:.*")
+
match = pattern.match(out)
+
if match:
+
raise Exception("command `{}` failed".format(command))
+
'';
+
})
+5 -1
pkgs/os-specific/linux/kbd/default.nix
···
"--disable-nls"
];
+
patches = [
+
./search-paths.patch
+
];
+
postPatch =
''
# Renaming keymaps with name clashes, because loadkeys just picks
···
nativeBuildInputs = [ autoreconfHook pkg-config flex ];
passthru.tests = {
-
inherit (nixosTests) keymap kbd-setfont-decompress;
+
inherit (nixosTests) keymap kbd-setfont-decompress kbd-update-search-paths-patch;
};
meta = with lib; {
+85
pkgs/os-specific/linux/kbd/search-paths.patch
···
+
Add /etc/kbd to the list of directories to search for the console
+
fonts, screen mappings, Unicode maps, keytable files, etc.
+
+
Without this patch, kbd will only look inside
+
/nix/store/<hash>-kbd-x.x.x/share.
+
+
--- a/src/libkeymap/analyze.l
+
+++ b/src/libkeymap/analyze.l
+
@@ -109,6 +109,9 @@ static const char *const include_dirpath1[] = {
+
NULL
+
};
+
static const char *const include_dirpath3[] = {
+
+ "/etc/kbd/" KEYMAPDIR "/include/",
+
+ "/etc/kbd/" KEYMAPDIR "/i386/include/",
+
+ "/etc/kbd/" KEYMAPDIR "/mac/include/",
+
DATADIR "/" KEYMAPDIR "/include/",
+
DATADIR "/" KEYMAPDIR "/i386/include/",
+
DATADIR "/" KEYMAPDIR "/mac/include/",
+
--- a/src/libkfont/context.c
+
+++ b/src/libkfont/context.c
+
@@ -13,6 +13,7 @@
+
/* search for the map file in these directories (with trailing /) */
+
static const char *const mapdirpath[] = {
+
"",
+
+ "/etc/kbd/" TRANSDIR "/",
+
DATADIR "/" TRANSDIR "/",
+
NULL
+
};
+
@@ -28,6 +29,7 @@ static const char *const mapsuffixes[] = {
+
/* search for the font in these directories (with trailing /) */
+
static const char *const fontdirpath[] = {
+
"",
+
+ "/etc/kbd/" FONTDIR "/",
+
DATADIR "/" FONTDIR "/",
+
NULL
+
};
+
@@ -42,6 +44,7 @@ static char const *const fontsuffixes[] = {
+
+
static const char *const unidirpath[] = {
+
"",
+
+ "/etc/kbd/" UNIMAPDIR "/",
+
DATADIR "/" UNIMAPDIR "/",
+
NULL
+
};
+
@@ -55,6 +58,7 @@ static const char *const unisuffixes[] = {
+
/* hide partial fonts a bit - loading a single one is a bad idea */
+
const char *const partfontdirpath[] = {
+
"",
+
+ "/etc/kbd/" FONTDIR "/" PARTIALDIR "/",
+
DATADIR "/" FONTDIR "/" PARTIALDIR "/",
+
NULL
+
};
+
--- a/src/loadkeys.c
+
+++ b/src/loadkeys.c
+
@@ -27,6 +27,7 @@
+
+
static const char *const dirpath1[] = {
+
"",
+
+ "/etc/kbd/" KEYMAPDIR "/**",
+
DATADIR "/" KEYMAPDIR "/**",
+
KERNDIR "/",
+
NULL
+
--- a/src/resizecons.c
+
+++ b/src/resizecons.c
+
@@ -104,6 +104,7 @@ static void vga_set_verticaldisplayend_lowbyte(int);
+
+
const char *const dirpath[] = {
+
"",
+
+ "/etc/kbd/" VIDEOMODEDIR "/",
+
DATADIR "/" VIDEOMODEDIR "/",
+
NULL
+
};
+
--- a/src/setfont.c
+
+++ b/src/setfont.c
+
@@ -48,8 +48,8 @@ usage(void)
+
" -v Be verbose.\n"
+
" -C <cons> Indicate console device to be used.\n"
+
" -V Print version and exit.\n"
+
- "Files are loaded from the current directory or %s/*/.\n"),
+
- DATADIR);
+
+ "Files are loaded from the current directory or %s/*/ or %s/*/.\n"),
+
+ DATADIR, "/etc/kbd");
+
exit(EX_USAGE);
+
}
+