Skip to content

Commit

Permalink
Two fixes to multi repl command (backport #10017) (#10085)
Browse files Browse the repository at this point in the history
* Add extra ghc options to multi-repl file

These options are configured into the program by Cabal, so we also need
to extract these and put them into the mutli-file.

Fixes #10015

(cherry picked from commit 539cb7b)

* Fix rendering of `-j` option in multi-repl

Before this was rendered as..

```
/run/current-system/sw/bin/ghc --interactive -package-env - -j 'NumJobs (Just 8)' ...
```

Due to this place not being updated when support for semaphores was
added.

(cherry picked from commit c3708d2)

---------

Co-authored-by: Matthew Pickering <[email protected]>
Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
  • Loading branch information
mergify[bot] and mpickering authored Jun 8, 2024
1 parent 4175a28 commit 3c04d39
Show file tree
Hide file tree
Showing 11 changed files with 130 additions and 2 deletions.
4 changes: 3 additions & 1 deletion Cabal/src/Distribution/Simple/GHC/Build/Link.hs
Original file line number Diff line number Diff line change
Expand Up @@ -655,7 +655,9 @@ runReplOrWriteFlags ghcProg lbi rflags ghcOpts pkg_name target =
writeFileAtomic (out_dir </> this_unit) $
BS.pack $
escapeArgs $
extra_opts ++ renderGhcOptions comp platform (ghcOpts{ghcOptMode = NoFlag})
extra_opts
++ renderGhcOptions comp platform (ghcOpts{ghcOptMode = NoFlag})
++ programOverrideArgs ghcProg

replNoLoad :: Ord a => ReplOptions -> NubListR a -> NubListR a
replNoLoad replFlags l
Expand Down
7 changes: 6 additions & 1 deletion cabal-install/src/Distribution/Client/CmdRepl.hs
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,7 @@ import Distribution.Types.Library
( Library (..)
, emptyLibrary
)
import Distribution.Types.ParStrat
import Distribution.Types.Version
( Version
, mkVersion
Expand Down Expand Up @@ -466,6 +467,10 @@ replAction flags@NixStyleFlags{extraFlags = r@ReplFlags{..}, ..} targetStrings g
in -- GHC considers the last unit passed to be the active one
other_units ++ active_unit_files

render_j Serial = "1"
render_j (UseSem n) = show @Int n
render_j (NumJobs mn) = maybe "" (show @Int) mn

-- run ghc --interactive with
runProgramInvocation verbosity $
programInvocation ghcProg' $
Expand All @@ -474,7 +479,7 @@ replAction flags@NixStyleFlags{extraFlags = r@ReplFlags{..}, ..} targetStrings g
, "-package-env"
, "-" -- to ignore ghc.environment.* files
, "-j"
, show (buildSettingNumJobs (buildSettings ctx))
, render_j (buildSettingNumJobs (buildSettings ctx))
]
: [ ["-unit", "@" ++ dir </> unit]
| unit <- unit_files_ordered
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Revision history for extra-options

## 0.1.0.0 -- YYYY-mm-dd

* First version. Released on an unsuspecting world.
30 changes: 30 additions & 0 deletions cabal-testsuite/PackageTests/MultiRepl/ExtraOptions/LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
Copyright (c) 2024, Matthew Pickering

All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

* Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.

* Redistributions in binary form must reproduce the above
copyright notice, this list of conditions and the following
disclaimer in the documentation and/or other materials provided
with the distribution.

* Neither the name of Matthew Pickering nor the names of other
contributors may be used to endorse or promote products derived
from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
10 changes: 10 additions & 0 deletions cabal-testsuite/PackageTests/MultiRepl/ExtraOptions/app/Main.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
module Main where

import qualified MyLib (someFunc)

#ifdef FOO
main :: IO ()
main = do
putStrLn "Hello, Haskell!"
MyLib.someFunc
#endif
13 changes: 13 additions & 0 deletions cabal-testsuite/PackageTests/MultiRepl/ExtraOptions/cabal.out
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
# cabal v2-repl
Resolving dependencies...
Build profile: -w ghc-<GHCVER> -O1
In order, the following will be built:
- extra-options-0.1.0.0 (interactive) (lib) (first run)
- extra-options-0.1.0.0 (interactive) (test:extra-options-test) (first run)
- extra-options-0.1.0.0 (interactive) (exe:extra-options) (first run)
Configuring library for extra-options-0.1.0.0...
Preprocessing library for extra-options-0.1.0.0...
Configuring test suite 'extra-options-test' for extra-options-0.1.0.0...
Preprocessing test suite 'extra-options-test' for extra-options-0.1.0.0...
Configuring executable 'extra-options' for extra-options-0.1.0.0...
Preprocessing executable 'extra-options' for extra-options-0.1.0.0...
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
packages: .

tests: True

program-options
ghc-options: -XCPP -DFOO
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import Test.Cabal.Prelude

main = do
cabalTest $ do
skipUnlessGhcVersion ">= 9.4"
void $ cabalWithStdin "v2-repl" ["--enable-multi-repl","all"] ""
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
cabal-version: 3.0
name: extra-options
version: 0.1.0.0
license: BSD-3-Clause
license-file: LICENSE
author: Matthew Pickering
maintainer: [email protected]
build-type: Simple
extra-doc-files: CHANGELOG.md

common warnings
ghc-options: -Wall

library
import: warnings
exposed-modules: MyLib
build-depends: base
hs-source-dirs: src
default-language: Haskell2010

executable extra-options
import: warnings
main-is: Main.hs
build-depends:
base,
extra-options

hs-source-dirs: app
default-language: Haskell2010

test-suite extra-options-test
import: warnings
default-language: Haskell2010
type: exitcode-stdio-1.0
hs-source-dirs: test
main-is: Main.hs
build-depends:
base,
extra-options
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
module MyLib (someFunc) where

#ifdef FOO
someFunc :: IO ()
someFunc = putStrLn "someFunc"
#endif
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
module Main (main) where

#ifdef FOO
main :: IO ()
main = putStrLn "Test suite not yet implemented."
#endif

0 comments on commit 3c04d39

Please sign in to comment.