diff options
author | makefu <github@syntax-fehler.de> | 2015-11-17 23:14:28 +0100 |
---|---|---|
committer | makefu <github@syntax-fehler.de> | 2015-11-17 23:14:28 +0100 |
commit | 84743dcd4ab912721841d7431e02a4b40edd95a1 (patch) | |
tree | 19d0200fb7b3f60861eb08dc1243bc49d4411c7d /mv/2configs/xserver/xserver.conf.nix | |
parent | e4c46c2ec22613830c5839001550f5fa155e260d (diff) | |
parent | dba0db28d96978d51284512c6b57a48fbfa9f492 (diff) |
Merge remote-tracking branch 'cd/master'
Diffstat (limited to 'mv/2configs/xserver/xserver.conf.nix')
-rw-r--r-- | mv/2configs/xserver/xserver.conf.nix | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/mv/2configs/xserver/xserver.conf.nix b/mv/2configs/xserver/xserver.conf.nix new file mode 100644 index 000000000..e8a997a99 --- /dev/null +++ b/mv/2configs/xserver/xserver.conf.nix @@ -0,0 +1,40 @@ +{ config, lib, pkgs, ... }: + +with lib; + +let + cfg = config.services.xserver; +in + +pkgs.stdenv.mkDerivation { + name = "xserver.conf"; + + xfs = optionalString (cfg.useXFS != false) + ''FontPath "${toString cfg.useXFS}"''; + + inherit (cfg) config; + + buildCommand = + '' + echo 'Section "Files"' >> $out + echo $xfs >> $out + + for i in ${toString config.fonts.fonts}; do + if test "''${i:0:''${#NIX_STORE}}" == "$NIX_STORE"; then + for j in $(find $i -name fonts.dir); do + echo " FontPath \"$(dirname $j)\"" >> $out + done + fi + done + + for i in $(find ${toString cfg.modules} -type d); do + if test $(echo $i/*.so* | wc -w) -ne 0; then + echo " ModulePath \"$i\"" >> $out + fi + done + + echo 'EndSection' >> $out + + echo "$config" >> $out + ''; +} |