erlang: use makeOverridable for customizations

authored by Daiderd Jordan and committed by Gleb Peregud e88a89ad 3426c88b

+38 -48
+26 -10
pkgs/development/beam-modules/lib.nix
··· 2 3 rec { 4 5 - /* Uses generic-builder to evaluate provided drv containing OTP-version specific data. 6 7 drv: package containing version-specific args; 8 builder: generic builder for all Erlang versions; 9 - gargs: arguments passed to the generic-builder, used mostly to customize dependencies; 10 - args: arguments merged into version-specific args, used mostly to enable/disable high-level OTP 11 - features, like ODBC or WX support; 12 13 - Please note that "mkDerivation" defined here is the one called from R16.nix and similar files. 14 */ 15 - callErlang = drv: gargs: args: pkgs.callPackage drv ( 16 - let builder = pkgs.callPackage ../../development/interpreters/erlang/generic-builder.nix gargs; 17 - in { 18 - mkDerivation = a: builder (a // args); 19 - }); 20 21 }
··· 2 3 rec { 4 5 + /* Similar to callPackageWith/callPackage, but without makeOverridable 6 + */ 7 + callPackageWith = autoArgs: fn: args: 8 + let 9 + f = if builtins.isFunction fn then fn else import fn; 10 + auto = builtins.intersectAttrs (builtins.functionArgs f) autoArgs; 11 + in f (auto // args); 12 + 13 + callPackage = callPackageWith pkgs; 14 + 15 + /* Uses generic-builder to evaluate provided drv containing OTP-version 16 + specific data. 17 18 drv: package containing version-specific args; 19 builder: generic builder for all Erlang versions; 20 + args: arguments merged into version-specific args, used mostly to customize 21 + dependencies; 22 23 + Arguments passed to the generic-builder are overridable, used to 24 + enable/disable high-level OTP features, like ODBC or WX support; 25 + 26 + Please note that "mkDerivation" defined here is the one called from R16.nix 27 + and similar files. 28 */ 29 + callErlang = drv: args: 30 + let 31 + builder = callPackage ../../development/interpreters/erlang/generic-builder.nix args; 32 + in 33 + callPackage drv { 34 + mkDerivation = pkgs.makeOverridable builder; 35 + }; 36 37 }
+12 -38
pkgs/top-level/beam-packages.nix
··· 12 erlang_odbc_javac = erlangR18_odbc_javac; 13 14 # These are standard Erlang versions, using the generic builder. 15 - erlangR16 = lib.callErlang ../development/interpreters/erlang/R16.nix {} {}; 16 - erlangR16_odbc = lib.callErlang ../development/interpreters/erlang/R16.nix {} { 17 - odbcSupport = true; 18 - }; 19 - erlangR17 = lib.callErlang ../development/interpreters/erlang/R17.nix {} {}; 20 - erlangR17_odbc = lib.callErlang ../development/interpreters/erlang/R17.nix {} { 21 - odbcSupport = true; 22 - }; 23 - erlangR17_javac = lib.callErlang ../development/interpreters/erlang/R17.nix {} { 24 - javacSupport = true; 25 - }; 26 - erlangR17_odbc_javac = lib.callErlang ../development/interpreters/erlang/R17.nix {} { 27 javacSupport = true; odbcSupport = true; 28 }; 29 erlangR18 = lib.callErlang ../development/interpreters/erlang/R18.nix { 30 wxGTK = wxGTK30; 31 - } {}; 32 - erlangR18_odbc = lib.callErlang ../development/interpreters/erlang/R18.nix { 33 - wxGTK = wxGTK30; 34 - } { 35 - odbcSupport = true; 36 }; 37 - erlangR18_javac = lib.callErlang ../development/interpreters/erlang/R18.nix { 38 - wxGTK = wxGTK30; 39 - } { 40 - javacSupport = true; 41 - }; 42 - erlangR18_odbc_javac = lib.callErlang ../development/interpreters/erlang/R18.nix { 43 - wxGTK = wxGTK30; 44 - } { 45 javacSupport = true; odbcSupport = true; 46 }; 47 erlangR19 = lib.callErlang ../development/interpreters/erlang/R19.nix { 48 wxGTK = wxGTK30; 49 - } {}; 50 - erlangR19_odbc = lib.callErlang ../development/interpreters/erlang/R19.nix { 51 - wxGTK = wxGTK30; 52 - } { 53 - odbcSupport = true; 54 - }; 55 - erlangR19_javac = lib.callErlang ../development/interpreters/erlang/R19.nix { 56 - wxGTK = wxGTK30; 57 - } { 58 - javacSupport = true; 59 }; 60 - erlangR19_odbc_javac = lib.callErlang ../development/interpreters/erlang/R19.nix { 61 - wxGTK = wxGTK30; 62 - } { 63 javacSupport = true; odbcSupport = true; 64 }; 65
··· 12 erlang_odbc_javac = erlangR18_odbc_javac; 13 14 # These are standard Erlang versions, using the generic builder. 15 + erlangR16 = lib.callErlang ../development/interpreters/erlang/R16.nix {}; 16 + erlangR16_odbc = erlangR16.override { odbcSupport = true; }; 17 + erlangR17 = lib.callErlang ../development/interpreters/erlang/R17.nix {}; 18 + erlangR17_odbc = erlangR17.override { odbcSupport = true; }; 19 + erlangR17_javac = erlangR17.override { javacSupport = true; }; 20 + erlangR17_odbc_javac = erlangR17.override { 21 javacSupport = true; odbcSupport = true; 22 }; 23 erlangR18 = lib.callErlang ../development/interpreters/erlang/R18.nix { 24 wxGTK = wxGTK30; 25 }; 26 + erlangR18_odbc = erlangR18.override { odbcSupport = true; }; 27 + erlangR18_javac = erlangR18.override { javacSupport = true; }; 28 + erlangR18_odbc_javac = erlangR18.override { 29 javacSupport = true; odbcSupport = true; 30 }; 31 erlangR19 = lib.callErlang ../development/interpreters/erlang/R19.nix { 32 wxGTK = wxGTK30; 33 }; 34 + erlangR19_odbc = erlangR19.override { odbcSupport = true; }; 35 + erlangR19_javac = erlangR19.override { javacSupport = true; }; 36 + erlangR19_odbc_javac = erlangR19.override { 37 javacSupport = true; odbcSupport = true; 38 }; 39