nixOS:如何从同一个包的两个实例之间的冲突中恢复,同一个版本

时间:2016-10-19 05:02:10

标签: haskell nixos nixpkgs

这是我的nixos版本:

$ nixos-version 
16.09pre85931.125ffff (Flounder)

这是我的shell脚本:

$ cat test.nix 
{ nixpkgs ? import <nixpkgs> {
}, compiler ? "ghc801" }:

let
  inherit (nixpkgs) pkgs;
  ghc = pkgs.haskell.packages.${compiler}.ghcWithPackages (ps: with ps; [
    diagrams
    diagrams-pgf
  ]);
in
pkgs.stdenv.mkDerivation {
  name = "test";
  buildInputs = with pkgs; [
    ghc
  ];
  shellHook = ''
    eval $(egrep ^export ${ghc}/bin/ghc)
  '';
}

这是问题所在。请注意,同一个包的相同版本的两个实例之间存在冲突:

$ nix-shell --pure test.nix 
these derivations will be built:
  /nix/store/r6080kvlvdb16c1frz8alnm14xjizkf5-ghc-8.0.1.drv
building path(s) ‘/nix/store/1129nds6xhq6hqawdd2s9z9n6va57jgl-ghc-8.0.1’
collision between `/nix/store/amdnmbd8p52d49bqmphv9f7ly7lf7pkk-active-0.2.0.10/share/doc/x86_64-linux-ghc-8.0.1/active-0.2.0.10/html/Data-Active.html' and `/nix/store/yniw6akz2ldimdlj9yq968ldaf4j18h1-active-0.2.0.10/share/doc/x86_64-linux-ghc-8.0.1/active-0.2.0.10/html/Data-Active.html'
builder for ‘/nix/store/r6080kvlvdb16c1frz8alnm14xjizkf5-ghc-8.0.1.drv’ failed with exit code 255
error: build of ‘/nix/store/r6080kvlvdb16c1frz8alnm14xjizkf5-ghc-8.0.1.drv’ failed
/run/current-system/sw/bin/nix-shell: failed to build all dependencies

我知道如果软件包有不同的版本,那么我可以这样做:

$ nix-env --set-flag priority 15 <package>-<version>

但由于包名和版本相同,我不知道该怎么做。

我该如何从中恢复?

2 个答案:

答案 0 :(得分:2)

ghcWithPackages有效地创建了一个全新的GHC发行版,可以自定义包含您列出的软件包。这与pkgs.ghc不同,不仅仅是依赖它的东西;将两者安装到同一环境中没有意义。我认为你不小心提到了两者,这就是导致碰撞的原因。

首先,您使用ghc制作个人GHC并将其作为名称let使用。

在你所说的let的范围内:

buildInputs = with pkgs; [
  ghc
];

withpkgs的每个属性都纳入以下表达式的范围。 pkgs具有ghc属性,with范围是包含ghc绑定的最内层范围,因此优先于ghc let 1}}。

另一方面,shellHook超出了with的范围。因此${ghc}是对您的let-bound ghc的引用。这使得你的推导也依赖于它。

如果这是正确的,解决方案将是:

  1. 删除with,因此构建输入列表与代码的其余部分看到相同的ghc(使用来自此pkgs的其他任何内容的限定引用)
  2. with移到let之外,因此您的ghc版本是最里面的绑定(但随后您使用pkgs中的所有内容污染整个文件的命名空间,当它变得更复杂时会变得混乱)
  3. let中使用其他变量名称(myghc或其他内容),并在任何地方引用

答案 1 :(得分:2)

尝试在nixpkgs commit 125ffff上重现您的问题时,我收到了不同的错误。即:

src/System/Texrunner/Online.hs:45:1: warning: [-Wunused-imports]
    The import of ‘Control.Applicative’ is redundant
      except perhaps to import instances from ‘Control.Applicative’
    To import instances alone, use: import Control.Applicative()
[3 of 3] Compiling System.Texrunner ( src/System/Texrunner.hs, dist/build/System/Texrunner.o )

src/System/Texrunner.hs:18:1: warning: [-Wunused-imports]
    The import of ‘Control.Applicative’ is redundant
      except perhaps to import instances from ‘Control.Applicative’
    To import instances alone, use: import Control.Applicative()
Preprocessing test suite 'tests' for texrunner-0.0.1.1...
[1 of 2] Compiling Tex.PDF          ( tests/Tex/PDF.hs, dist/build/tests/tests-tmp/Tex/PDF.dyn_o )
[2 of 2] Compiling Main             ( tests/Tests.hs, dist/build/tests/tests-tmp/Main.dyn_o )

tests/Tests.hs:5:1: error:
    Failed to load interface for ‘Tex.LogParse’
    Use -v to see a list of the files searched for.
builder for ‘/nix/store/g3mwscrvwsr9zrr5h14d59w7nh06qmsw-texrunner-0.0.1.1.drv’ failed with exit code 1
cannot build derivation ‘/nix/store/9las78qbxqrlhakhdiqwc2jf7g6i5688-ghc-8.0.1.drv’: 1 dependencies couldn't be built
error: build of ‘/nix/store/9las78qbxqrlhakhdiqwc2jf7g6i5688-ghc-8.0.1.drv’ failed

这让我相信<nixpkgs>指向您机器上的不同提交。 上述问题已在提交7c7417中修复。截至提交80224e(撰写本文时为主人),该更改仍处于活动状态。那时我可以重现你的错误。

问题似乎是,diagramsdiagrams-pgf作为单独的包,取决于optparse-applicative的不同版本。包diagrams-pgf的整个范围都覆盖了较新的版本,这意味着它还引入了diagrams的不同版本和其他依赖项。这似乎导致了碰撞。

一个简单的修复方法应该只依赖于你的nix-shell中的diagrams-pgf。大多数图表将作为diagrams-pgf的依赖关系拉入,因此仍然可用。

{ nixpkgs ? import <nixpkgs> {
}, compiler ? "ghc801" }:

let
  inherit (nixpkgs) pkgs;
  ghc = pkgs.haskell.packages.${compiler}.ghcWithPackages (ps: with ps; [
    diagrams-pgf # <--- HERE
  ]);
in
pkgs.stdenv.mkDerivation {
  name = "test";
  buildInputs = with pkgs; [
    ghc
  ];
  shellHook = ''
    eval $(egrep ^export ${ghc}/bin/ghc)
  '';
}

ghc --show-packages确认:

$ ghc --show-packages | grep 'name: diagrams'
name: diagrams-lib
name: diagrams-solve
name: diagrams-core
name: diagrams-pgf

不幸的是,由diagrams-svg引入的包diagrams无法使用新版本的optparse-applicative进行构建。因此,目前无法在不修补其中一些软件包的情况下构建同时具有diagramsdiagrams-pgf的环境。

如果您需要diagrams-contrib,那么以下内容应该可以解决问题:

{ nixpkgs ? import ~/src/nixpkgs {}
, compiler ? "ghc801" }:

let
  inherit (nixpkgs) pkgs;
  ghc = pkgs.haskell.packages.${compiler}.ghcWithPackages (ps: with ps; [
    (diagrams-contrib.overrideScope (self: super: {
      optparse-applicative = self.optparse-applicative_0_13_0_0;
    })) # <--- HERE
    diagrams-pgf
  ]);
in
pkgs.stdenv.mkDerivation {
  name = "test";
  buildInputs = with pkgs; [
    ghc
  ];
  shellHook = ''
    eval $(egrep ^export ${ghc}/bin/ghc)
  '';
}