Skip to content

Commit

Permalink
Merge branch 'stable' into 3073-fix-hackage-security
Browse files Browse the repository at this point in the history
  • Loading branch information
snoyberg authored Feb 16, 2018
2 parents 37ca416 + c2e24e8 commit f1ab593
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 16 deletions.
31 changes: 16 additions & 15 deletions doc/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -47,23 +47,22 @@ stack exec my-project-exe
```

- The `stack new` command will create a new directory containing all
the needed files to start a project correctly.
the needed files to start a project correctly.
- The `stack setup` will download the compiler if necessary in an isolated
location (default `~/.stack`) that won't interfere with any system-level
installations. (For information on installation paths, please use the
`stack path` command.).
- The `stack build` command will build the minimal project.
- `stack exec my-project-exe` will execute the command.
- If you just want to install an executable using stack, then all you have to do
is `stack install <package-name>`.
is `stack install <package-name>`.

If you want to launch a REPL:

```bash
stack ghci
```


Run `stack` for a complete list of commands.

##### Workflow
Expand All @@ -90,19 +89,20 @@ So to manage your library:

1. Edit files in the `src/` directory.

The `app` directory should preferably contain only files related to
executables.
The `app` directory should preferably contain only files related to
executables.

2. If you need to include another library (for example the package [`text`](https://hackage.haskell.org/package/text):
2. If you need to include another library (for example the package
[`text`](https://hackage.haskell.org/package/text)):

- Add the package `text` to the file `my-project.cabal`
in the section `build-depends: ...`.
- run `stack build` another time
- Run `stack build` another time.

3. If you get an error that tells you your package isn't in the LTS.
Just try to add a new version in the `stack.yaml` file in the `extra-deps` section.

It was a really fast introduction on how to start to code in Haskell using `stack`.
That was a really fast introduction on how to start to code in Haskell using `stack`.
If you want to go further, we highly recommend you to read the [`stack` guide](GUIDE.md).

#### How to contribute
Expand Down Expand Up @@ -132,7 +132,7 @@ stack setup && \
stack build
```

If you need to check you changes quickly run:
If you need to check your changes quickly run:

```bash
stack ghci
Expand All @@ -145,17 +145,17 @@ the current directory.

#### Complete guide to stack

This repository also contains a complete [user guide to using stack
](GUIDE.md), covering all of the most common use cases.
This repository also contains a complete [user guide to using
stack](GUIDE.md), covering all of the most common use cases.


#### Questions, Feedback, Discussion

* For frequently asked questions about detailed or specific use-cases, please
see [the FAQ](faq.md).
* For general questions, comments, feedback and support please write
* For general questions, comments, feedback and support, please write
to [the stack mailing list](https://groups.google.com/d/forum/haskell-stack).
* For bugs, issues, or requests please
* For bugs, issues, or requests, please
[open an issue](https://github.com/commercialhaskell/stack/issues/new).
* When using Stack Overflow, please use [the haskell-stack
tag](http://stackoverflow.com/questions/tagged/haskell-stack).
Expand All @@ -169,7 +169,7 @@ easy-to-learn interface, while providing the customizability and
power experienced developers need. As a build tool, Stack does not
stand alone. It is built on the great work provided by:

* The __Glasgow Haskell Compiler__ (GHC), the premiere Haskell
* The __Glasgow Haskell Compiler__ (GHC), the premier Haskell
compiler. Stack will manage your GHC installations and automatically
select the appropriate compiler version for your project.
* The __Cabal build system__, a specification for defining Haskell
Expand All @@ -189,4 +189,5 @@ commercial Haskell users, and has since become a thriving open source
project meeting the needs of Haskell users of all stripes.

If you'd like to get involved with Stack, check out the
[newcomer friendly](https://github.com/commercialhaskell/stack/issues?q=is%3Aopen+is%3Aissue+label%3a%22newcomer+friendly%22) label on the Github issue tracker.
[newcomer friendly](https://github.com/commercialhaskell/stack/issues?q=is%3Aopen+is%3Aissue+label%3a%22newcomer+friendly%22)
label on the Github issue tracker.
6 changes: 6 additions & 0 deletions src/Stack/Package.hs
Original file line number Diff line number Diff line change
Expand Up @@ -1369,7 +1369,13 @@ hpack pkgDir = do
config <- view configL
case configOverrideHpack config of
HpackBundled -> do
#if MIN_VERSION_hpack(0,26,0)
r <- liftIO $ Hpack.hpackResult $ Hpack.setTarget (toFilePath hpackFile) Hpack.defaultOptions
#elif MIN_VERSION_hpack(0,23,0)
r <- liftIO $ Hpack.hpackResult Hpack.defaultRunOptions {Hpack.runOptionsConfigDir = Just (toFilePath pkgDir)} Hpack.NoForce
#else
r <- liftIO $ Hpack.hpackResult (Just $ toFilePath pkgDir) Hpack.NoForce
#endif
forM_ (Hpack.resultWarnings r) prettyWarnS
let cabalFile = styleFile . fromString . Hpack.resultCabalFile $ r
case Hpack.resultStatus r of
Expand Down
3 changes: 2 additions & 1 deletion stack-nightly.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
resolver: nightly-2017-12-20
resolver: nightly-2018-02-11
nix:
# --nix on the command-line to enable.
enable: false
Expand All @@ -10,3 +10,4 @@ extra-deps:
- archive: https://github.com/haskell/hackage-security/archive/5763a92829585965700e2e1a716e57e74c134d6a.tar.gz
subdirs:
- hackage-security
- hpack-0.26.0

0 comments on commit f1ab593

Please sign in to comment.