diff options
Diffstat (limited to 'ghc/InteractiveUI.hs')
-rw-r--r-- | ghc/InteractiveUI.hs | 47 |
1 files changed, 33 insertions, 14 deletions
diff --git a/ghc/InteractiveUI.hs b/ghc/InteractiveUI.hs index 7fd9c8b1ab..0727d6b629 100644 --- a/ghc/InteractiveUI.hs +++ b/ghc/InteractiveUI.hs @@ -130,13 +130,10 @@ ghciWelcomeMsg :: String ghciWelcomeMsg = "GHCi, version " ++ cProjectVersion ++ ": http://www.haskell.org/ghc/ :? for help" -cmdName :: Command -> String -cmdName (n,_,_) = n - GLOBAL_VAR(macros_ref, [], [Command]) ghciCommands :: [Command] -ghciCommands = [ +ghciCommands = map mkCmd [ -- Hugs users are accustomed to :e, so make sure it doesn't overlap ("?", keepGoing help, noCompletion), ("add", keepGoingPaths addModule, completeFilename), @@ -148,7 +145,6 @@ ghciCommands = [ ("cd", keepGoing' changeDirectory, completeFilename), ("check", keepGoing' checkModule, completeHomeModule), ("continue", keepGoing continueCmd, noCompletion), - ("complete", keepGoing completeCmd, noCompletion), ("cmd", keepGoing cmdCmd, completeExpression), ("ctags", keepGoing createCTagsWithLineNumbersCmd, completeFilename), ("ctags!", keepGoing createCTagsWithRegExesCmd, completeFilename), @@ -189,8 +185,21 @@ ghciCommands = [ ("trace", keepGoing traceCmd, completeExpression), ("undef", keepGoing undefineMacro, completeMacro), ("unset", keepGoing unsetOptions, completeSetOptions) + ] ++ map mkCmdHidden [ -- hidden commands + ("complete", keepGoing completeCmd) ] - + where + mkCmd (n,a,c) = Command { cmdName = n + , cmdAction = a + , cmdHidden = False + , cmdCompletionFunc = c + } + + mkCmdHidden (n,a) = Command { cmdName = n + , cmdAction = a + , cmdHidden = True + , cmdCompletionFunc = noCompletion + } -- We initialize readline (in the interactiveUI function) to use -- word_break_chars as the default set of completion word break characters. @@ -1019,7 +1028,7 @@ specialCommand str = do maybe_cmd <- lift $ lookupCommand cmd htxt <- short_help <$> getGHCiState case maybe_cmd of - GotCommand (_,f,_) -> f (dropWhile isSpace rest) + GotCommand cmd -> (cmdAction cmd) (dropWhile isSpace rest) BadCommand -> do liftIO $ hPutStr stdout ("unknown command ':" ++ cmd ++ "'\n" ++ htxt) @@ -1049,7 +1058,10 @@ lookupCommand' :: String -> GHCi (Maybe Command) lookupCommand' ":" = return Nothing lookupCommand' str' = do macros <- liftIO $ readIORef macros_ref - ghci_cmds <- ghci_commands `fmap` getGHCiState + ghci_cmds <- ghci_commands <$> getGHCiState + + let ghci_cmds_nohide = filter (not . cmdHidden) ghci_cmds + let (str, xcmds) = case str' of ':' : rest -> (rest, []) -- "::" selects a builtin command _ -> (str', macros) -- otherwise include macros in lookup @@ -1057,7 +1069,8 @@ lookupCommand' str' = do lookupExact s = find $ (s ==) . cmdName lookupPrefix s = find $ (s `isPrefixOf`) . cmdName - builtinPfxMatch = lookupPrefix str ghci_cmds + -- hidden commands can only be matched exact + builtinPfxMatch = lookupPrefix str ghci_cmds_nohide -- first, look for exact match (while preferring macros); then, look -- for first prefix match (preferring builtins), *unless* a macro @@ -1307,8 +1320,14 @@ defineMacro overwrite s = do new_expr = L (getLoc expr) $ ExprWithTySig body tySig hv <- GHC.compileParsedExpr new_expr - liftIO (writeIORef macros_ref -- later defined macros have precedence - ((macro_name, lift . runMacro hv, noCompletion) : filtered)) + let newCmd = Command { cmdName = macro_name + , cmdAction = lift . runMacro hv + , cmdHidden = False + , cmdCompletionFunc = noCompletion + } + + -- later defined macros have precedence + liftIO $ writeIORef macros_ref (newCmd : filtered) runMacro :: GHC.HValue{-String -> IO String-} -> String -> GHCi Bool runMacro fun s = do @@ -2533,14 +2552,14 @@ ghciCompleteWord line@(left,_) = case firstWord of lookupCompletion c = do maybe_cmd <- lookupCommand' c case maybe_cmd of - Just (_,_,f) -> return f - Nothing -> return completeFilename + Just cmd -> return (cmdCompletionFunc cmd) + Nothing -> return completeFilename completeGhciCommand = wrapCompleter " " $ \w -> do macros <- liftIO $ readIORef macros_ref cmds <- ghci_commands `fmap` getGHCiState let macro_names = map (':':) . map cmdName $ macros - let command_names = map (':':) . map cmdName $ cmds + let command_names = map (':':) . map cmdName $ filter (not . cmdHidden) cmds let{ candidates = case w of ':' : ':' : _ -> map (':':) command_names _ -> nub $ macro_names ++ command_names } |