Je kunt niet meer dan 25 onderwerpen selecteren Onderwerpen moeten beginnen met een letter of nummer, kunnen streepjes bevatten ('-') en kunnen maximaal 35 tekens lang zijn.
 
 
John Wiegley 80c0e742dc Remove reference to gitlib-utils 9 jaren geleden
Stackage Resolve two compiler warnings 9 jaren geleden
app Track multiple haskell-platform versions and determine GHC version 9 jaren geleden
hp Different folder 9 jaren geleden
patching Script fix 9 jaren geleden
.gitignore Separate version selection and building #25 9 jaren geleden
.gitmodules Add blank .gitmodules 9 jaren geleden
LICENSE Minor cleanups 9 jaren geleden
README.md Update readme for later GHCs 9 jaren geleden
Setup.hs Initial code 9 jaren geleden
allowed.txt Remove reference to gitlib-utils 9 jaren geleden
debian-bootstrap.sh Remove temporary hacks from debian-bootstrap.sh 9 jaren geleden
full-run.sh full-run calls uploads 9 jaren geleden
stackage.cabal Upload user checking 9 jaren geleden

README.md

stackage

"Stable Hackage," tools for creating a vetted set of packages from Hackage.

A note about the codebase: the goal is to minimize dependencies and have the maximum range of supported compiler versions. Therefore, we avoid anything "complicated." For example, instead of using the text package, we use Strings everywhere.

Get your package included

In order to get your package included in the set of stable packages, you should send a pull request against this repository. In the Stackage.Config module, there's a function called defaultStablePackages. In general, to add a set of packages, you would add:

mapM_ (add "your-email-address") $ words
    "package1 package2 package3"

You can follow the examples of the other sets of packages in that function. Once you've done this, you should confirm that your newly added packages are compatible with the rest of stackage by building the package set.

You should also read the maintainers agreement.

Build the package set

As this project is just starting, we don't really have a solid set of steps. In general, the following set of commands should be good for getting started:

cabal update
cabal install cabal-dev
git clone https://github.com/fpco/stackage
cd stackage
git submodule update --init # get the Haskell Platform files
runghc app/stackage.hs select
runghc app/stackage.hs check
runghc app/stackage.hs build # takes a *long* time
runghc app/stackage.hs test # also takes a *long* time

Notes

Make sure to have Cabal-1.16 installed in either your global or user database, regardless of any sandboxing, as custom build types require it to be present. You must build with cabal-install 1.16, due to several important bug fixes.

Using a non-Haskell Platform versions of GHC

By default, Stackage bases itself off of the Haskell Platform for determining which packages are core packages, and locks down package versions to match the Haskell Platform selections. This works fine when you are compiling with the same version of GHC as the Haskell Platform was built on. If you're using a different version of GHC, you'll probably need to use the following options for the select call:

--no-platform --use-global-db

The former says to disregard Haskell Platform package versions, and the latter says to determine which packages are core packages based on their presence in the global package database.