2017-02-14 16:51:55 -08:00
|
|
|
|
diff --git a/src/XMonad/Core.hs b/src/XMonad/Core.hs
|
2018-08-20 18:05:28 -07:00
|
|
|
|
index 7810522..3262934 100644
|
2015-12-22 09:02:15 -08:00
|
|
|
|
--- a/src/XMonad/Core.hs
|
|
|
|
|
+++ b/src/XMonad/Core.hs
|
2018-08-20 18:05:28 -07:00
|
|
|
|
@@ -53,6 +53,7 @@ import System.Posix.Types (ProcessID)
|
2013-12-12 13:33:51 -08:00
|
|
|
|
import System.Process
|
|
|
|
|
import System.Directory
|
|
|
|
|
import System.Exit
|
|
|
|
|
+import System.Environment (lookupEnv)
|
|
|
|
|
import Graphics.X11.Xlib
|
2017-02-14 16:51:55 -08:00
|
|
|
|
import Graphics.X11.Xlib.Extras (getWindowAttributes, WindowAttributes, Event)
|
2013-12-12 13:33:51 -08:00
|
|
|
|
import Data.Typeable
|
2018-08-20 18:05:28 -07:00
|
|
|
|
@@ -601,6 +602,7 @@ recompile force = io $ do
|
2017-02-14 16:51:55 -08:00
|
|
|
|
lib = cfgdir </> "lib"
|
|
|
|
|
buildscript = cfgdir </> "build"
|
|
|
|
|
|
2015-03-08 08:36:37 -07:00
|
|
|
|
+ ghc <- fromMaybe "ghc" <$> liftIO (lookupEnv "NIX_GHC")
|
2013-12-12 13:33:51 -08:00
|
|
|
|
libTs <- mapM getModTime . Prelude.filter isSource =<< allFiles lib
|
|
|
|
|
srcT <- getModTime src
|
|
|
|
|
binT <- getModTime bin
|
2018-08-20 18:05:28 -07:00
|
|
|
|
@@ -643,7 +645,7 @@ recompile force = io $ do
|
2017-02-14 16:51:55 -08:00
|
|
|
|
status <- bracket (openFile err WriteMode) hClose $ \errHandle ->
|
|
|
|
|
waitForProcess =<< if useBuildscript
|
|
|
|
|
then compileScript bin cfgdir buildscript errHandle
|
|
|
|
|
- else compileGHC bin cfgdir errHandle
|
|
|
|
|
+ else compileGHC ghc bin cfgdir errHandle
|
2013-12-12 13:33:51 -08:00
|
|
|
|
|
|
|
|
|
-- re-enable SIGCHLD:
|
2017-02-14 16:51:55 -08:00
|
|
|
|
installSignalHandlers
|
2018-08-20 18:05:28 -07:00
|
|
|
|
@@ -653,6 +655,7 @@ recompile force = io $ do
|
|
|
|
|
then trace "XMonad recompilation process exited with success!"
|
|
|
|
|
else do
|
|
|
|
|
ghcErr <- readFile err
|
|
|
|
|
+ xmessage <- fromMaybe "xmessage" <$> liftIO (lookupEnv "XMONAD_XMESSAGE")
|
|
|
|
|
let msg = unlines $
|
|
|
|
|
["Error detected while loading xmonad configuration file: " ++ src]
|
|
|
|
|
++ lines (if null ghcErr then show status else ghcErr)
|
|
|
|
|
@@ -660,7 +663,7 @@ recompile force = io $ do
|
|
|
|
|
-- nb, the ordering of printing, then forking, is crucial due to
|
|
|
|
|
-- lazy evaluation
|
|
|
|
|
hPutStrLn stderr msg
|
|
|
|
|
- forkProcess $ executeFile "xmessage" True ["-default", "okay", replaceUnicode msg] Nothing
|
|
|
|
|
+ forkProcess $ executeFile xmessage True ["-default", "okay", replaceUnicode msg] Nothing
|
|
|
|
|
return ()
|
2013-12-12 13:33:51 -08:00
|
|
|
|
return (status == ExitSuccess)
|
|
|
|
|
else return True
|
2018-08-20 18:05:28 -07:00
|
|
|
|
@@ -678,16 +681,16 @@ recompile force = io $ do
|
2017-02-14 16:51:55 -08:00
|
|
|
|
'\8216' -> '`' -- ‘
|
|
|
|
|
'\8217' -> '`' -- ’
|
|
|
|
|
_ -> c
|
|
|
|
|
- compileGHC bin dir errHandle =
|
|
|
|
|
- runProcess "ghc" ["--make"
|
|
|
|
|
- , "xmonad.hs"
|
|
|
|
|
- , "-i"
|
|
|
|
|
- , "-ilib"
|
|
|
|
|
- , "-fforce-recomp"
|
|
|
|
|
- , "-main-is", "main"
|
|
|
|
|
- , "-v0"
|
|
|
|
|
- , "-o", bin
|
|
|
|
|
- ] (Just dir) Nothing Nothing Nothing (Just errHandle)
|
|
|
|
|
+ compileGHC ghc bin dir errHandle =
|
|
|
|
|
+ runProcess ghc ["--make"
|
|
|
|
|
+ , "xmonad.hs"
|
|
|
|
|
+ , "-i"
|
|
|
|
|
+ , "-ilib"
|
|
|
|
|
+ , "-fforce-recomp"
|
|
|
|
|
+ , "-main-is", "main"
|
|
|
|
|
+ , "-v0"
|
|
|
|
|
+ , "-o", bin
|
|
|
|
|
+ ] (Just dir) Nothing Nothing Nothing (Just errHandle)
|
|
|
|
|
compileScript bin dir script errHandle =
|
|
|
|
|
runProcess script [bin] (Just dir) Nothing Nothing Nothing (Just errHandle)
|
|
|
|
|
|