Hacker News new | ask | show | jobs
by tresta 5332 days ago
Hmmm... won't install with ghc 7.0.4:

  $ cabal install berp
  Resolving dependencies...
  cabal: dependencies conflict: ghc-7.0.4 requires containers ==0.4.0.0 however
  containers-0.4.0.0 was excluded because berp-0.0.2 requires containers <0.4
2 comments

This is pretty usual when it comes to major revision changes in the compiler or standard library with many languages.

This is what you should do:

1. checkout berp from GitHub

2. try to build using cabal in the checked out source tree

3. if there are failing dependencies, hack Cabal build files. this case is probably trivial and berp developers have left containers < 0.4 without a good reason (I may be wrong here, see what's changed in the "containers" package).

4. go to step 2, repeat until software is built

5. submit the change to github, file pull request

After three hours of trying to install this with GHC 6.12.1 and GHC 7.0.3 I have given up.

The problem isn't with berp .cabal files but with dependencies of berp.

ghc-7.0.3 requires containers ==0.4.0.0 language-python requires containers ==0.3.0.0

ghc-6.12.1 requires directory ==1.0.1.0 language-python requires directory ==1.0.1.2

Fetching and unpacking language-python and changing the dependencies manually doesn't appear to fix the problem, for reasons I do not understand.

There is a workaround for the issues with language-python. One can do:

cabal fetch language-python cabal unpack language-python edit the language-python.cabal file updating the containers dependency to 0.4.0.0 then change the version number of language-python itself to 0.3.3 cabal configure cabal install

However, this will not fix the more obtuse problem:

Warning: This package indirectly depends on multiple versions of the same package. This is highly likely to cause a compile failure. package haskell98-1.1.0.1 requires process-1.0.1.5 package ghc-7.0.3 requires process-1.0.1.5 package Cabal-1.10.1.0 requires process-1.0.1.5 package berpinterpreter-0.0.3 requires process-1.0.1.5

I believe the only solution for this problem is to rebuild the entire Haskell platform from source, and if that fails, to format and reload the entire machine.

But you know, keep voting this thread up because Hackhell is awesome.

I finally got it to build, after rebuilding most of Haskell.

It crashes on just about everything. Even a simple "for" loop defeats it. So one has to replace all of those with while blocks.

Every single one of the Python benchmarks I have previously written fails with a not implemented error.

On the one trivial example I timed which worked it was about 1000 times slower than Python.

This sounds sadly like my experiences trying to get the Yi editor to install. I love Haskell in theory, but the build system is so painful if you aren't an expert!
The same can be said about Ruby, except that my experiences with Ruby are worse than with Haskell. With Haskell, you can get a pretty nice "batteries included" setup by installing the latest Haskell platform package.

With Ruby, you have to learn to use rvm, bundler and whatnot just to get a recent version of Ruby installed. Many distributions ship with quite old versions of Ruby and the Ruby official release tarballs have been unreliable (version number doesn't change, tarball contents does, etc).

Lots of languages seem to suffer from similar problems.

When you "cabal unpack language-python" and fix the dependencies, make sure you boost its minor version number (e.g: from: 1.0.3 to 1.0.3.1), otherwise cabal-install will ignore your custom install of the package and will revert to the one from the repositories.

cabal-install is a big hurdle -- must be improved for faster Haskell adoption.

Welcome to the dll hell-style package management system of hackage.