diff options
author | jeschli <jeschli@gmail.com> | 2018-04-18 08:26:03 +0200 |
---|---|---|
committer | jeschli <jeschli@gmail.com> | 2018-04-18 08:26:03 +0200 |
commit | 88357921c1399e44080e68318b35b05430fecd5d (patch) | |
tree | 176cf780a48560ceb3d3b1ab625ab360742ede8c /jeschli/2configs/xserver/xserver.conf.nix | |
parent | e800670c1892cca7c9d12476d65bb4750e213890 (diff) | |
parent | 3871554d1935bcdc5d8ed6b82c847bee03a6d6bf (diff) |
Merge remote-tracking branch 'origin/staging/jeschli'
Diffstat (limited to 'jeschli/2configs/xserver/xserver.conf.nix')
-rw-r--r-- | jeschli/2configs/xserver/xserver.conf.nix | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/jeschli/2configs/xserver/xserver.conf.nix b/jeschli/2configs/xserver/xserver.conf.nix new file mode 100644 index 000000000..6f34e0150 --- /dev/null +++ b/jeschli/2configs/xserver/xserver.conf.nix @@ -0,0 +1,40 @@ +{ config, lib, pkgs, ... }: + +with import <stockholm/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 + ''; +} |