Add more version information to debug command
This commit is contained in:
parent
5e2f79b7c8
commit
5d9e8ea12b
@ -7,6 +7,7 @@ import Control.Monad.Trans.Journal
|
|||||||
import qualified Data.Map as Map
|
import qualified Data.Map as Map
|
||||||
import qualified Data.Set as Set
|
import qualified Data.Set as Set
|
||||||
import Data.Char
|
import Data.Char
|
||||||
|
import Data.Version
|
||||||
import Data.List.Split
|
import Data.List.Split
|
||||||
import Text.PrettyPrint
|
import Text.PrettyPrint
|
||||||
import Language.Haskell.GhcMod.Monad
|
import Language.Haskell.GhcMod.Monad
|
||||||
@ -17,6 +18,11 @@ import Language.Haskell.GhcMod.Pretty
|
|||||||
import Language.Haskell.GhcMod.Utils
|
import Language.Haskell.GhcMod.Utils
|
||||||
import Language.Haskell.GhcMod.Cradle
|
import Language.Haskell.GhcMod.Cradle
|
||||||
import Language.Haskell.GhcMod.Stack
|
import Language.Haskell.GhcMod.Stack
|
||||||
|
import Language.Haskell.GhcMod.Output
|
||||||
|
|
||||||
|
import Paths_ghc_mod (version)
|
||||||
|
|
||||||
|
import Config (cProjectVersion)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
@ -34,14 +40,20 @@ debugInfo = do
|
|||||||
|
|
||||||
pkgOpts <- packageGhcOptions
|
pkgOpts <- packageGhcOptions
|
||||||
|
|
||||||
|
readProc <- gmReadProcess
|
||||||
|
|
||||||
|
ghcVersion <- liftIO $
|
||||||
|
dropWhileEnd isSpace <$> readProc "ghc" ["--numeric-version"] ""
|
||||||
|
|
||||||
return $ unlines $
|
return $ unlines $
|
||||||
[ "Root directory: " ++ cradleRootDir
|
[ "Version: ghc-mod-" ++ showVersion version
|
||||||
|
, "Library GHC Version: " ++ cProjectVersion
|
||||||
|
, "System GHC Version: " ++ ghcVersion
|
||||||
|
, "Root directory: " ++ cradleRootDir
|
||||||
, "Current directory: " ++ cradleCurrentDir
|
, "Current directory: " ++ cradleCurrentDir
|
||||||
, "GHC Package flags:\n" ++ render (nest 4 $
|
, "GHC Package flags:\n" ++ render (nest 4 $
|
||||||
fsep $ map text pkgOpts)
|
fsep $ map text pkgOpts)
|
||||||
, "GHC System libraries: " ++ ghcLibDir
|
, "GHC System libraries: " ++ ghcLibDir
|
||||||
, "GHC user options:\n" ++ render (nest 4 $
|
|
||||||
fsep $ map text optGhcUserOptions)
|
|
||||||
] ++ cabal
|
] ++ cabal
|
||||||
|
|
||||||
stackPaths :: IOish m => GhcModT m [String]
|
stackPaths :: IOish m => GhcModT m [String]
|
||||||
@ -63,9 +75,18 @@ cabalDebug = do
|
|||||||
opts = Map.map gmcGhcOpts mcs
|
opts = Map.map gmcGhcOpts mcs
|
||||||
srcOpts = Map.map gmcGhcSrcOpts mcs
|
srcOpts = Map.map gmcGhcSrcOpts mcs
|
||||||
|
|
||||||
|
readProc <- gmReadProcess
|
||||||
|
cabalInstVersion <- liftIO $
|
||||||
|
dropWhileEnd isSpace <$> readProc "cabal" ["--numeric-version"] ""
|
||||||
|
packages <- liftIO $ readProc "ghc-pkg" ["list", "--simple-output"] ""
|
||||||
|
let cabalPackages = filter ((== ["Cabal"]) . take 1 . splitOn "-") $ splitWhen isSpace packages
|
||||||
|
|
||||||
return $
|
return $
|
||||||
[ "Cabal file: " ++ show cradleCabalFile
|
[ "cabal-install Version: " ++ cabalInstVersion
|
||||||
, "Project: " ++ show cradleProject
|
, "Cabal Library Versions:\n" ++ render (nest 4 $
|
||||||
|
fsep $ map text cabalPackages)
|
||||||
|
, "Cabal file: " ++ show cradleCabalFile
|
||||||
|
, "Project: " ++ show cradleProject
|
||||||
, "Cabal entrypoints:\n" ++ render (nest 4 $
|
, "Cabal entrypoints:\n" ++ render (nest 4 $
|
||||||
mapDoc gmComponentNameDoc smpDoc entrypoints)
|
mapDoc gmComponentNameDoc smpDoc entrypoints)
|
||||||
, "Cabal components:\n" ++ render (nest 4 $
|
, "Cabal components:\n" ++ render (nest 4 $
|
||||||
|
Loading…
Reference in New Issue
Block a user