summaryrefslogtreecommitdiff
path: root/ghc/GHCi
diff options
context:
space:
mode:
authorTakenobu Tani <takenobu.hs@gmail.com>2019-10-12 14:30:04 +0900
committerMarge Bot <ben+marge-bot@smart-cactus.org>2019-10-23 05:59:00 -0400
commit4798f3b91c23709d7c464004bf07e28c75060c11 (patch)
treedfe7760d495e8095ac02a63e26c1170ef8221320 /ghc/GHCi
parent17987a4b665d4a270b1bebba1f61d67887f2653c (diff)
downloadhaskell-4798f3b91c23709d7c464004bf07e28c75060c11.tar.gz
Allow command name resolution for GHCi commands with option `!` #17345
This commit allows command name resolution for GHCi commands with option `!` as follows: ghci> :k! Int Int :: * = Int This commit changes implementation as follows: Before: * Prefix match with full string including the option `!` (e.g. `k!`) After (this patch): * Prefix match without option suffix `!` (e.g. `k`) * in addition, suffix match with option `!` See also #8305 and #8113
Diffstat (limited to 'ghc/GHCi')
-rw-r--r--ghc/GHCi/UI.hs19
1 files changed, 14 insertions, 5 deletions
diff --git a/ghc/GHCi/UI.hs b/ghc/GHCi/UI.hs
index 0d047de510..e2f51be65f 100644
--- a/ghc/GHCi/UI.hs
+++ b/ghc/GHCi/UI.hs
@@ -102,8 +102,8 @@ import qualified Data.ByteString.Char8 as BS
import Data.Char
import Data.Function
import Data.IORef ( IORef, modifyIORef, newIORef, readIORef, writeIORef )
-import Data.List ( find, group, intercalate, intersperse, isPrefixOf, nub,
- partition, sort, sortBy, (\\) )
+import Data.List ( find, group, intercalate, intersperse, isPrefixOf,
+ isSuffixOf, nub, partition, sort, sortBy, (\\) )
import qualified Data.Set as S
import Data.Maybe
import Data.Map (Map)
@@ -1387,8 +1387,8 @@ lookupCommand' str' = do
':' : rest -> (rest, []) -- "::" selects a builtin command
_ -> (str', macros) -- otherwise include macros in lookup
- lookupExact s = find $ (s ==) . cmdName
- lookupPrefix s = find $ (s `isPrefixOf`) . cmdName
+ lookupExact s = find $ (s ==) . cmdName
+ lookupPrefix s = find $ (s `isPrefixOptOf`) . cmdName
-- hidden commands can only be matched exact
builtinPfxMatch = lookupPrefix str ghci_cmds_nohide
@@ -1402,6 +1402,15 @@ lookupCommand' str' = do
builtinPfxMatch <|>
lookupPrefix str xcmds
+-- This predicate is for prefix match with a command-body and
+-- suffix match with an option, such as `!`.
+-- The current implementation assumes only the `!` character
+-- as the option delimiter.
+-- See also #17345
+isPrefixOptOf :: String -> String -> Bool
+isPrefixOptOf s x = let (body, opt) = break (== '!') s
+ in (body `isPrefixOf` x) && (opt `isSuffixOf` x)
+
getCurrentBreakSpan :: GHC.GhcMonad m => m (Maybe SrcSpan)
getCurrentBreakSpan = do
resumes <- GHC.getResumeContext
@@ -3329,7 +3338,7 @@ completeGhciCommand = wrapCompleter " " $ \w -> do
let{ candidates = case w of
':' : ':' : _ -> map (':':) command_names
_ -> nub $ macro_names ++ command_names }
- return $ filter (w `isPrefixOf`) candidates
+ return $ filter (w `isPrefixOptOf`) candidates
completeMacro = wrapIdentCompleter $ \w -> do
cmds <- ghci_macros <$> getGHCiState