diff options
author | Ismaël Bouya <ismael.bouya@normalesup.org> | 2020-03-25 11:57:48 +0100 |
---|---|---|
committer | Ismaël Bouya <ismael.bouya@normalesup.org> | 2020-04-25 00:04:53 +0200 |
commit | 72300eb8116c960935a462564d96db6fac355bca (patch) | |
tree | da182278dc7b1a39c287cc701cff73df2b44fc52 /pkgs/mpd_0_21/default.nix | |
parent | 22e09a87fb538a0eaf81837750b0948f26f79cf1 (diff) | |
download | NUR-72300eb8116c960935a462564d96db6fac355bca.tar.gz NUR-72300eb8116c960935a462564d96db6fac355bca.tar.zst NUR-72300eb8116c960935a462564d96db6fac355bca.zip |
Upgrade nixos
Diffstat (limited to 'pkgs/mpd_0_21/default.nix')
-rw-r--r-- | pkgs/mpd_0_21/default.nix | 68 |
1 files changed, 39 insertions, 29 deletions
diff --git a/pkgs/mpd_0_21/default.nix b/pkgs/mpd_0_21/default.nix index f19a76fb..4f97e3fc 100644 --- a/pkgs/mpd_0_21/default.nix +++ b/pkgs/mpd_0_21/default.nix | |||
@@ -21,13 +21,7 @@ | |||
21 | }: | 21 | }: |
22 | 22 | ||
23 | let | 23 | let |
24 | major = "0.21"; | ||
25 | minor = "7"; | ||
26 | |||
27 | lib = stdenv.lib; | 24 | lib = stdenv.lib; |
28 | mkDisable = f: "-D${f}=disabled"; | ||
29 | mkEnable = f: "-D${f}=enabled"; | ||
30 | keys = lib.mapAttrsToList (k: v: k); | ||
31 | 25 | ||
32 | featureDependencies = { | 26 | featureDependencies = { |
33 | # Storage plugins | 27 | # Storage plugins |
@@ -77,6 +71,7 @@ let | |||
77 | icu = [ icu ]; | 71 | icu = [ icu ]; |
78 | pcre = [ pcre ]; | 72 | pcre = [ pcre ]; |
79 | sqlite = [ sqlite ]; | 73 | sqlite = [ sqlite ]; |
74 | syslog = [ ]; | ||
80 | systemd = [ systemd ]; | 75 | systemd = [ systemd ]; |
81 | yajl = [ yajl ]; | 76 | yajl = [ yajl ]; |
82 | zeroconf = [ avahi dbus ]; | 77 | zeroconf = [ avahi dbus ]; |
@@ -84,49 +79,60 @@ let | |||
84 | 79 | ||
85 | run = { features ? null }: | 80 | run = { features ? null }: |
86 | let | 81 | let |
87 | fl = if (features == null ) | ||
88 | then keys featureDependencies | ||
89 | else features; | ||
90 | |||
91 | # Disable platform specific features if needed | 82 | # Disable platform specific features if needed |
92 | # using libmad to decode mp3 files on darwin is causing a segfault -- there | 83 | # using libmad to decode mp3 files on darwin is causing a segfault -- there |
93 | # is probably a solution, but I'm disabling it for now | 84 | # is probably a solution, but I'm disabling it for now |
94 | platformMask = lib.optionals stdenv.isDarwin [ "mad" "pulse" "jack" "nfs" "smb" ] | 85 | platformMask = lib.optionals stdenv.isDarwin [ "mad" "pulse" "jack" "nfs" "smbclient" ] |
95 | ++ lib.optionals (!stdenv.isLinux) [ "alsa" "systemd" ]; | 86 | ++ lib.optionals (!stdenv.isLinux) [ "alsa" "systemd" "syslog" ]; |
96 | features_ = lib.subtractLists platformMask fl; | 87 | |
88 | knownFeatures = builtins.attrNames featureDependencies; | ||
89 | platformFeatures = lib.subtractLists platformMask knownFeatures; | ||
90 | |||
91 | features_ = if (features == null ) | ||
92 | then platformFeatures | ||
93 | else | ||
94 | let unknown = lib.subtractLists knownFeatures features; in | ||
95 | if (unknown != []) | ||
96 | then throw "Unknown feature(s): ${lib.concatStringsSep " " unknown}" | ||
97 | else | ||
98 | let unsupported = lib.subtractLists platformFeatures features; in | ||
99 | if (unsupported != []) | ||
100 | then throw "Feature(s) ${lib.concatStringsSep " " unsupported} are not supported on ${stdenv.hostPlatform.system}" | ||
101 | else features; | ||
97 | 102 | ||
98 | in stdenv.mkDerivation rec { | 103 | in stdenv.mkDerivation rec { |
99 | name = "mpd-${version}"; | 104 | pname = "mpd"; |
100 | version = "${major}${if minor == "" then "" else "." + minor}"; | 105 | version = "0.21.21"; |
101 | 106 | ||
102 | src = fetchFromGitHub { | 107 | src = fetchFromGitHub { |
103 | owner = "MusicPlayerDaemon"; | 108 | owner = "MusicPlayerDaemon"; |
104 | repo = "MPD"; | 109 | repo = "MPD"; |
105 | rev = "v${version}"; | 110 | rev = "v${version}"; |
106 | sha256 = "11zi8hmlj63ngzl06vzx05669k20j4cdsp0caz4p4ayn46fd4m17"; | 111 | sha256 = "0ysyjlmmfm1y5jqyv83bs9p7zqr9pgj1hmdq2b7kx9kridclbnng"; |
107 | }; | 112 | }; |
108 | 113 | ||
109 | buildInputs = [ glib boost ] | 114 | buildInputs = [ glib boost ] |
110 | ++ (lib.concatLists (lib.attrVals features_ featureDependencies)) | 115 | ++ (lib.concatLists (lib.attrVals features_ featureDependencies)) |
111 | ++ lib.optional stdenv.isDarwin darwin.apple_sdk.frameworks.AudioToolbox; | 116 | ++ lib.optionals stdenv.isDarwin [ darwin.apple_sdk.frameworks.AudioToolbox darwin.apple_sdk.frameworks.AudioUnit ]; |
112 | 117 | ||
113 | nativeBuildInputs = [ meson ninja pkgconfig ]; | 118 | nativeBuildInputs = [ meson ninja pkgconfig ]; |
114 | 119 | ||
115 | enableParallelBuilding = true; | 120 | enableParallelBuilding = true; |
116 | 121 | ||
122 | mesonAutoFeatures = "disabled"; | ||
117 | mesonFlags = | 123 | mesonFlags = |
118 | map mkEnable features_ ++ map mkDisable (lib.subtractLists features_ (keys featureDependencies)) | 124 | map (x: "-D${x}=enabled") features_ |
119 | ++ [ "-Dsyslog=enabled" ] | 125 | ++ map (x: "-D${x}=disabled") (lib.subtractLists features_ knownFeatures) |
120 | ++ lib.optional (lib.any (x: x == "zeroconf") features_) | 126 | ++ lib.optional (builtins.elem "zeroconf" features_) |
121 | "-Dzeroconf=avahi" | 127 | "-Dzeroconf=avahi" |
122 | ++ lib.optional stdenv.isLinux | 128 | ++ lib.optional (builtins.elem "systemd" features_) |
123 | "-Dsystemd_system_unit_dir=etc/systemd/system"; | 129 | "-Dsystemd_system_unit_dir=etc/systemd/system"; |
124 | 130 | ||
125 | meta = with stdenv.lib; { | 131 | meta = with stdenv.lib; { |
126 | description = "A flexible, powerful daemon for playing music"; | 132 | description = "A flexible, powerful daemon for playing music"; |
127 | homepage = http://mpd.wikia.com/wiki/Music_Player_Daemon_Wiki; | 133 | homepage = "https://www.musicpd.org/"; |
128 | license = licenses.gpl2; | 134 | license = licenses.gpl2; |
129 | maintainers = with maintainers; [ astsmtl fuuzetsu ehmry fpletz ]; | 135 | maintainers = with maintainers; [ astsmtl ehmry fpletz tobim ]; |
130 | platforms = platforms.unix; | 136 | platforms = platforms.unix; |
131 | 137 | ||
132 | longDescription = '' | 138 | longDescription = '' |
@@ -140,13 +146,17 @@ in | |||
140 | { | 146 | { |
141 | mpd = run { }; | 147 | mpd = run { }; |
142 | mpd-small = run { features = [ | 148 | mpd-small = run { features = [ |
143 | "webdav" "curl" "mms" "nfs" "bzip2" "zzip" | 149 | "webdav" "curl" "mms" "bzip2" "zzip" |
144 | "audiofile" "faad" "flac" "gme" "mad" | 150 | "audiofile" "faad" "flac" "gme" "mad" |
145 | "mpg123" "opus" "vorbis" | 151 | "mpg123" "opus" "vorbis" "vorbisenc" |
146 | "vorbisenc" "lame" "libsamplerate" | 152 | "lame" "libsamplerate" "shout" |
147 | "alsa" "shout" "libmpdclient" | 153 | "libmpdclient" "id3tag" "expat" "pcre" |
148 | "id3tag" "expat" "pcre" "yajl" "sqlite" | 154 | "yajl" "sqlite" |
149 | "soundcloud" "qobuz" "tidal" | 155 | "soundcloud" "qobuz" "tidal" |
150 | "systemd" | 156 | ] ++ lib.optionals stdenv.isLinux [ |
157 | "alsa" "systemd" "syslog" | ||
158 | ] ++ lib.optionals (!stdenv.isDarwin) [ | ||
159 | "mad" "jack" "nfs" | ||
151 | ]; }; | 160 | ]; }; |
161 | mpdWithFeatures = run; | ||
152 | } | 162 | } |