sddm: take themes from system environment
This commit is contained in:
parent
be7b7d908f
commit
870c07cc2b
@ -190,7 +190,6 @@ in
|
|||||||
|
|
||||||
services.xserver.displayManager.sddm = {
|
services.xserver.displayManager.sddm = {
|
||||||
theme = "breeze";
|
theme = "breeze";
|
||||||
package = pkgs.sddmPlasma5;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
security.pam.services.kde = { allowNullPassword = true; };
|
security.pam.services.kde = { allowNullPassword = true; };
|
||||||
|
@ -9,7 +9,7 @@ let
|
|||||||
cfg = dmcfg.sddm;
|
cfg = dmcfg.sddm;
|
||||||
xEnv = config.systemd.services."display-manager".environment;
|
xEnv = config.systemd.services."display-manager".environment;
|
||||||
|
|
||||||
sddm = cfg.package;
|
inherit (pkgs) sddm;
|
||||||
|
|
||||||
xserverWrapper = pkgs.writeScript "xserver-wrapper" ''
|
xserverWrapper = pkgs.writeScript "xserver-wrapper" ''
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
@ -37,8 +37,8 @@ let
|
|||||||
|
|
||||||
[Theme]
|
[Theme]
|
||||||
Current=${cfg.theme}
|
Current=${cfg.theme}
|
||||||
ThemeDir=${sddm}/share/sddm/themes
|
ThemeDir=/run/current-system/sw/share/sddm/themes
|
||||||
FacesDir=${sddm}/share/sddm/faces
|
FacesDir=/run/current-system/sw/share/sddm/faces
|
||||||
|
|
||||||
[Users]
|
[Users]
|
||||||
MaximumUid=${toString config.ids.uids.nixbld}
|
MaximumUid=${toString config.ids.uids.nixbld}
|
||||||
@ -105,15 +105,6 @@ in
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
package = mkOption {
|
|
||||||
type = types.package;
|
|
||||||
default = pkgs.sddm;
|
|
||||||
description = ''
|
|
||||||
The SDDM package to install.
|
|
||||||
The default package can be overridden to provide extra themes.
|
|
||||||
'';
|
|
||||||
};
|
|
||||||
|
|
||||||
autoNumlock = mkOption {
|
autoNumlock = mkOption {
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = false;
|
default = false;
|
||||||
@ -205,7 +196,13 @@ in
|
|||||||
services.xserver.displayManager.job = {
|
services.xserver.displayManager.job = {
|
||||||
logsXsession = true;
|
logsXsession = true;
|
||||||
|
|
||||||
execCmd = "exec ${sddm}/bin/sddm";
|
environment = {
|
||||||
|
# Take themes system environment
|
||||||
|
NIX_PROFILES = "/run/current-system/sw";
|
||||||
|
XDG_DATA_DIRS = "/run/current-system/sw/share";
|
||||||
|
};
|
||||||
|
|
||||||
|
execCmd = "exec /run/current-system/sw/bin/sddm";
|
||||||
};
|
};
|
||||||
|
|
||||||
security.pam.services = {
|
security.pam.services = {
|
||||||
@ -254,7 +251,8 @@ in
|
|||||||
|
|
||||||
users.extraGroups.sddm.gid = config.ids.gids.sddm;
|
users.extraGroups.sddm.gid = config.ids.gids.sddm;
|
||||||
|
|
||||||
services.dbus.packages = [ sddm.unwrapped ];
|
environment.systemPackages = [ sddm ];
|
||||||
|
services.dbus.packages = [ sddm ];
|
||||||
|
|
||||||
# To enable user switching, allow sddm to allocate TTYs/displays dynamically.
|
# To enable user switching, allow sddm to allocate TTYs/displays dynamically.
|
||||||
services.xserver.tty = null;
|
services.xserver.tty = null;
|
||||||
|
@ -1,121 +1,72 @@
|
|||||||
{ stdenv, lib, makeQtWrapper, fetchFromGitHub, fetchpatch
|
{ mkDerivation, lib, copyPathsToStore, fetchFromGitHub, fetchpatch
|
||||||
, cmake, extra-cmake-modules, pkgconfig, libxcb, libpthreadstubs, lndir
|
, cmake, extra-cmake-modules, pkgconfig, libxcb, libpthreadstubs, lndir
|
||||||
, libXdmcp, libXau, qtbase, qtdeclarative, qttools, pam, systemd
|
, libXdmcp, libXau, qtbase, qtdeclarative, qttools, pam, systemd
|
||||||
, themes
|
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
version = "0.14.0";
|
version = "0.14.0";
|
||||||
|
|
||||||
unwrapped = stdenv.mkDerivation rec {
|
/* Fix display of user avatars. */
|
||||||
name = "sddm-unwrapped-${version}";
|
patchFixUserAvatars = fetchpatch {
|
||||||
|
url = https://github.com/sddm/sddm/commit/ecb903e48822bd90650bdd64fe80754e3e9664cb.patch;
|
||||||
src = fetchFromGitHub {
|
sha256 = "0zm88944pwdad8grmv0xwnxl23xml85ryc71x2xac233jxdyx6ms";
|
||||||
owner = "sddm";
|
|
||||||
repo = "sddm";
|
|
||||||
rev = "v${version}";
|
|
||||||
sha256 = "0wwid23kw0725zpw67zchalg9mmharr7sn4yzhijq7wqpsczjfxj";
|
|
||||||
};
|
|
||||||
|
|
||||||
patches = [
|
|
||||||
./0001-ignore-config-mtime.patch
|
|
||||||
(fetchpatch { /* Fix display of user avatars. */
|
|
||||||
url = https://github.com/sddm/sddm/commit/ecb903e48822bd90650bdd64fe80754e3e9664cb.patch;
|
|
||||||
sha256 = "0zm88944pwdad8grmv0xwnxl23xml85ryc71x2xac233jxdyx6ms";
|
|
||||||
})
|
|
||||||
];
|
|
||||||
|
|
||||||
postPatch =
|
|
||||||
# Module Qt5::Test must be included in `find_package` before it is used.
|
|
||||||
''
|
|
||||||
sed -i CMakeLists.txt -e '/find_package(Qt5/ s|)| Test)|'
|
|
||||||
'';
|
|
||||||
|
|
||||||
nativeBuildInputs = [ cmake extra-cmake-modules pkgconfig qttools ];
|
|
||||||
|
|
||||||
buildInputs = [
|
|
||||||
libxcb libpthreadstubs libXdmcp libXau pam systemd
|
|
||||||
];
|
|
||||||
|
|
||||||
propagatedBuildInputs = [
|
|
||||||
qtbase qtdeclarative
|
|
||||||
];
|
|
||||||
|
|
||||||
cmakeFlags = [
|
|
||||||
"-DCONFIG_FILE=/etc/sddm.conf"
|
|
||||||
# Set UID_MIN and UID_MAX so that the build script won't try
|
|
||||||
# to read them from /etc/login.defs (fails in chroot).
|
|
||||||
# The values come from NixOS; they may not be appropriate
|
|
||||||
# for running SDDM outside NixOS, but that configuration is
|
|
||||||
# not supported anyway.
|
|
||||||
"-DUID_MIN=1000"
|
|
||||||
"-DUID_MAX=29999"
|
|
||||||
];
|
|
||||||
|
|
||||||
preConfigure = ''
|
|
||||||
export cmakeFlags="$cmakeFlags -DQT_IMPORTS_DIR=$out/$qtQmlPrefix -DCMAKE_INSTALL_SYSCONFDIR=$out/etc -DSYSTEMD_SYSTEM_UNIT_DIR=$out/lib/systemd/system"
|
|
||||||
'';
|
|
||||||
|
|
||||||
enableParallelBuilding = true;
|
|
||||||
|
|
||||||
postInstall = ''
|
|
||||||
# remove empty scripts
|
|
||||||
rm "$out/share/sddm/scripts/Xsetup" "$out/share/sddm/scripts/Xstop"
|
|
||||||
'';
|
|
||||||
|
|
||||||
meta = with stdenv.lib; {
|
|
||||||
description = "QML based X11 display manager";
|
|
||||||
homepage = "https://github.com/sddm/sddm";
|
|
||||||
platforms = platforms.linux;
|
|
||||||
maintainers = with maintainers; [ abbradar ttuegel ];
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
in
|
in mkDerivation rec {
|
||||||
|
name = "sddm-unwrapped-${version}";
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
src = fetchFromGitHub {
|
||||||
name = "sddm-${version}";
|
owner = "sddm";
|
||||||
|
repo = "sddm";
|
||||||
|
rev = "v${version}";
|
||||||
|
sha256 = "0wwid23kw0725zpw67zchalg9mmharr7sn4yzhijq7wqpsczjfxj";
|
||||||
|
};
|
||||||
|
|
||||||
nativeBuildInputs = [ lndir makeQtWrapper ];
|
patches =
|
||||||
buildInputs = [ unwrapped ] ++ themes;
|
copyPathsToStore (lib.readPathsFromFile ./. ./series)
|
||||||
themes = map (pkg: pkg.out or pkg) themes;
|
++ [ patchFixUserAvatars ];
|
||||||
inherit unwrapped;
|
|
||||||
|
|
||||||
unpackPhase = "true";
|
postPatch =
|
||||||
configurePhase = "runHook preConfigure; runHook postConfigure";
|
# Module Qt5::Test must be included in `find_package` before it is used.
|
||||||
buildPhase = "runHook preBuild; runHook postBuild";
|
''
|
||||||
|
sed -i CMakeLists.txt -e '/find_package(Qt5/ s|)| Test)|'
|
||||||
|
'';
|
||||||
|
|
||||||
installPhase = ''
|
nativeBuildInputs = [ cmake extra-cmake-modules pkgconfig qttools ];
|
||||||
runHook preInstall
|
|
||||||
|
|
||||||
propagated=
|
buildInputs = [
|
||||||
for i in $unwrapped $themes; do
|
libxcb libpthreadstubs libXdmcp libXau pam systemd
|
||||||
findInputs $i propagated propagated-user-env-packages
|
];
|
||||||
if [ -z "$crossConfig" ]; then
|
|
||||||
findInputs $i propagated propagated-native-build-inputs
|
|
||||||
else
|
|
||||||
findInputs $i propagated propagated-build-inputs
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
for pkg in $propagated; do
|
propagatedBuildInputs = [
|
||||||
addToSearchPath RUNTIME_XDG_DATA_DIRS "$pkg/share"
|
qtbase qtdeclarative
|
||||||
addToSearchPath RUNTIME_XDG_CONFIG_DIRS "$pkg/etc/xdg"
|
];
|
||||||
done
|
|
||||||
|
|
||||||
mkdir -p "$out/bin"
|
cmakeFlags = [
|
||||||
makeQtWrapper "$unwrapped/bin/sddm" "$out/bin/sddm"
|
"-DCONFIG_FILE=/etc/sddm.conf"
|
||||||
|
# Set UID_MIN and UID_MAX so that the build script won't try
|
||||||
|
# to read them from /etc/login.defs (fails in chroot).
|
||||||
|
# The values come from NixOS; they may not be appropriate
|
||||||
|
# for running SDDM outside NixOS, but that configuration is
|
||||||
|
# not supported anyway.
|
||||||
|
"-DUID_MIN=1000"
|
||||||
|
"-DUID_MAX=29999"
|
||||||
|
];
|
||||||
|
|
||||||
mkdir -p "$out/share/sddm"
|
preConfigure = ''
|
||||||
for pkg in $unwrapped $themes; do
|
export cmakeFlags="$cmakeFlags -DQT_IMPORTS_DIR=$out/$qtQmlPrefix -DCMAKE_INSTALL_SYSCONFDIR=$out/etc -DSYSTEMD_SYSTEM_UNIT_DIR=$out/lib/systemd/system"
|
||||||
local sddmDir="$pkg/share/sddm"
|
|
||||||
if [ -d "$sddmDir" ]; then
|
|
||||||
lndir -silent "$sddmDir" "$out/share/sddm"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
runHook postInstall
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
inherit (unwrapped) meta;
|
postInstall = ''
|
||||||
|
# remove empty scripts
|
||||||
|
rm "$out/share/sddm/scripts/Xsetup" "$out/share/sddm/scripts/Xstop"
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "QML based X11 display manager";
|
||||||
|
homepage = "https://github.com/sddm/sddm";
|
||||||
|
platforms = platforms.linux;
|
||||||
|
maintainers = with maintainers; [ abbradar ttuegel ];
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,24 @@
|
|||||||
|
Index: sddm-0.14.0/src/daemon/Greeter.cpp
|
||||||
|
===================================================================
|
||||||
|
--- sddm-0.14.0.orig/src/daemon/Greeter.cpp
|
||||||
|
+++ sddm-0.14.0/src/daemon/Greeter.cpp
|
||||||
|
@@ -157,18 +157,7 @@ namespace SDDM {
|
||||||
|
<< args;
|
||||||
|
|
||||||
|
// greeter environment
|
||||||
|
- QProcessEnvironment env;
|
||||||
|
- QProcessEnvironment sysenv = QProcessEnvironment::systemEnvironment();
|
||||||
|
-
|
||||||
|
- insertEnvironmentList({QStringLiteral("LANG"), QStringLiteral("LANGUAGE"),
|
||||||
|
- QStringLiteral("LC_CTYPE"), QStringLiteral("LC_NUMERIC"), QStringLiteral("LC_TIME"), QStringLiteral("LC_COLLATE"),
|
||||||
|
- QStringLiteral("LC_MONETARY"), QStringLiteral("LC_MESSAGES"), QStringLiteral("LC_PAPER"), QStringLiteral("LC_NAME"),
|
||||||
|
- QStringLiteral("LC_ADDRESS"), QStringLiteral("LC_TELEPHONE"), QStringLiteral("LC_MEASUREMENT"), QStringLiteral("LC_IDENTIFICATION"),
|
||||||
|
- QStringLiteral("LD_LIBRARY_PATH"),
|
||||||
|
- QStringLiteral("QML2_IMPORT_PATH"),
|
||||||
|
- QStringLiteral("QT_PLUGIN_PATH"),
|
||||||
|
- QStringLiteral("XDG_DATA_DIRS")
|
||||||
|
- }, sysenv, env);
|
||||||
|
+ QProcessEnvironment env = QProcessEnvironment::systemEnvironment();
|
||||||
|
|
||||||
|
env.insert(QStringLiteral("PATH"), mainConfig.Users.DefaultPath.get());
|
||||||
|
env.insert(QStringLiteral("DISPLAY"), m_display->name());
|
2
pkgs/applications/display-managers/sddm/series
Normal file
2
pkgs/applications/display-managers/sddm/series
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
sddm-ignore-config-mtime.patch
|
||||||
|
sddm-nix-profiles.patch
|
@ -15866,16 +15866,7 @@ with pkgs;
|
|||||||
|
|
||||||
printrun = callPackage ../applications/misc/printrun { };
|
printrun = callPackage ../applications/misc/printrun { };
|
||||||
|
|
||||||
sddm = libsForQt5.callPackage ../applications/display-managers/sddm {
|
sddm = libsForQt5.callPackage ../applications/display-managers/sddm { };
|
||||||
themes = []; # extra themes, etc.
|
|
||||||
};
|
|
||||||
|
|
||||||
sddmPlasma5 = sddm.override {
|
|
||||||
themes = [
|
|
||||||
plasma5.plasma-workspace
|
|
||||||
pkgs.breeze-icons
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
skrooge = libsForQt5.callPackage ../applications/office/skrooge {};
|
skrooge = libsForQt5.callPackage ../applications/office/skrooge {};
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user