Skip to content

Commit

Permalink
Adds --ide-backend-tools-path and --extra-path
Browse files Browse the repository at this point in the history
With `--ide-backend-tools-path` one can indicate where to search for
`ide-backend-server` and `ide-backend-exe-cabal` binaries. If not given,
defaults to system path (but note that the system path won't be used
as well if a value for this arg is given).

With `--extra-path` one can provide an additional path that will be
additionally used when searching for `ghc`, `ide-backend-server`,
etc. It replaces the previous `--path` argument.
  • Loading branch information
jcpetruzza committed Jul 22, 2015
1 parent c4a02ae commit 34da7fa
Showing 1 changed file with 40 additions and 13 deletions.
53 changes: 40 additions & 13 deletions stack-ide/src/Stack/Ide/CmdLine.hs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE OverloadedStrings #-}
module Stack.Ide.CmdLine (
Expand Down Expand Up @@ -94,7 +96,7 @@ parseInitParams = SessionInitParams
xs <|> fld defaultSessionInitParams

parseConfig :: Parser SessionConfig
parseConfig = SessionConfig
parseConfig = mkSessionConfig
<$> (strOption $ mconcat [
long "dir"
, metavar "DIR"
Expand All @@ -110,14 +112,21 @@ parseConfig = SessionConfig
, "If this is passed, then there's no need for the editor to send the source / data files to the backend. Instead, it just directly uses the files."
]
])
<*> (fmap splitSearchPath' . strOption $ mconcat [
long "ide-backend-tools-path"
, metavar "PATH"
, value ""
, help "Path to search for suitable binaries of ide-backend-server and ide-backend-exe-cabal. Defaults to system path."
])
<*> (defaultTo configExtraPathDirs . fmap splitSearchPath' . strOption $ mconcat [
long "path"
long "extra-path"
, metavar "PATH"
, value ""
, help "Additional search path to add to search for tools (ghc, ide-backend-server, etc.)."
, helpDoc . Just $ Doc.vcat [
"Additional search path to add to search for every tools (ghc, ide-backend-server, etc.)."
, "Useful for overriding default locations."
]
])
<*> useDefault configInProcess
<*> useDefault configGenerateModInfo
<*> (fmap mkPackageDBStack . strOption $ mconcat [
long "package-db"
, metavar "DIR"
Expand All @@ -127,19 +136,11 @@ parseConfig = SessionConfig
, autoWrap "This takes the form of a search path; the resulting DB stack will consist of the global DB and the specified specific DBs."
]
])
<*> useDefault configLicenseExc
<*> useDefault configLicenseFixed
<*> useDefault configLog
<*> (fmap not . switch $ mconcat [
long "keep-tmp-files"
, help "Do not delete the session directory on termination"
])
<*> useDefault configIdeBackendServer
<*> useDefault configIdeBackendExeCabal
where
useDefault :: (SessionConfig -> a) -> Parser a
useDefault fld = pure (fld defaultSessionConfig)

defaultTo :: (SessionConfig -> [a]) -> Parser [a] -> Parser [a]
defaultTo fld = fmap $ \xs ->
case xs of
Expand All @@ -151,6 +152,32 @@ parseConfig = SessionConfig
mkPackageDBStack path = GlobalPackageDB
: map SpecificPackageDB (splitSearchPath' path)

ide_backend_server = snd $ configIdeBackendServer defaultSessionConfig
ide_backend_exe_cabal = snd $ configIdeBackendExeCabal defaultSessionConfig

mkSessionConfig configDir configLocalWorkingDir toolsPath configExtraPathDirs
configPackageDBStack configDeleteTempFiles
= let
SessionConfig{configInProcess,configGenerateModInfo,configLog,
configLicenseExc,configLicenseFixed}
= defaultSessionConfig

toolsPath' = (map ProgramSearchPathDir configExtraPathDirs) ++ case toolsPath of
[] -> [ProgramSearchPathDefault]
_ -> map ProgramSearchPathDir toolsPath
-- NB. These binaries are tied to the version of ghc being used for the project;
-- so if we are given a specific toolsPath but ide-backend-server is not found there,
-- it is arguably better to just fail, and not use a potentially incorrect version of
-- the binary that could be accidentally installed somewhere on the system path...
-- (e.g. a 'file not found' error is simpler to diagnose for a user than an obscure
-- 'invalid package db format' error)

configIdeBackendServer = (toolsPath', ide_backend_server)
configIdeBackendExeCabal = (toolsPath', ide_backend_exe_cabal)

in SessionConfig{..}


{-------------------------------------------------------------------------------
Top-level API
-------------------------------------------------------------------------------}
Expand Down

0 comments on commit 34da7fa

Please sign in to comment.