Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

First class support for Liquid Haskell? #2641

Open
mgsloan opened this issue Sep 27, 2016 · 7 comments
Open

First class support for Liquid Haskell? #2641

mgsloan opened this issue Sep 27, 2016 · 7 comments

Comments

@mgsloan
Copy link
Contributor

mgsloan commented Sep 27, 2016

Should we add first class support for Liquid Haskell in stack? I have not used Liquid Haskell much yet, so I don't know how much sense this makes. It could be as simple as stack liquid, and it will automatically install it appropriately if necessary, and run the tool on your code. I will send an email to the Liquid Haskell authors and get them involved in this discussion.

It is quite possible that first class support is unnecessary. I just found this project - https://github.com/spinda/liquidhaskell-cabal/blob/0.1.1.0/README.md - but I have not yet tried it, sounds like it supports stack decently. Perhaps it would be helpful to streamline things for usage with stack?

In mgsloan/store#71 , @kantp added use of liquid haskell to verify that we stay within the bounds of the bytebuffer! This allows us to have code that is both fast and trustworthy. Fantastic!

Considering we are now maintaining code that uses Liquid Haskell, it only makes sense to have our Travis CI for store use it. To me, the most sensible implementation approach is by having direct support in stack.

@gridaphobe
Copy link

@mgsloan this is an exciting idea, thanks for suggesting it!

There are two modes I think we'd want to support.

  1. Run LiquidHaskell as part of the build process, which is what the liquidhaskell-cabal package does.
  2. Run LiquidHaskell on individual modules, e.g. as part of a linter for emacs/vim.

In both cases, I think the main support we'd want from stack is to ensure a version of LiquidHaskell is used that is compatible with the selected GHC. Specifically we want to ensure that LiquidHaskell was built with the same GHC that we're using to build the project. So perhaps a stack liquid command could just ensure that? (i.e. something equivalent to stack build liquidhaskell && stack exec liquid -- "$@" ought to work?)

@mgsloan
Copy link
Contributor Author

mgsloan commented Sep 27, 2016

That's correct Eric! stack build liquidhaskell will place the liquid executable in your local sandbox, and it will use the appropriate GHC version. Not quite as efficient as possible, but I think a more efficient approach will be implemented before the next release - #2643.

Run LiquidHaskell as part of the build process, which is what the liquidhaskell-cabal package does.

Makes sense! I suppose we can directly use the liquidhaskell-cabal project, or borrow its approach.

Run LiquidHaskell on individual modules, e.g. as part of a linter for emacs/vim.

This is not directly within the scope of stack, however I think it is within scope for intero! For example, intero plans support for hoogle: https://github.com/commercialhaskell/intero/issues/129

The real awesome-sauce would be to compile liquid haskell directly into intero, but I'm not sure how much effort that would take. We face a similar problem with support for ghcjs in intero: https://github.com/commercialhaskell/intero/issues/64

@gridaphobe
Copy link

Run LiquidHaskell on individual modules, e.g. as part of a linter for emacs/vim.
This is not directly within the scope of stack, however I think it is within scope for intero! For example, intero plans support for hoogle: commercialhaskell/intero#129

The real awesome-sauce would be to compile liquid haskell directly into intero, but I'm not sure how much effort that would take. We face a similar problem with support for ghcjs in intero: commercialhaskell/intero#64

Hmm, integration with intero is also a very cool idea, and could avoid some of the overhead from having multiple GHC's typecheck the source (one for GHC itself, and one for GHC via LH).

I think running liquid on a single file is well within the scope of stack though, that's the default mode for liquid, and doesn't seem to be any different from the stack ghc command.

@nikivazou
Copy link

Thanks for the suggestion @mgsloan!

One thing to keep in mind when you are using Liquid Haskell in a big library is that verification time can be long.

I did integrate Liquid Haskell verification in a real project (~73 modules) and I just added a command "runLiquidAll" in the Travis CI built. That ended up taking ~80 min that does not fit well in software building process.

Now, if there is a stack command that installs Liquid Haskell and runs liquid in all the .hs files, it would be definitely convenient. Moreover, if we can tell Travis CI to only run this in the nightly builds, this would be even more practical.

@mgsloan
Copy link
Contributor Author

mgsloan commented Sep 27, 2016

Hmm, integration with intero is also a very cool idea, and could avoid some of the overhead from having multiple GHC's typecheck the source (one for GHC itself, and one for GHC via LH).

Yep! I think it makes a lot of sense to turn intero into something that provides a shared GHC context for all the tools that need it. haskell-ide-engine has a similar goal and approach. We are taking the approach of extending GHCI, rather than starting fresh, because this is the easiest way to do it while retaining REPL capability.

One thing to keep in mind when you are using Liquid Haskell in a big library is that verification time can be long.

Good to know, @nikivazou ! It certainly makes sense to me to have it as a CI step. That way, most contributors do not need to run liquid haskell. Instead, there will be an async notification if they broke some property.

@chshersh
Copy link

chshersh commented Mar 5, 2018

@nikivazou Could you share your runLiquidAll command? I'm trying to configure LiquidHaskell on Travis CI and this is not an easy task...

@nikivazou
Copy link

nikivazou commented Mar 6, 2018 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

4 participants