{-# LANGUAGE CPP #-}
{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE DuplicateRecordFields #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE MagicHash #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TupleSections #-}
{-# LANGUAGE TypeApplications #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE ViewPatterns #-}
{-# LANGUAGE NamedFieldPuns #-}
module Ide.Plugin.Splice
( descriptor,
)
where
import Control.Applicative (Alternative ((<|>)))
import Control.Arrow
import qualified Control.Foldl as L
import Control.Lens (ix, view, (%~), (<&>), (^.), Identity(..))
import Control.Monad
import Control.Monad.Extra (eitherM)
import qualified Control.Monad.Fail as Fail
import Control.Monad.IO.Unlift
import Control.Monad.Trans.Class
import Control.Monad.Trans.Except
import Control.Monad.Trans.Maybe
import Data.Aeson
import Data.Foldable (Foldable (foldl'))
import Data.Function
import Data.Generics
import qualified Data.Kind as Kinds
import Data.List (sortOn)
import Data.Maybe (fromMaybe, listToMaybe,
mapMaybe)
import qualified Data.Text as T
import Development.IDE
import Development.IDE.GHC.Compat hiding (getLoc)
import Development.IDE.GHC.ExactPrint
import Exception
import GHC.Exts
import GhcMonad
import GhcPlugins hiding (Var, getLoc, (<>))
import Ide.Plugin.Splice.Types
import Ide.Types
import Language.Haskell.GHC.ExactPrint (setPrecedingLines,
uniqueSrcSpanT)
import Language.LSP.Server
import Language.LSP.Types
import Language.LSP.Types.Capabilities
import qualified Language.LSP.Types.Lens as J
import RnSplice
import TcRnMonad
descriptor :: PluginId -> PluginDescriptor IdeState
descriptor :: PluginId -> PluginDescriptor IdeState
descriptor PluginId
plId =
(PluginId -> PluginDescriptor IdeState
forall ideState. PluginId -> PluginDescriptor ideState
defaultPluginDescriptor PluginId
plId)
{ pluginCommands :: [PluginCommand IdeState]
pluginCommands = [PluginCommand IdeState]
commands
, pluginHandlers :: PluginHandlers IdeState
pluginHandlers = SClientMethod 'TextDocumentCodeAction
-> PluginMethodHandler IdeState 'TextDocumentCodeAction
-> PluginHandlers IdeState
forall (m :: Method 'FromClient 'Request) ideState.
PluginMethod m =>
SClientMethod m
-> PluginMethodHandler ideState m -> PluginHandlers ideState
mkPluginHandler SClientMethod 'TextDocumentCodeAction
STextDocumentCodeAction PluginMethodHandler IdeState 'TextDocumentCodeAction
codeAction
}
commands :: [PluginCommand IdeState]
commands :: [PluginCommand IdeState]
commands =
[ CommandId
-> Text
-> CommandFunction IdeState ExpandSpliceParams
-> PluginCommand IdeState
forall ideState a.
FromJSON a =>
CommandId
-> Text -> CommandFunction ideState a -> PluginCommand ideState
PluginCommand CommandId
expandInplaceId Text
inplaceCmdName (CommandFunction IdeState ExpandSpliceParams
-> PluginCommand IdeState)
-> CommandFunction IdeState ExpandSpliceParams
-> PluginCommand IdeState
forall a b. (a -> b) -> a -> b
$ ExpandStyle -> CommandFunction IdeState ExpandSpliceParams
expandTHSplice ExpandStyle
Inplace
]
newtype SubSpan = SubSpan {SubSpan -> SrcSpan
runSubSpan :: SrcSpan}
instance Eq SubSpan where
== :: SubSpan -> SubSpan -> Bool
(==) = SrcSpan -> SrcSpan -> Bool
forall a. Eq a => a -> a -> Bool
(==) (SrcSpan -> SrcSpan -> Bool)
-> (SubSpan -> SrcSpan) -> SubSpan -> SubSpan -> Bool
forall b c a. (b -> b -> c) -> (a -> b) -> a -> a -> c
`on` SubSpan -> SrcSpan
runSubSpan
instance Ord SubSpan where
<= :: SubSpan -> SubSpan -> Bool
(<=) = (SrcSpan -> SrcSpan -> Bool) -> SubSpan -> SubSpan -> Bool
coerce SrcSpan -> SrcSpan -> Bool
isSubspanOf
expandTHSplice ::
ExpandStyle ->
CommandFunction IdeState ExpandSpliceParams
expandTHSplice :: ExpandStyle -> CommandFunction IdeState ExpandSpliceParams
expandTHSplice ExpandStyle
_eStyle IdeState
ideState params :: ExpandSpliceParams
params@ExpandSpliceParams {RealSrcSpan
Uri
SpliceContext
spliceContext :: ExpandSpliceParams -> SpliceContext
spliceSpan :: ExpandSpliceParams -> RealSrcSpan
uri :: ExpandSpliceParams -> Uri
spliceContext :: SpliceContext
spliceSpan :: RealSrcSpan
uri :: Uri
..} = do
ClientCapabilities
clientCapabilities <- LspT Config IO ClientCapabilities
forall config (m :: * -> *).
MonadLsp config m =>
m ClientCapabilities
getClientCapabilities
LspT Config IO () -> IO ()
rio <- LspT Config IO (LspT Config IO () -> IO ())
forall (m :: * -> *) a. MonadUnliftIO m => m (m a -> IO a)
askRunInIO
let reportEditor :: ReportEditor
reportEditor :: MessageType -> [Text] -> m ()
reportEditor MessageType
msgTy [Text]
msgs = IO () -> m ()
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ LspT Config IO () -> IO ()
rio (LspT Config IO () -> IO ()) -> LspT Config IO () -> IO ()
forall a b. (a -> b) -> a -> b
$ SServerMethod 'WindowShowMessage
-> MessageParams 'WindowShowMessage -> LspT Config IO ()
forall (m :: Method 'FromServer 'Notification) (f :: * -> *)
config.
MonadLsp config f =>
SServerMethod m -> MessageParams m -> f ()
sendNotification SServerMethod 'WindowShowMessage
SWindowShowMessage (MessageType -> Text -> ShowMessageParams
ShowMessageParams MessageType
msgTy ([Text] -> Text
T.unlines [Text]
msgs))
expandManually :: NormalizedFilePath -> ExceptT String IO WorkspaceEdit
expandManually NormalizedFilePath
fp = do
Maybe (TcModuleResult, PositionMapping)
mresl <-
IO (Maybe (TcModuleResult, PositionMapping))
-> ExceptT String IO (Maybe (TcModuleResult, PositionMapping))
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe (TcModuleResult, PositionMapping))
-> ExceptT String IO (Maybe (TcModuleResult, PositionMapping)))
-> IO (Maybe (TcModuleResult, PositionMapping))
-> ExceptT String IO (Maybe (TcModuleResult, PositionMapping))
forall a b. (a -> b) -> a -> b
$ String
-> IdeState
-> Action (Maybe (TcModuleResult, PositionMapping))
-> IO (Maybe (TcModuleResult, PositionMapping))
forall a. String -> IdeState -> Action a -> IO a
runAction String
"expandTHSplice.fallback.TypeCheck (stale)" IdeState
ideState (Action (Maybe (TcModuleResult, PositionMapping))
-> IO (Maybe (TcModuleResult, PositionMapping)))
-> Action (Maybe (TcModuleResult, PositionMapping))
-> IO (Maybe (TcModuleResult, PositionMapping))
forall a b. (a -> b) -> a -> b
$ TypeCheck
-> NormalizedFilePath
-> Action (Maybe (TcModuleResult, PositionMapping))
forall k v.
IdeRule k v =>
k -> NormalizedFilePath -> Action (Maybe (v, PositionMapping))
useWithStale TypeCheck
TypeCheck NormalizedFilePath
fp
(TcModuleResult {Bool
RenamedSource
ParsedModule
TcGblEnv
Splices
tmrParsed :: TcModuleResult -> ParsedModule
tmrRenamed :: TcModuleResult -> RenamedSource
tmrTypechecked :: TcModuleResult -> TcGblEnv
tmrTopLevelSplices :: TcModuleResult -> Splices
tmrDeferedError :: TcModuleResult -> Bool
tmrDeferedError :: Bool
tmrTopLevelSplices :: Splices
tmrTypechecked :: TcGblEnv
tmrRenamed :: RenamedSource
tmrParsed :: ParsedModule
..}, PositionMapping
_) <-
ExceptT String IO (TcModuleResult, PositionMapping)
-> ((TcModuleResult, PositionMapping)
-> ExceptT String IO (TcModuleResult, PositionMapping))
-> Maybe (TcModuleResult, PositionMapping)
-> ExceptT String IO (TcModuleResult, PositionMapping)
forall b a. b -> (a -> b) -> Maybe a -> b
maybe
(String -> ExceptT String IO (TcModuleResult, PositionMapping)
forall (m :: * -> *) e a. Monad m => e -> ExceptT e m a
throwE String
"Splice expansion: Type-checking information not found in cache.\nYou can once delete or replace the macro with placeholder, convince the type checker and then revert to original (errornous) macro and expand splice again."
)
(TcModuleResult, PositionMapping)
-> ExceptT String IO (TcModuleResult, PositionMapping)
forall (f :: * -> *) a. Applicative f => a -> f a
pure Maybe (TcModuleResult, PositionMapping)
mresl
MessageType -> [Text] -> ExceptT String IO ()
ReportEditor
reportEditor
MessageType
MtWarning
[ Text
"Expansion in type-chcking phase failed;"
, Text
"trying to expand manually, but note taht it is less rigorous."
]
ParsedModule
pm <-
IO ParsedModule -> ExceptT String IO ParsedModule
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO ParsedModule -> ExceptT String IO ParsedModule)
-> IO ParsedModule -> ExceptT String IO ParsedModule
forall a b. (a -> b) -> a -> b
$
String -> IdeState -> Action ParsedModule -> IO ParsedModule
forall a. String -> IdeState -> Action a -> IO a
runAction String
"expandTHSplice.fallback.GetParsedModule" IdeState
ideState (Action ParsedModule -> IO ParsedModule)
-> Action ParsedModule -> IO ParsedModule
forall a b. (a -> b) -> a -> b
$
GetParsedModule -> NormalizedFilePath -> Action ParsedModule
forall k v. IdeRule k v => k -> NormalizedFilePath -> Action v
use_ GetParsedModule
GetParsedModule NormalizedFilePath
fp
(Annotated ParsedSource
ps, HscEnv
hscEnv, DynFlags
_dflags) <- IdeState
-> NormalizedFilePath
-> ParsedModule
-> ExceptT String IO (Annotated ParsedSource, HscEnv, DynFlags)
setupHscEnv IdeState
ideState NormalizedFilePath
fp ParsedModule
pm
ClientCapabilities
-> ReportEditor
-> Range
-> Annotated ParsedSource
-> HscEnv
-> TcGblEnv
-> RealSrcSpan
-> ExpandStyle
-> ExpandSpliceParams
-> ExceptT String IO WorkspaceEdit
manualCalcEdit
ClientCapabilities
clientCapabilities
ReportEditor
reportEditor
Range
range
Annotated ParsedSource
ps
HscEnv
hscEnv
TcGblEnv
tmrTypechecked
RealSrcSpan
spliceSpan
ExpandStyle
_eStyle
ExpandSpliceParams
params
withTypeChecked :: NormalizedFilePath
-> TcModuleResult -> ExceptT String IO WorkspaceEdit
withTypeChecked NormalizedFilePath
fp TcModuleResult {Bool
RenamedSource
ParsedModule
TcGblEnv
Splices
tmrDeferedError :: Bool
tmrTopLevelSplices :: Splices
tmrTypechecked :: TcGblEnv
tmrRenamed :: RenamedSource
tmrParsed :: ParsedModule
tmrParsed :: TcModuleResult -> ParsedModule
tmrRenamed :: TcModuleResult -> RenamedSource
tmrTypechecked :: TcModuleResult -> TcGblEnv
tmrTopLevelSplices :: TcModuleResult -> Splices
tmrDeferedError :: TcModuleResult -> Bool
..} = do
(Annotated ParsedSource
ps, HscEnv
_hscEnv, DynFlags
dflags) <- IdeState
-> NormalizedFilePath
-> ParsedModule
-> ExceptT String IO (Annotated ParsedSource, HscEnv, DynFlags)
setupHscEnv IdeState
ideState NormalizedFilePath
fp ParsedModule
tmrParsed
let Splices {[(LHsExpr GhcTc, [LHsDecl GhcPs])]
[(LHsExpr GhcTc, Serialized)]
[(LHsExpr GhcTc, LPat GhcPs)]
[(LHsExpr GhcTc, LHsType GhcPs)]
[(LHsExpr GhcTc, LHsExpr GhcPs)]
exprSplices :: Splices -> [(LHsExpr GhcTc, LHsExpr GhcPs)]
patSplices :: Splices -> [(LHsExpr GhcTc, LPat GhcPs)]
typeSplices :: Splices -> [(LHsExpr GhcTc, LHsType GhcPs)]
declSplices :: Splices -> [(LHsExpr GhcTc, [LHsDecl GhcPs])]
awSplices :: Splices -> [(LHsExpr GhcTc, Serialized)]
awSplices :: [(LHsExpr GhcTc, Serialized)]
declSplices :: [(LHsExpr GhcTc, [LHsDecl GhcPs])]
typeSplices :: [(LHsExpr GhcTc, LHsType GhcPs)]
patSplices :: [(LHsExpr GhcTc, LPat GhcPs)]
exprSplices :: [(LHsExpr GhcTc, LHsExpr GhcPs)]
..} = Splices
tmrTopLevelSplices
let exprSuperSpans :: Maybe (SrcSpan, LHsExpr GhcPs)
exprSuperSpans =
[(SrcSpan, LHsExpr GhcPs)] -> Maybe (SrcSpan, LHsExpr GhcPs)
forall a. [a] -> Maybe a
listToMaybe ([(SrcSpan, LHsExpr GhcPs)] -> Maybe (SrcSpan, LHsExpr GhcPs))
-> [(SrcSpan, LHsExpr GhcPs)] -> Maybe (SrcSpan, LHsExpr GhcPs)
forall a b. (a -> b) -> a -> b
$ SrcSpan
-> [(LHsExpr GhcTc, LHsExpr GhcPs)] -> [(SrcSpan, LHsExpr GhcPs)]
forall a. SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc SrcSpan
srcSpan [(LHsExpr GhcTc, LHsExpr GhcPs)]
exprSplices
_patSuperSpans :: Maybe (SrcSpan, Located (Pat GhcPs))
_patSuperSpans =
#if __GLASGOW_HASKELL__ == 808
fmap (second dL) $
#endif
[(SrcSpan, Located (Pat GhcPs))]
-> Maybe (SrcSpan, Located (Pat GhcPs))
forall a. [a] -> Maybe a
listToMaybe ([(SrcSpan, Located (Pat GhcPs))]
-> Maybe (SrcSpan, Located (Pat GhcPs)))
-> [(SrcSpan, Located (Pat GhcPs))]
-> Maybe (SrcSpan, Located (Pat GhcPs))
forall a b. (a -> b) -> a -> b
$ SrcSpan
-> [(LHsExpr GhcTc, Located (Pat GhcPs))]
-> [(SrcSpan, Located (Pat GhcPs))]
forall a. SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc SrcSpan
srcSpan [(LHsExpr GhcTc, LPat GhcPs)]
[(LHsExpr GhcTc, Located (Pat GhcPs))]
patSplices
typeSuperSpans :: Maybe (SrcSpan, LHsType GhcPs)
typeSuperSpans =
[(SrcSpan, LHsType GhcPs)] -> Maybe (SrcSpan, LHsType GhcPs)
forall a. [a] -> Maybe a
listToMaybe ([(SrcSpan, LHsType GhcPs)] -> Maybe (SrcSpan, LHsType GhcPs))
-> [(SrcSpan, LHsType GhcPs)] -> Maybe (SrcSpan, LHsType GhcPs)
forall a b. (a -> b) -> a -> b
$ SrcSpan
-> [(LHsExpr GhcTc, LHsType GhcPs)] -> [(SrcSpan, LHsType GhcPs)]
forall a. SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc SrcSpan
srcSpan [(LHsExpr GhcTc, LHsType GhcPs)]
typeSplices
declSuperSpans :: Maybe (SrcSpan, [LHsDecl GhcPs])
declSuperSpans =
[(SrcSpan, [LHsDecl GhcPs])] -> Maybe (SrcSpan, [LHsDecl GhcPs])
forall a. [a] -> Maybe a
listToMaybe ([(SrcSpan, [LHsDecl GhcPs])] -> Maybe (SrcSpan, [LHsDecl GhcPs]))
-> [(SrcSpan, [LHsDecl GhcPs])] -> Maybe (SrcSpan, [LHsDecl GhcPs])
forall a b. (a -> b) -> a -> b
$ SrcSpan
-> [(LHsExpr GhcTc, [LHsDecl GhcPs])]
-> [(SrcSpan, [LHsDecl GhcPs])]
forall a. SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc SrcSpan
srcSpan [(LHsExpr GhcTc, [LHsDecl GhcPs])]
declSplices
graftSpliceWith ::
forall ast.
HasSplice ast =>
Maybe (SrcSpan, Located (ast GhcPs)) ->
Maybe (Either String WorkspaceEdit)
graftSpliceWith :: Maybe (SrcSpan, Located (ast GhcPs))
-> Maybe (Either String WorkspaceEdit)
graftSpliceWith Maybe (SrcSpan, Located (ast GhcPs))
expandeds =
Maybe (SrcSpan, Located (ast GhcPs))
expandeds Maybe (SrcSpan, Located (ast GhcPs))
-> ((SrcSpan, Located (ast GhcPs)) -> Either String WorkspaceEdit)
-> Maybe (Either String WorkspaceEdit)
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> \(SrcSpan
_, Located (ast GhcPs)
expanded) ->
DynFlags
-> ClientCapabilities
-> Uri
-> Graft (Either String) ParsedSource
-> Annotated ParsedSource
-> Either String WorkspaceEdit
transform
DynFlags
dflags
ClientCapabilities
clientCapabilities
Uri
uri
(SrcSpan
-> Located (ast GhcPs) -> Graft (Either String) ParsedSource
forall ast a.
(ASTElement ast, Data a) =>
SrcSpan -> Located ast -> Graft (Either String) a
graft (RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spliceSpan) Located (ast GhcPs)
expanded)
Annotated ParsedSource
ps
ExceptT String IO WorkspaceEdit
-> (Either String WorkspaceEdit -> ExceptT String IO WorkspaceEdit)
-> Maybe (Either String WorkspaceEdit)
-> ExceptT String IO WorkspaceEdit
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (String -> ExceptT String IO WorkspaceEdit
forall (m :: * -> *) e a. Monad m => e -> ExceptT e m a
throwE String
"No splice information found") ((String -> ExceptT String IO WorkspaceEdit)
-> (WorkspaceEdit -> ExceptT String IO WorkspaceEdit)
-> Either String WorkspaceEdit
-> ExceptT String IO WorkspaceEdit
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either String -> ExceptT String IO WorkspaceEdit
forall (m :: * -> *) e a. Monad m => e -> ExceptT e m a
throwE WorkspaceEdit -> ExceptT String IO WorkspaceEdit
forall (f :: * -> *) a. Applicative f => a -> f a
pure) (Maybe (Either String WorkspaceEdit)
-> ExceptT String IO WorkspaceEdit)
-> Maybe (Either String WorkspaceEdit)
-> ExceptT String IO WorkspaceEdit
forall a b. (a -> b) -> a -> b
$
case SpliceContext
spliceContext of
SpliceContext
Expr -> Maybe (SrcSpan, LHsExpr GhcPs)
-> Maybe (Either String WorkspaceEdit)
forall (ast :: * -> *).
HasSplice ast =>
Maybe (SrcSpan, Located (ast GhcPs))
-> Maybe (Either String WorkspaceEdit)
graftSpliceWith Maybe (SrcSpan, LHsExpr GhcPs)
exprSuperSpans
SpliceContext
Pat ->
Maybe (SrcSpan, Located (Pat GhcPs))
-> Maybe (Either String WorkspaceEdit)
forall (ast :: * -> *).
HasSplice ast =>
Maybe (SrcSpan, Located (ast GhcPs))
-> Maybe (Either String WorkspaceEdit)
graftSpliceWith Maybe (SrcSpan, Located (Pat GhcPs))
_patSuperSpans
SpliceContext
HsType -> Maybe (SrcSpan, LHsType GhcPs)
-> Maybe (Either String WorkspaceEdit)
forall (ast :: * -> *).
HasSplice ast =>
Maybe (SrcSpan, Located (ast GhcPs))
-> Maybe (Either String WorkspaceEdit)
graftSpliceWith Maybe (SrcSpan, LHsType GhcPs)
typeSuperSpans
SpliceContext
HsDecl ->
Maybe (SrcSpan, [LHsDecl GhcPs])
declSuperSpans Maybe (SrcSpan, [LHsDecl GhcPs])
-> ((SrcSpan, [LHsDecl GhcPs]) -> Either String WorkspaceEdit)
-> Maybe (Either String WorkspaceEdit)
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> \(SrcSpan
_, [LHsDecl GhcPs]
expanded) ->
DynFlags
-> ClientCapabilities
-> Uri
-> Graft (Either String) ParsedSource
-> Annotated ParsedSource
-> Either String WorkspaceEdit
transform
DynFlags
dflags
ClientCapabilities
clientCapabilities
Uri
uri
(SrcSpan -> [LHsDecl GhcPs] -> Graft (Either String) ParsedSource
forall a.
HasDecls a =>
SrcSpan -> [LHsDecl GhcPs] -> Graft (Either String) a
graftDecls (RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spliceSpan) [LHsDecl GhcPs]
expanded)
Annotated ParsedSource
ps
Either String WorkspaceEdit
-> (WorkspaceEdit -> WorkspaceEdit) -> Either String WorkspaceEdit
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&>
Uri -> Range -> WorkspaceEdit -> WorkspaceEdit
adjustToRange Uri
uri Range
range
Maybe (Either ResponseError WorkspaceEdit)
res <- IO (Maybe (Either ResponseError WorkspaceEdit))
-> LspT Config IO (Maybe (Either ResponseError WorkspaceEdit))
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Maybe (Either ResponseError WorkspaceEdit))
-> LspT Config IO (Maybe (Either ResponseError WorkspaceEdit)))
-> IO (Maybe (Either ResponseError WorkspaceEdit))
-> LspT Config IO (Maybe (Either ResponseError WorkspaceEdit))
forall a b. (a -> b) -> a -> b
$ MaybeT IO (Either ResponseError WorkspaceEdit)
-> IO (Maybe (Either ResponseError WorkspaceEdit))
forall (m :: * -> *) a. MaybeT m a -> m (Maybe a)
runMaybeT (MaybeT IO (Either ResponseError WorkspaceEdit)
-> IO (Maybe (Either ResponseError WorkspaceEdit)))
-> MaybeT IO (Either ResponseError WorkspaceEdit)
-> IO (Maybe (Either ResponseError WorkspaceEdit))
forall a b. (a -> b) -> a -> b
$ do
NormalizedFilePath
fp <- IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath
forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT (IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath)
-> IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath
forall a b. (a -> b) -> a -> b
$ Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath))
-> Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath)
forall a b. (a -> b) -> a -> b
$ NormalizedUri -> Maybe NormalizedFilePath
uriToNormalizedFilePath (NormalizedUri -> Maybe NormalizedFilePath)
-> NormalizedUri -> Maybe NormalizedFilePath
forall a b. (a -> b) -> a -> b
$ Uri -> NormalizedUri
toNormalizedUri Uri
uri
Either String WorkspaceEdit
eedits <-
( IO (Either String WorkspaceEdit)
-> MaybeT IO (Either String WorkspaceEdit)
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IO (Either String WorkspaceEdit)
-> MaybeT IO (Either String WorkspaceEdit))
-> (TcModuleResult -> IO (Either String WorkspaceEdit))
-> TcModuleResult
-> MaybeT IO (Either String WorkspaceEdit)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ExceptT String IO WorkspaceEdit -> IO (Either String WorkspaceEdit)
forall e (m :: * -> *) a. ExceptT e m a -> m (Either e a)
runExceptT (ExceptT String IO WorkspaceEdit
-> IO (Either String WorkspaceEdit))
-> (TcModuleResult -> ExceptT String IO WorkspaceEdit)
-> TcModuleResult
-> IO (Either String WorkspaceEdit)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. NormalizedFilePath
-> TcModuleResult -> ExceptT String IO WorkspaceEdit
withTypeChecked NormalizedFilePath
fp
(TcModuleResult -> MaybeT IO (Either String WorkspaceEdit))
-> MaybeT IO TcModuleResult
-> MaybeT IO (Either String WorkspaceEdit)
forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< IO (Maybe TcModuleResult) -> MaybeT IO TcModuleResult
forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT
(String
-> IdeState
-> Action (Maybe TcModuleResult)
-> IO (Maybe TcModuleResult)
forall a. String -> IdeState -> Action a -> IO a
runAction String
"expandTHSplice.TypeCheck" IdeState
ideState (Action (Maybe TcModuleResult) -> IO (Maybe TcModuleResult))
-> Action (Maybe TcModuleResult) -> IO (Maybe TcModuleResult)
forall a b. (a -> b) -> a -> b
$ TypeCheck -> NormalizedFilePath -> Action (Maybe TcModuleResult)
forall k v.
IdeRule k v =>
k -> NormalizedFilePath -> Action (Maybe v)
use TypeCheck
TypeCheck NormalizedFilePath
fp)
)
MaybeT IO (Either String WorkspaceEdit)
-> MaybeT IO (Either String WorkspaceEdit)
-> MaybeT IO (Either String WorkspaceEdit)
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
<|> IO (Either String WorkspaceEdit)
-> MaybeT IO (Either String WorkspaceEdit)
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (ExceptT String IO WorkspaceEdit -> IO (Either String WorkspaceEdit)
forall e (m :: * -> *) a. ExceptT e m a -> m (Either e a)
runExceptT (ExceptT String IO WorkspaceEdit
-> IO (Either String WorkspaceEdit))
-> ExceptT String IO WorkspaceEdit
-> IO (Either String WorkspaceEdit)
forall a b. (a -> b) -> a -> b
$ NormalizedFilePath -> ExceptT String IO WorkspaceEdit
expandManually NormalizedFilePath
fp)
case Either String WorkspaceEdit
eedits of
Left String
err -> do
MessageType -> [Text] -> MaybeT IO ()
ReportEditor
reportEditor
MessageType
MtError
[Text
"Error during expanding splice: " Text -> Text -> Text
forall a. Semigroup a => a -> a -> a
<> String -> Text
T.pack String
err]
Either ResponseError WorkspaceEdit
-> MaybeT IO (Either ResponseError WorkspaceEdit)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (ResponseError -> Either ResponseError WorkspaceEdit
forall a b. a -> Either a b
Left (ResponseError -> Either ResponseError WorkspaceEdit)
-> ResponseError -> Either ResponseError WorkspaceEdit
forall a b. (a -> b) -> a -> b
$ Text -> ResponseError
responseError (Text -> ResponseError) -> Text -> ResponseError
forall a b. (a -> b) -> a -> b
$ String -> Text
T.pack String
err)
Right WorkspaceEdit
edits ->
Either ResponseError WorkspaceEdit
-> MaybeT IO (Either ResponseError WorkspaceEdit)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (WorkspaceEdit -> Either ResponseError WorkspaceEdit
forall a b. b -> Either a b
Right WorkspaceEdit
edits)
case Maybe (Either ResponseError WorkspaceEdit)
res of
Maybe (Either ResponseError WorkspaceEdit)
Nothing -> Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either ResponseError Value
-> LspM Config (Either ResponseError Value))
-> Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall a b. (a -> b) -> a -> b
$ Value -> Either ResponseError Value
forall a b. b -> Either a b
Right Value
Null
Just (Left ResponseError
err) -> Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either ResponseError Value
-> LspM Config (Either ResponseError Value))
-> Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall a b. (a -> b) -> a -> b
$ ResponseError -> Either ResponseError Value
forall a b. a -> Either a b
Left ResponseError
err
Just (Right WorkspaceEdit
edit) -> do
LspId 'WorkspaceApplyEdit
_ <- SServerMethod 'WorkspaceApplyEdit
-> MessageParams 'WorkspaceApplyEdit
-> (Either ResponseError (ResponseResult 'WorkspaceApplyEdit)
-> LspT Config IO ())
-> LspT Config IO (LspId 'WorkspaceApplyEdit)
forall (m :: Method 'FromServer 'Request) (f :: * -> *) config.
MonadLsp config f =>
SServerMethod m
-> MessageParams m
-> (Either ResponseError (ResponseResult m) -> f ())
-> f (LspId m)
sendRequest SServerMethod 'WorkspaceApplyEdit
SWorkspaceApplyEdit (Maybe Text -> WorkspaceEdit -> ApplyWorkspaceEditParams
ApplyWorkspaceEditParams Maybe Text
forall a. Maybe a
Nothing WorkspaceEdit
edit) (\Either ResponseError (ResponseResult 'WorkspaceApplyEdit)
_ -> () -> LspT Config IO ()
forall (f :: * -> *) a. Applicative f => a -> f a
pure ())
Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either ResponseError Value
-> LspM Config (Either ResponseError Value))
-> Either ResponseError Value
-> LspM Config (Either ResponseError Value)
forall a b. (a -> b) -> a -> b
$ Value -> Either ResponseError Value
forall a b. b -> Either a b
Right Value
Null
where
range :: Range
range = RealSrcSpan -> Range
realSrcSpanToRange RealSrcSpan
spliceSpan
srcSpan :: SrcSpan
srcSpan = RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spliceSpan
setupHscEnv
:: IdeState
-> NormalizedFilePath
-> ParsedModule
-> ExceptT String IO (Annotated ParsedSource, HscEnv, DynFlags)
setupHscEnv :: IdeState
-> NormalizedFilePath
-> ParsedModule
-> ExceptT String IO (Annotated ParsedSource, HscEnv, DynFlags)
setupHscEnv IdeState
ideState NormalizedFilePath
fp ParsedModule
pm = do
HscEnvEq
hscEnvEq <-
IO HscEnvEq -> ExceptT String IO HscEnvEq
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO HscEnvEq -> ExceptT String IO HscEnvEq)
-> IO HscEnvEq -> ExceptT String IO HscEnvEq
forall a b. (a -> b) -> a -> b
$
String -> IdeState -> Action HscEnvEq -> IO HscEnvEq
forall a. String -> IdeState -> Action a -> IO a
runAction String
"expandTHSplice.fallback.ghcSessionDeps" IdeState
ideState (Action HscEnvEq -> IO HscEnvEq) -> Action HscEnvEq -> IO HscEnvEq
forall a b. (a -> b) -> a -> b
$
GhcSessionDeps -> NormalizedFilePath -> Action HscEnvEq
forall k v. IdeRule k v => k -> NormalizedFilePath -> Action v
use_ GhcSessionDeps
GhcSessionDeps NormalizedFilePath
fp
let ps :: Annotated ParsedSource
ps = ParsedModule -> Annotated ParsedSource
annotateParsedSource ParsedModule
pm
hscEnv0 :: HscEnv
hscEnv0 = HscEnvEq -> HscEnv
hscEnvWithImportPaths HscEnvEq
hscEnvEq
modSum :: ModSummary
modSum = ParsedModule -> ModSummary
pm_mod_summary ParsedModule
pm
DynFlags
df' <- IO DynFlags -> ExceptT String IO DynFlags
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO DynFlags -> ExceptT String IO DynFlags)
-> IO DynFlags -> ExceptT String IO DynFlags
forall a b. (a -> b) -> a -> b
$ HscEnv -> DynFlags -> IO DynFlags
setupDynFlagsForGHCiLike HscEnv
hscEnv0 (DynFlags -> IO DynFlags) -> DynFlags -> IO DynFlags
forall a b. (a -> b) -> a -> b
$ ModSummary -> DynFlags
ms_hspp_opts ModSummary
modSum
let hscEnv :: HscEnv
hscEnv = HscEnv
hscEnv0 { hsc_dflags :: DynFlags
hsc_dflags = DynFlags
df' }
(Annotated ParsedSource, HscEnv, DynFlags)
-> ExceptT String IO (Annotated ParsedSource, HscEnv, DynFlags)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Annotated ParsedSource
ps, HscEnv
hscEnv, DynFlags
df')
setupDynFlagsForGHCiLike :: HscEnv -> DynFlags -> IO DynFlags
setupDynFlagsForGHCiLike :: HscEnv -> DynFlags -> IO DynFlags
setupDynFlagsForGHCiLike HscEnv
env DynFlags
dflags = do
let dflags3 :: DynFlags
dflags3 =
DynFlags
dflags
{ hscTarget :: HscTarget
hscTarget = HscTarget
HscInterpreted
, ghcMode :: GhcMode
ghcMode = GhcMode
CompManager
, ghcLink :: GhcLink
ghcLink = GhcLink
LinkInMemory
}
platform :: Platform
platform = DynFlags -> Platform
targetPlatform DynFlags
dflags3
dflags3a :: DynFlags
dflags3a = DynFlags -> DynFlags
updateWays (DynFlags -> DynFlags) -> DynFlags -> DynFlags
forall a b. (a -> b) -> a -> b
$ DynFlags
dflags3 {ways :: [Way]
ways = [Way]
interpWays}
dflags3b :: DynFlags
dflags3b =
(DynFlags -> GeneralFlag -> DynFlags)
-> DynFlags -> [GeneralFlag] -> DynFlags
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl DynFlags -> GeneralFlag -> DynFlags
gopt_set DynFlags
dflags3a ([GeneralFlag] -> DynFlags) -> [GeneralFlag] -> DynFlags
forall a b. (a -> b) -> a -> b
$
(Way -> [GeneralFlag]) -> [Way] -> [GeneralFlag]
forall (t :: * -> *) a b. Foldable t => (a -> [b]) -> t a -> [b]
concatMap (Platform -> Way -> [GeneralFlag]
wayGeneralFlags Platform
platform) [Way]
interpWays
dflags3c :: DynFlags
dflags3c =
(DynFlags -> GeneralFlag -> DynFlags)
-> DynFlags -> [GeneralFlag] -> DynFlags
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl DynFlags -> GeneralFlag -> DynFlags
gopt_unset DynFlags
dflags3b ([GeneralFlag] -> DynFlags) -> [GeneralFlag] -> DynFlags
forall a b. (a -> b) -> a -> b
$
(Way -> [GeneralFlag]) -> [Way] -> [GeneralFlag]
forall (t :: * -> *) a b. Foldable t => (a -> [b]) -> t a -> [b]
concatMap (Platform -> Way -> [GeneralFlag]
wayUnsetGeneralFlags Platform
platform) [Way]
interpWays
dflags4 :: DynFlags
dflags4 =
DynFlags
dflags3c
DynFlags -> GeneralFlag -> DynFlags
`gopt_set` GeneralFlag
Opt_ImplicitImportQualified
DynFlags -> GeneralFlag -> DynFlags
`gopt_set` GeneralFlag
Opt_IgnoreOptimChanges
DynFlags -> GeneralFlag -> DynFlags
`gopt_set` GeneralFlag
Opt_IgnoreHpcChanges
DynFlags -> GeneralFlag -> DynFlags
`gopt_unset` GeneralFlag
Opt_DiagnosticsShowCaret
HscEnv -> DynFlags -> IO DynFlags
initializePlugins HscEnv
env DynFlags
dflags4
adjustToRange :: Uri -> Range -> WorkspaceEdit -> WorkspaceEdit
adjustToRange :: Uri -> Range -> WorkspaceEdit -> WorkspaceEdit
adjustToRange Uri
uri Range
ran (WorkspaceEdit Maybe WorkspaceEditMap
mhult Maybe (List DocumentChange)
mlt Maybe ChangeAnnotationMap
x) =
Maybe WorkspaceEditMap
-> Maybe (List DocumentChange)
-> Maybe ChangeAnnotationMap
-> WorkspaceEdit
WorkspaceEdit (WorkspaceEditMap -> WorkspaceEditMap
adjustWS (WorkspaceEditMap -> WorkspaceEditMap)
-> Maybe WorkspaceEditMap -> Maybe WorkspaceEditMap
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe WorkspaceEditMap
mhult) ((DocumentChange -> DocumentChange)
-> List DocumentChange -> List DocumentChange
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap DocumentChange -> DocumentChange
adjustDoc (List DocumentChange -> List DocumentChange)
-> Maybe (List DocumentChange) -> Maybe (List DocumentChange)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe (List DocumentChange)
mlt) Maybe ChangeAnnotationMap
x
where
adjustTextEdits :: Traversable f => f TextEdit -> f TextEdit
adjustTextEdits :: f TextEdit -> f TextEdit
adjustTextEdits f TextEdit
eds =
let Just Range
minStart =
Fold TextEdit (Maybe Range) -> f TextEdit -> Maybe Range
forall (f :: * -> *) a b. Foldable f => Fold a b -> f a -> b
L.fold
((TextEdit -> Range)
-> Fold Range (Maybe Range) -> Fold TextEdit (Maybe Range)
forall a b r. (a -> b) -> Fold b r -> Fold a r
L.premap (Getting Range TextEdit Range -> TextEdit -> Range
forall s (m :: * -> *) a. MonadReader s m => Getting a s a -> m a
view Getting Range TextEdit Range
forall s a. HasRange s a => Lens' s a
J.range) Fold Range (Maybe Range)
forall a. Ord a => Fold a (Maybe a)
L.minimum)
f TextEdit
eds
in Range -> TextEdit -> TextEdit
adjustLine Range
minStart (TextEdit -> TextEdit) -> f TextEdit -> f TextEdit
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> f TextEdit
eds
adjustATextEdits :: Traversable f => f (TextEdit |? AnnotatedTextEdit) -> f (TextEdit |? AnnotatedTextEdit)
adjustATextEdits :: f (TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
adjustATextEdits = ((TextEdit |? AnnotatedTextEdit) -> TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (((TextEdit |? AnnotatedTextEdit) -> TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit))
-> ((TextEdit |? AnnotatedTextEdit)
-> TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
forall a b. (a -> b) -> a -> b
$ \case
InL TextEdit
t -> TextEdit -> TextEdit |? AnnotatedTextEdit
forall a b. a -> a |? b
InL (TextEdit -> TextEdit |? AnnotatedTextEdit)
-> TextEdit -> TextEdit |? AnnotatedTextEdit
forall a b. (a -> b) -> a -> b
$ Identity TextEdit -> TextEdit
forall a. Identity a -> a
runIdentity (Identity TextEdit -> TextEdit) -> Identity TextEdit -> TextEdit
forall a b. (a -> b) -> a -> b
$ Identity TextEdit -> Identity TextEdit
forall (f :: * -> *). Traversable f => f TextEdit -> f TextEdit
adjustTextEdits (TextEdit -> Identity TextEdit
forall a. a -> Identity a
Identity TextEdit
t)
InR AnnotatedTextEdit{Range
$sel:_range:AnnotatedTextEdit :: AnnotatedTextEdit -> Range
_range :: Range
_range, Text
$sel:_newText:AnnotatedTextEdit :: AnnotatedTextEdit -> Text
_newText :: Text
_newText, ChangeAnnotationIdentifier
$sel:_annotationId:AnnotatedTextEdit :: AnnotatedTextEdit -> ChangeAnnotationIdentifier
_annotationId :: ChangeAnnotationIdentifier
_annotationId} ->
let oldTE :: TextEdit
oldTE = TextEdit :: Range -> Text -> TextEdit
TextEdit{Range
$sel:_range:TextEdit :: Range
_range :: Range
_range,Text
$sel:_newText:TextEdit :: Text
_newText :: Text
_newText}
in let TextEdit{Range
_range :: Range
$sel:_range:TextEdit :: TextEdit -> Range
_range,Text
_newText :: Text
$sel:_newText:TextEdit :: TextEdit -> Text
_newText} = Identity TextEdit -> TextEdit
forall a. Identity a -> a
runIdentity (Identity TextEdit -> TextEdit) -> Identity TextEdit -> TextEdit
forall a b. (a -> b) -> a -> b
$ Identity TextEdit -> Identity TextEdit
forall (f :: * -> *). Traversable f => f TextEdit -> f TextEdit
adjustTextEdits (TextEdit -> Identity TextEdit
forall a. a -> Identity a
Identity TextEdit
oldTE)
in AnnotatedTextEdit -> TextEdit |? AnnotatedTextEdit
forall a b. b -> a |? b
InR (AnnotatedTextEdit -> TextEdit |? AnnotatedTextEdit)
-> AnnotatedTextEdit -> TextEdit |? AnnotatedTextEdit
forall a b. (a -> b) -> a -> b
$ AnnotatedTextEdit :: Range -> Text -> ChangeAnnotationIdentifier -> AnnotatedTextEdit
AnnotatedTextEdit{Range
_range :: Range
$sel:_range:AnnotatedTextEdit :: Range
_range,Text
_newText :: Text
$sel:_newText:AnnotatedTextEdit :: Text
_newText,ChangeAnnotationIdentifier
$sel:_annotationId:AnnotatedTextEdit :: ChangeAnnotationIdentifier
_annotationId :: ChangeAnnotationIdentifier
_annotationId}
adjustWS :: WorkspaceEditMap -> WorkspaceEditMap
adjustWS = Index WorkspaceEditMap
-> Traversal' WorkspaceEditMap (IxValue WorkspaceEditMap)
forall m. Ixed m => Index m -> Traversal' m (IxValue m)
ix Uri
Index WorkspaceEditMap
uri ((List TextEdit -> Identity (List TextEdit))
-> WorkspaceEditMap -> Identity WorkspaceEditMap)
-> (List TextEdit -> List TextEdit)
-> WorkspaceEditMap
-> WorkspaceEditMap
forall s t a b. ASetter s t a b -> (a -> b) -> s -> t
%~ List TextEdit -> List TextEdit
forall (f :: * -> *). Traversable f => f TextEdit -> f TextEdit
adjustTextEdits
adjustDoc :: DocumentChange -> DocumentChange
adjustDoc :: DocumentChange -> DocumentChange
adjustDoc (InR CreateFile |? (RenameFile |? DeleteFile)
es) = (CreateFile |? (RenameFile |? DeleteFile)) -> DocumentChange
forall a b. b -> a |? b
InR CreateFile |? (RenameFile |? DeleteFile)
es
adjustDoc (InL TextDocumentEdit
es)
| TextDocumentEdit
es TextDocumentEdit -> Getting Uri TextDocumentEdit Uri -> Uri
forall s a. s -> Getting a s a -> a
^. (VersionedTextDocumentIdentifier
-> Const Uri VersionedTextDocumentIdentifier)
-> TextDocumentEdit -> Const Uri TextDocumentEdit
forall s a. HasTextDocument s a => Lens' s a
J.textDocument ((VersionedTextDocumentIdentifier
-> Const Uri VersionedTextDocumentIdentifier)
-> TextDocumentEdit -> Const Uri TextDocumentEdit)
-> ((Uri -> Const Uri Uri)
-> VersionedTextDocumentIdentifier
-> Const Uri VersionedTextDocumentIdentifier)
-> Getting Uri TextDocumentEdit Uri
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Uri -> Const Uri Uri)
-> VersionedTextDocumentIdentifier
-> Const Uri VersionedTextDocumentIdentifier
forall s a. HasUri s a => Lens' s a
J.uri Uri -> Uri -> Bool
forall a. Eq a => a -> a -> Bool
== Uri
uri =
TextDocumentEdit -> DocumentChange
forall a b. a -> a |? b
InL (TextDocumentEdit -> DocumentChange)
-> TextDocumentEdit -> DocumentChange
forall a b. (a -> b) -> a -> b
$ TextDocumentEdit
es TextDocumentEdit
-> (TextDocumentEdit -> TextDocumentEdit) -> TextDocumentEdit
forall a b. a -> (a -> b) -> b
& (List (TextEdit |? AnnotatedTextEdit)
-> Identity (List (TextEdit |? AnnotatedTextEdit)))
-> TextDocumentEdit -> Identity TextDocumentEdit
forall s a. HasEdits s a => Lens' s a
J.edits ((List (TextEdit |? AnnotatedTextEdit)
-> Identity (List (TextEdit |? AnnotatedTextEdit)))
-> TextDocumentEdit -> Identity TextDocumentEdit)
-> (List (TextEdit |? AnnotatedTextEdit)
-> List (TextEdit |? AnnotatedTextEdit))
-> TextDocumentEdit
-> TextDocumentEdit
forall s t a b. ASetter s t a b -> (a -> b) -> s -> t
%~ List (TextEdit |? AnnotatedTextEdit)
-> List (TextEdit |? AnnotatedTextEdit)
forall (f :: * -> *).
Traversable f =>
f (TextEdit |? AnnotatedTextEdit)
-> f (TextEdit |? AnnotatedTextEdit)
adjustATextEdits
| Bool
otherwise = TextDocumentEdit -> DocumentChange
forall a b. a -> a |? b
InL TextDocumentEdit
es
adjustLine :: Range -> TextEdit -> TextEdit
adjustLine :: Range -> TextEdit -> TextEdit
adjustLine Range
bad =
(Range -> Identity Range) -> TextEdit -> Identity TextEdit
forall s a. HasRange s a => Lens' s a
J.range ((Range -> Identity Range) -> TextEdit -> Identity TextEdit)
-> (Range -> Range) -> TextEdit -> TextEdit
forall s t a b. ASetter s t a b -> (a -> b) -> s -> t
%~ \Range
r ->
if Range
r Range -> Range -> Bool
forall a. Eq a => a -> a -> Bool
== Range
bad then Range
ran else Range
bad
findSubSpansDesc :: SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc :: SrcSpan -> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
findSubSpansDesc SrcSpan
srcSpan =
((SrcSpan, a) -> Down SubSpan) -> [(SrcSpan, a)] -> [(SrcSpan, a)]
forall b a. Ord b => (a -> b) -> [a] -> [a]
sortOn (SubSpan -> Down SubSpan
forall a. a -> Down a
Down (SubSpan -> Down SubSpan)
-> ((SrcSpan, a) -> SubSpan) -> (SrcSpan, a) -> Down SubSpan
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SrcSpan -> SubSpan
SubSpan (SrcSpan -> SubSpan)
-> ((SrcSpan, a) -> SrcSpan) -> (SrcSpan, a) -> SubSpan
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (SrcSpan, a) -> SrcSpan
forall a b. (a, b) -> a
fst)
([(SrcSpan, a)] -> [(SrcSpan, a)])
-> ([(LHsExpr GhcTc, a)] -> [(SrcSpan, a)])
-> [(LHsExpr GhcTc, a)]
-> [(SrcSpan, a)]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((LHsExpr GhcTc, a) -> Maybe (SrcSpan, a))
-> [(LHsExpr GhcTc, a)] -> [(SrcSpan, a)]
forall a b. (a -> Maybe b) -> [a] -> [b]
mapMaybe
( \(L SrcSpan
spn HsExpr GhcTc
_, a
e) -> do
Bool -> Maybe ()
forall (f :: * -> *). Alternative f => Bool -> f ()
guard (SrcSpan
spn SrcSpan -> SrcSpan -> Bool
`isSubspanOf` SrcSpan
srcSpan)
(SrcSpan, a) -> Maybe (SrcSpan, a)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (SrcSpan
spn, a
e)
)
data SpliceClass where
OneToOneAST :: HasSplice ast => Proxy# ast -> SpliceClass
IsHsDecl :: SpliceClass
class (Outputable (ast GhcRn), ASTElement (ast GhcPs)) => HasSplice ast where
type SpliceOf ast :: Kinds.Type -> Kinds.Type
type SpliceOf ast = HsSplice
matchSplice :: Proxy# ast -> ast GhcPs -> Maybe (SpliceOf ast GhcPs)
expandSplice :: Proxy# ast -> SpliceOf ast GhcPs -> RnM (Either (ast GhcPs) (ast GhcRn), FreeVars)
instance HasSplice HsExpr where
matchSplice :: Proxy# HsExpr -> HsExpr GhcPs -> Maybe (SpliceOf HsExpr GhcPs)
matchSplice Proxy# HsExpr
_ (HsSpliceE XSpliceE GhcPs
_ HsSplice GhcPs
spl) = HsSplice GhcPs -> Maybe (HsSplice GhcPs)
forall a. a -> Maybe a
Just HsSplice GhcPs
spl
matchSplice Proxy# HsExpr
_ HsExpr GhcPs
_ = Maybe (SpliceOf HsExpr GhcPs)
forall a. Maybe a
Nothing
expandSplice :: Proxy# HsExpr
-> SpliceOf HsExpr GhcPs
-> RnM (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars)
expandSplice Proxy# HsExpr
_ = ((HsExpr GhcRn, FreeVars)
-> (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsExpr GhcRn, FreeVars)
-> RnM (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((HsExpr GhcRn -> Either (HsExpr GhcPs) (HsExpr GhcRn))
-> (HsExpr GhcRn, FreeVars)
-> (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars)
forall (a :: * -> * -> *) b c d.
Arrow a =>
a b c -> a (b, d) (c, d)
first HsExpr GhcRn -> Either (HsExpr GhcPs) (HsExpr GhcRn)
forall a b. b -> Either a b
Right) (IOEnv (Env TcGblEnv TcLclEnv) (HsExpr GhcRn, FreeVars)
-> RnM (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars))
-> (HsSplice GhcPs
-> IOEnv (Env TcGblEnv TcLclEnv) (HsExpr GhcRn, FreeVars))
-> HsSplice GhcPs
-> RnM (Either (HsExpr GhcPs) (HsExpr GhcRn), FreeVars)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HsSplice GhcPs
-> IOEnv (Env TcGblEnv TcLclEnv) (HsExpr GhcRn, FreeVars)
rnSpliceExpr
instance HasSplice Pat where
matchSplice :: Proxy# Pat -> Pat GhcPs -> Maybe (SpliceOf Pat GhcPs)
matchSplice Proxy# Pat
_ (SplicePat XSplicePat GhcPs
_ HsSplice GhcPs
spl) = HsSplice GhcPs -> Maybe (HsSplice GhcPs)
forall a. a -> Maybe a
Just HsSplice GhcPs
spl
matchSplice Proxy# Pat
_ Pat GhcPs
_ = Maybe (SpliceOf Pat GhcPs)
forall a. Maybe a
Nothing
expandSplice :: Proxy# Pat
-> SpliceOf Pat GhcPs
-> RnM (Either (Pat GhcPs) (Pat GhcRn), FreeVars)
expandSplice Proxy# Pat
_ = HsSplice GhcPs -> RnM (Either (Pat GhcPs) (Pat GhcRn), FreeVars)
SpliceOf Pat GhcPs
-> RnM (Either (Pat GhcPs) (Pat GhcRn), FreeVars)
rnSplicePat
instance HasSplice HsType where
matchSplice :: Proxy# HsType -> HsType GhcPs -> Maybe (SpliceOf HsType GhcPs)
matchSplice Proxy# HsType
_ (HsSpliceTy XSpliceTy GhcPs
_ HsSplice GhcPs
spl) = HsSplice GhcPs -> Maybe (HsSplice GhcPs)
forall a. a -> Maybe a
Just HsSplice GhcPs
spl
matchSplice Proxy# HsType
_ HsType GhcPs
_ = Maybe (SpliceOf HsType GhcPs)
forall a. Maybe a
Nothing
expandSplice :: Proxy# HsType
-> SpliceOf HsType GhcPs
-> RnM (Either (HsType GhcPs) (HsType GhcRn), FreeVars)
expandSplice Proxy# HsType
_ = ((HsType GhcRn, FreeVars)
-> (Either (HsType GhcPs) (HsType GhcRn), FreeVars))
-> IOEnv (Env TcGblEnv TcLclEnv) (HsType GhcRn, FreeVars)
-> RnM (Either (HsType GhcPs) (HsType GhcRn), FreeVars)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((HsType GhcRn -> Either (HsType GhcPs) (HsType GhcRn))
-> (HsType GhcRn, FreeVars)
-> (Either (HsType GhcPs) (HsType GhcRn), FreeVars)
forall (a :: * -> * -> *) b c d.
Arrow a =>
a b c -> a (b, d) (c, d)
first HsType GhcRn -> Either (HsType GhcPs) (HsType GhcRn)
forall a b. b -> Either a b
Right) (IOEnv (Env TcGblEnv TcLclEnv) (HsType GhcRn, FreeVars)
-> RnM (Either (HsType GhcPs) (HsType GhcRn), FreeVars))
-> (HsSplice GhcPs
-> IOEnv (Env TcGblEnv TcLclEnv) (HsType GhcRn, FreeVars))
-> HsSplice GhcPs
-> RnM (Either (HsType GhcPs) (HsType GhcRn), FreeVars)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. HsSplice GhcPs
-> IOEnv (Env TcGblEnv TcLclEnv) (HsType GhcRn, FreeVars)
rnSpliceType
classifyAST :: SpliceContext -> SpliceClass
classifyAST :: SpliceContext -> SpliceClass
classifyAST = \case
SpliceContext
Expr -> Proxy# HsExpr -> SpliceClass
forall (ast :: * -> *). HasSplice ast => Proxy# ast -> SpliceClass
OneToOneAST @HsExpr Proxy# HsExpr
forall k (a :: k). Proxy# a
proxy#
SpliceContext
HsDecl -> SpliceClass
IsHsDecl
SpliceContext
Pat -> Proxy# Pat -> SpliceClass
forall (ast :: * -> *). HasSplice ast => Proxy# ast -> SpliceClass
OneToOneAST @Pat Proxy# Pat
forall k (a :: k). Proxy# a
proxy#
SpliceContext
HsType -> Proxy# HsType -> SpliceClass
forall (ast :: * -> *). HasSplice ast => Proxy# ast -> SpliceClass
OneToOneAST @HsType Proxy# HsType
forall k (a :: k). Proxy# a
proxy#
type ReportEditor = forall m. MonadIO m => MessageType -> [T.Text] -> m ()
manualCalcEdit ::
ClientCapabilities ->
ReportEditor ->
Range ->
Annotated ParsedSource ->
HscEnv ->
TcGblEnv ->
RealSrcSpan ->
ExpandStyle ->
ExpandSpliceParams ->
ExceptT String IO WorkspaceEdit
manualCalcEdit :: ClientCapabilities
-> ReportEditor
-> Range
-> Annotated ParsedSource
-> HscEnv
-> TcGblEnv
-> RealSrcSpan
-> ExpandStyle
-> ExpandSpliceParams
-> ExceptT String IO WorkspaceEdit
manualCalcEdit ClientCapabilities
clientCapabilities ReportEditor
reportEditor Range
ran Annotated ParsedSource
ps HscEnv
hscEnv TcGblEnv
typechkd RealSrcSpan
srcSpan ExpandStyle
_eStyle ExpandSpliceParams {RealSrcSpan
Uri
SpliceContext
spliceContext :: SpliceContext
spliceSpan :: RealSrcSpan
uri :: Uri
spliceContext :: ExpandSpliceParams -> SpliceContext
spliceSpan :: ExpandSpliceParams -> RealSrcSpan
uri :: ExpandSpliceParams -> Uri
..} = do
(WarningMessages
warns, WorkspaceEdit
resl) <-
IO (Either String (WarningMessages, WorkspaceEdit))
-> ExceptT String IO (WarningMessages, WorkspaceEdit)
forall e (m :: * -> *) a. m (Either e a) -> ExceptT e m a
ExceptT (IO (Either String (WarningMessages, WorkspaceEdit))
-> ExceptT String IO (WarningMessages, WorkspaceEdit))
-> IO (Either String (WarningMessages, WorkspaceEdit))
-> ExceptT String IO (WarningMessages, WorkspaceEdit)
forall a b. (a -> b) -> a -> b
$ do
((WarningMessages
warns, WarningMessages
errs), Maybe (Either String WorkspaceEdit)
eresl) <-
HscEnv
-> TcGblEnv
-> RealSrcSpan
-> TcM (Either String WorkspaceEdit)
-> IO (Messages, Maybe (Either String WorkspaceEdit))
forall r.
HscEnv
-> TcGblEnv -> RealSrcSpan -> TcM r -> IO (Messages, Maybe r)
initTcWithGbl HscEnv
hscEnv TcGblEnv
typechkd RealSrcSpan
srcSpan (TcM (Either String WorkspaceEdit)
-> IO (Messages, Maybe (Either String WorkspaceEdit)))
-> TcM (Either String WorkspaceEdit)
-> IO (Messages, Maybe (Either String WorkspaceEdit))
forall a b. (a -> b) -> a -> b
$
case SpliceContext -> SpliceClass
classifyAST SpliceContext
spliceContext of
SpliceClass
IsHsDecl -> (Either String WorkspaceEdit -> Either String WorkspaceEdit)
-> TcM (Either String WorkspaceEdit)
-> TcM (Either String WorkspaceEdit)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((WorkspaceEdit -> WorkspaceEdit)
-> Either String WorkspaceEdit -> Either String WorkspaceEdit
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ((WorkspaceEdit -> WorkspaceEdit)
-> Either String WorkspaceEdit -> Either String WorkspaceEdit)
-> (WorkspaceEdit -> WorkspaceEdit)
-> Either String WorkspaceEdit
-> Either String WorkspaceEdit
forall a b. (a -> b) -> a -> b
$ Uri -> Range -> WorkspaceEdit -> WorkspaceEdit
adjustToRange Uri
uri Range
ran) (TcM (Either String WorkspaceEdit)
-> TcM (Either String WorkspaceEdit))
-> TcM (Either String WorkspaceEdit)
-> TcM (Either String WorkspaceEdit)
forall a b. (a -> b) -> a -> b
$
(Graft (ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> Annotated ParsedSource -> TcM (Either String WorkspaceEdit))
-> Annotated ParsedSource
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit)
forall a b c. (a -> b -> c) -> b -> a -> c
flip (DynFlags
-> ClientCapabilities
-> Uri
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> Annotated ParsedSource
-> TcM (Either String WorkspaceEdit)
forall (m :: * -> *).
Monad m =>
DynFlags
-> ClientCapabilities
-> Uri
-> Graft (ExceptStringT m) ParsedSource
-> Annotated ParsedSource
-> m (Either String WorkspaceEdit)
transformM DynFlags
dflags ClientCapabilities
clientCapabilities Uri
uri) Annotated ParsedSource
ps (Graft (ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit)
forall a b. (a -> b) -> a -> b
$
SrcSpan
-> (LHsDecl GhcPs
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs]))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
forall a (m :: * -> *).
(HasDecls a, MonadFail m) =>
SrcSpan
-> (LHsDecl GhcPs -> TransformT m (Maybe [LHsDecl GhcPs]))
-> Graft m a
graftDeclsWithM (RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
srcSpan) ((LHsDecl GhcPs
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs]))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource)
-> (LHsDecl GhcPs
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs]))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
forall a b. (a -> b) -> a -> b
$ \case
(L SrcSpan
_spn (SpliceD XSpliceD GhcPs
_ (SpliceDecl XSpliceDecl GhcPs
_ (L SrcSpan
_ HsSplice GhcPs
spl) SpliceExplicitFlag
_))) -> do
[LHsDecl GhcPs]
eExpr <-
(SomeException
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs])
-> ([LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs]
forall (m :: * -> *) a c b.
Monad m =>
(a -> m c) -> (b -> m c) -> m (Either a b) -> m c
eitherM (String
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs]
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs])
-> (SomeException -> String)
-> SomeException
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SomeException -> String
forall a. Show a => a -> String
show) [LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs]
forall (f :: * -> *) a. Applicative f => a -> f a
pure
(TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) [LHsDecl GhcPs]
forall a b. (a -> b) -> a -> b
$ ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException [LHsDecl GhcPs])
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException [LHsDecl GhcPs])
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift
( IOEnv
(Env TcGblEnv TcLclEnv) (Either SomeException [LHsDecl GhcPs])
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException [LHsDecl GhcPs])
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IOEnv
(Env TcGblEnv TcLclEnv) (Either SomeException [LHsDecl GhcPs])
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException [LHsDecl GhcPs]))
-> IOEnv
(Env TcGblEnv TcLclEnv) (Either SomeException [LHsDecl GhcPs])
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException [LHsDecl GhcPs])
forall a b. (a -> b) -> a -> b
$
forall a.
(ExceptionMonad (IOEnv (Env TcGblEnv TcLclEnv)),
Exception SomeException) =>
IOEnv (Env TcGblEnv TcLclEnv) a
-> IOEnv (Env TcGblEnv TcLclEnv) (Either SomeException a)
forall (m :: * -> *) e a.
(ExceptionMonad m, Exception e) =>
m a -> m (Either e a)
gtry @_ @SomeException (IOEnv (Env TcGblEnv TcLclEnv) [LHsDecl GhcPs]
-> IOEnv
(Env TcGblEnv TcLclEnv) (Either SomeException [LHsDecl GhcPs]))
-> IOEnv (Env TcGblEnv TcLclEnv) [LHsDecl GhcPs]
-> IOEnv
(Env TcGblEnv TcLclEnv) (Either SomeException [LHsDecl GhcPs])
forall a b. (a -> b) -> a -> b
$
(([LHsDecl GhcPs], FreeVars) -> [LHsDecl GhcPs]
forall a b. (a, b) -> a
fst (([LHsDecl GhcPs], FreeVars) -> [LHsDecl GhcPs])
-> IOEnv (Env TcGblEnv TcLclEnv) ([LHsDecl GhcPs], FreeVars)
-> IOEnv (Env TcGblEnv TcLclEnv) [LHsDecl GhcPs]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> HsSplice GhcPs
-> IOEnv (Env TcGblEnv TcLclEnv) ([LHsDecl GhcPs], FreeVars)
rnTopSpliceDecls HsSplice GhcPs
spl)
)
Maybe [LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs])
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Maybe [LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs]))
-> Maybe [LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs])
forall a b. (a -> b) -> a -> b
$ [LHsDecl GhcPs] -> Maybe [LHsDecl GhcPs]
forall a. a -> Maybe a
Just [LHsDecl GhcPs]
eExpr
LHsDecl GhcPs
_ -> Maybe [LHsDecl GhcPs]
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe [LHsDecl GhcPs])
forall (f :: * -> *) a. Applicative f => a -> f a
pure Maybe [LHsDecl GhcPs]
forall a. Maybe a
Nothing
OneToOneAST Proxy# ast
astP ->
(Graft (ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> Annotated ParsedSource -> TcM (Either String WorkspaceEdit))
-> Annotated ParsedSource
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit)
forall a b c. (a -> b -> c) -> b -> a -> c
flip (DynFlags
-> ClientCapabilities
-> Uri
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> Annotated ParsedSource
-> TcM (Either String WorkspaceEdit)
forall (m :: * -> *).
Monad m =>
DynFlags
-> ClientCapabilities
-> Uri
-> Graft (ExceptStringT m) ParsedSource
-> Annotated ParsedSource
-> m (Either String WorkspaceEdit)
transformM DynFlags
dflags ClientCapabilities
clientCapabilities Uri
uri) Annotated ParsedSource
ps (Graft (ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
-> TcM (Either String WorkspaceEdit)
forall a b. (a -> b) -> a -> b
$
SrcSpan
-> (Located (ast GhcPs)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe (Located (ast GhcPs))))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
forall ast (m :: * -> *) a.
(MonadFail m, Data a, ASTElement ast) =>
SrcSpan
-> (Located ast -> TransformT m (Maybe (Located ast))) -> Graft m a
graftWithM (RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
srcSpan) ((Located (ast GhcPs)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe (Located (ast GhcPs))))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource)
-> (Located (ast GhcPs)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe (Located (ast GhcPs))))
-> Graft
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv))) ParsedSource
forall a b. (a -> b) -> a -> b
$ \case
(L SrcSpan
_spn (Proxy# ast -> ast GhcPs -> Maybe (SpliceOf ast GhcPs)
forall (ast :: * -> *).
HasSplice ast =>
Proxy# ast -> ast GhcPs -> Maybe (SpliceOf ast GhcPs)
matchSplice Proxy# ast
astP -> Just SpliceOf ast GhcPs
spl)) -> do
Either (ast GhcPs) (ast GhcRn)
eExpr <-
(SomeException
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn)))
-> (Either (ast GhcPs) (ast GhcRn)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn))
forall (m :: * -> *) a c b.
Monad m =>
(a -> m c) -> (b -> m c) -> m (Either a b) -> m c
eitherM (String
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn))
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn)))
-> (SomeException -> String)
-> SomeException
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SomeException -> String
forall a. Show a => a -> String
show) Either (ast GhcPs) (ast GhcRn)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn))
forall (f :: * -> *) a. Applicative f => a -> f a
pure
(TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either (ast GhcPs) (ast GhcRn))
forall a b. (a -> b) -> a -> b
$ ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift
( IOEnv
(Env TcGblEnv TcLclEnv)
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (IOEnv
(Env TcGblEnv TcLclEnv)
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException (Either (ast GhcPs) (ast GhcRn))))
-> IOEnv
(Env TcGblEnv TcLclEnv)
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
-> ExceptStringT
(IOEnv (Env TcGblEnv TcLclEnv))
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
forall a b. (a -> b) -> a -> b
$
forall a.
(ExceptionMonad (IOEnv (Env TcGblEnv TcLclEnv)),
Exception SomeException) =>
IOEnv (Env TcGblEnv TcLclEnv) a
-> IOEnv (Env TcGblEnv TcLclEnv) (Either SomeException a)
forall (m :: * -> *) e a.
(ExceptionMonad m, Exception e) =>
m a -> m (Either e a)
gtry @_ @SomeException (IOEnv (Env TcGblEnv TcLclEnv) (Either (ast GhcPs) (ast GhcRn))
-> IOEnv
(Env TcGblEnv TcLclEnv)
(Either SomeException (Either (ast GhcPs) (ast GhcRn))))
-> IOEnv (Env TcGblEnv TcLclEnv) (Either (ast GhcPs) (ast GhcRn))
-> IOEnv
(Env TcGblEnv TcLclEnv)
(Either SomeException (Either (ast GhcPs) (ast GhcRn)))
forall a b. (a -> b) -> a -> b
$
((Either (ast GhcPs) (ast GhcRn), FreeVars)
-> Either (ast GhcPs) (ast GhcRn)
forall a b. (a, b) -> a
fst ((Either (ast GhcPs) (ast GhcRn), FreeVars)
-> Either (ast GhcPs) (ast GhcRn))
-> IOEnv
(Env TcGblEnv TcLclEnv) (Either (ast GhcPs) (ast GhcRn), FreeVars)
-> IOEnv (Env TcGblEnv TcLclEnv) (Either (ast GhcPs) (ast GhcRn))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Proxy# ast
-> SpliceOf ast GhcPs
-> IOEnv
(Env TcGblEnv TcLclEnv) (Either (ast GhcPs) (ast GhcRn), FreeVars)
forall (ast :: * -> *).
HasSplice ast =>
Proxy# ast
-> SpliceOf ast GhcPs
-> RnM (Either (ast GhcPs) (ast GhcRn), FreeVars)
expandSplice Proxy# ast
astP SpliceOf ast GhcPs
spl)
)
Located (ast GhcPs) -> Maybe (Located (ast GhcPs))
forall a. a -> Maybe a
Just (Located (ast GhcPs) -> Maybe (Located (ast GhcPs)))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe (Located (ast GhcPs)))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (ast GhcPs
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs)))
-> (ast GhcRn
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs)))
-> Either (ast GhcPs) (ast GhcRn)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs))
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (Located (ast GhcPs)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Located (ast GhcPs)
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs)))
-> (ast GhcPs -> Located (ast GhcPs))
-> ast GhcPs
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SrcSpan -> ast GhcPs -> Located (ast GhcPs)
forall l e. l -> e -> GenLocated l e
L SrcSpan
_spn) (DynFlags
-> ast GhcRn
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Located (ast GhcPs))
forall (ast :: * -> *) (m :: * -> *).
(MonadFail m, HasSplice ast) =>
DynFlags -> ast GhcRn -> TransformT m (Located (ast GhcPs))
unRenamedE DynFlags
dflags) Either (ast GhcPs) (ast GhcRn)
eExpr
Located (ast GhcPs)
_ -> Maybe (Located (ast GhcPs))
-> TransformT
(ExceptStringT (IOEnv (Env TcGblEnv TcLclEnv)))
(Maybe (Located (ast GhcPs)))
forall (f :: * -> *) a. Applicative f => a -> f a
pure Maybe (Located (ast GhcPs))
forall a. Maybe a
Nothing
Either String (WarningMessages, WorkspaceEdit)
-> IO (Either String (WarningMessages, WorkspaceEdit))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either String (WarningMessages, WorkspaceEdit)
-> IO (Either String (WarningMessages, WorkspaceEdit)))
-> Either String (WarningMessages, WorkspaceEdit)
-> IO (Either String (WarningMessages, WorkspaceEdit))
forall a b. (a -> b) -> a -> b
$ (WarningMessages
warns,) (WorkspaceEdit -> (WarningMessages, WorkspaceEdit))
-> Either String WorkspaceEdit
-> Either String (WarningMessages, WorkspaceEdit)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Either String WorkspaceEdit
-> Maybe (Either String WorkspaceEdit)
-> Either String WorkspaceEdit
forall a. a -> Maybe a -> a
fromMaybe (String -> Either String WorkspaceEdit
forall a b. a -> Either a b
Left (String -> Either String WorkspaceEdit)
-> String -> Either String WorkspaceEdit
forall a b. (a -> b) -> a -> b
$ WarningMessages -> String
forall a. Show a => a -> String
show WarningMessages
errs) Maybe (Either String WorkspaceEdit)
eresl
Bool -> ExceptT String IO () -> ExceptT String IO ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless
(WarningMessages -> Bool
forall (t :: * -> *) a. Foldable t => t a -> Bool
null WarningMessages
warns)
(ExceptT String IO () -> ExceptT String IO ())
-> ExceptT String IO () -> ExceptT String IO ()
forall a b. (a -> b) -> a -> b
$ MessageType -> [Text] -> ExceptT String IO ()
ReportEditor
reportEditor
MessageType
MtWarning
[ Text
"Warning during expanding: "
, Text
""
, String -> Text
T.pack (WarningMessages -> String
forall a. Show a => a -> String
show WarningMessages
warns)
]
WorkspaceEdit -> ExceptT String IO WorkspaceEdit
forall (f :: * -> *) a. Applicative f => a -> f a
pure WorkspaceEdit
resl
where
dflags :: DynFlags
dflags = HscEnv -> DynFlags
hsc_dflags HscEnv
hscEnv
unRenamedE ::
forall ast m.
(Fail.MonadFail m, HasSplice ast) =>
DynFlags ->
ast GhcRn ->
TransformT m (Located (ast GhcPs))
unRenamedE :: DynFlags -> ast GhcRn -> TransformT m (Located (ast GhcPs))
unRenamedE DynFlags
dflags ast GhcRn
expr = do
String
uniq <- SrcSpan -> String
forall a. Show a => a -> String
show (SrcSpan -> String) -> TransformT m SrcSpan -> TransformT m String
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> TransformT m SrcSpan
forall (m :: * -> *). Monad m => TransformT m SrcSpan
uniqueSrcSpanT
(Anns
anns, Located (ast GhcPs)
expr') <-
(WarningMessages -> TransformT m (Anns, Located (ast GhcPs)))
-> ((Anns, Located (ast GhcPs))
-> TransformT m (Anns, Located (ast GhcPs)))
-> Either WarningMessages (Anns, Located (ast GhcPs))
-> TransformT m (Anns, Located (ast GhcPs))
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (String -> TransformT m (Anns, Located (ast GhcPs))
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String -> TransformT m (Anns, Located (ast GhcPs)))
-> (WarningMessages -> String)
-> WarningMessages
-> TransformT m (Anns, Located (ast GhcPs))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. WarningMessages -> String
forall a. Show a => a -> String
show) (Anns, Located (ast GhcPs))
-> TransformT m (Anns, Located (ast GhcPs))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Either WarningMessages (Anns, Located (ast GhcPs))
-> TransformT m (Anns, Located (ast GhcPs)))
-> Either WarningMessages (Anns, Located (ast GhcPs))
-> TransformT m (Anns, Located (ast GhcPs))
forall a b. (a -> b) -> a -> b
$
Parser (Located (ast GhcPs))
forall ast. ASTElement ast => Parser (Located ast)
parseAST @(ast GhcPs) DynFlags
dflags String
uniq (String -> Either WarningMessages (Anns, Located (ast GhcPs)))
-> String -> Either WarningMessages (Anns, Located (ast GhcPs))
forall a b. (a -> b) -> a -> b
$
DynFlags -> SDoc -> String
showSDoc DynFlags
dflags (SDoc -> String) -> SDoc -> String
forall a b. (a -> b) -> a -> b
$ ast GhcRn -> SDoc
forall a. Outputable a => a -> SDoc
ppr ast GhcRn
expr
let _anns' :: Anns
_anns' = Located (ast GhcPs) -> Int -> Int -> Anns -> Anns
forall a. Data a => Located a -> Int -> Int -> Anns -> Anns
setPrecedingLines Located (ast GhcPs)
expr' Int
0 Int
1 Anns
anns
Located (ast GhcPs) -> TransformT m (Located (ast GhcPs))
forall (f :: * -> *) a. Applicative f => a -> f a
pure Located (ast GhcPs)
expr'
data SearchResult r =
Continue | Stop | Here r
deriving (ReadPrec [SearchResult r]
ReadPrec (SearchResult r)
Int -> ReadS (SearchResult r)
ReadS [SearchResult r]
(Int -> ReadS (SearchResult r))
-> ReadS [SearchResult r]
-> ReadPrec (SearchResult r)
-> ReadPrec [SearchResult r]
-> Read (SearchResult r)
forall r. Read r => ReadPrec [SearchResult r]
forall r. Read r => ReadPrec (SearchResult r)
forall r. Read r => Int -> ReadS (SearchResult r)
forall r. Read r => ReadS [SearchResult r]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [SearchResult r]
$creadListPrec :: forall r. Read r => ReadPrec [SearchResult r]
readPrec :: ReadPrec (SearchResult r)
$creadPrec :: forall r. Read r => ReadPrec (SearchResult r)
readList :: ReadS [SearchResult r]
$creadList :: forall r. Read r => ReadS [SearchResult r]
readsPrec :: Int -> ReadS (SearchResult r)
$creadsPrec :: forall r. Read r => Int -> ReadS (SearchResult r)
Read, Int -> SearchResult r -> ShowS
[SearchResult r] -> ShowS
SearchResult r -> String
(Int -> SearchResult r -> ShowS)
-> (SearchResult r -> String)
-> ([SearchResult r] -> ShowS)
-> Show (SearchResult r)
forall r. Show r => Int -> SearchResult r -> ShowS
forall r. Show r => [SearchResult r] -> ShowS
forall r. Show r => SearchResult r -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [SearchResult r] -> ShowS
$cshowList :: forall r. Show r => [SearchResult r] -> ShowS
show :: SearchResult r -> String
$cshow :: forall r. Show r => SearchResult r -> String
showsPrec :: Int -> SearchResult r -> ShowS
$cshowsPrec :: forall r. Show r => Int -> SearchResult r -> ShowS
Show, SearchResult r -> SearchResult r -> Bool
(SearchResult r -> SearchResult r -> Bool)
-> (SearchResult r -> SearchResult r -> Bool)
-> Eq (SearchResult r)
forall r. Eq r => SearchResult r -> SearchResult r -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: SearchResult r -> SearchResult r -> Bool
$c/= :: forall r. Eq r => SearchResult r -> SearchResult r -> Bool
== :: SearchResult r -> SearchResult r -> Bool
$c== :: forall r. Eq r => SearchResult r -> SearchResult r -> Bool
Eq, Eq (SearchResult r)
Eq (SearchResult r)
-> (SearchResult r -> SearchResult r -> Ordering)
-> (SearchResult r -> SearchResult r -> Bool)
-> (SearchResult r -> SearchResult r -> Bool)
-> (SearchResult r -> SearchResult r -> Bool)
-> (SearchResult r -> SearchResult r -> Bool)
-> (SearchResult r -> SearchResult r -> SearchResult r)
-> (SearchResult r -> SearchResult r -> SearchResult r)
-> Ord (SearchResult r)
SearchResult r -> SearchResult r -> Bool
SearchResult r -> SearchResult r -> Ordering
SearchResult r -> SearchResult r -> SearchResult r
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
forall r. Ord r => Eq (SearchResult r)
forall r. Ord r => SearchResult r -> SearchResult r -> Bool
forall r. Ord r => SearchResult r -> SearchResult r -> Ordering
forall r.
Ord r =>
SearchResult r -> SearchResult r -> SearchResult r
min :: SearchResult r -> SearchResult r -> SearchResult r
$cmin :: forall r.
Ord r =>
SearchResult r -> SearchResult r -> SearchResult r
max :: SearchResult r -> SearchResult r -> SearchResult r
$cmax :: forall r.
Ord r =>
SearchResult r -> SearchResult r -> SearchResult r
>= :: SearchResult r -> SearchResult r -> Bool
$c>= :: forall r. Ord r => SearchResult r -> SearchResult r -> Bool
> :: SearchResult r -> SearchResult r -> Bool
$c> :: forall r. Ord r => SearchResult r -> SearchResult r -> Bool
<= :: SearchResult r -> SearchResult r -> Bool
$c<= :: forall r. Ord r => SearchResult r -> SearchResult r -> Bool
< :: SearchResult r -> SearchResult r -> Bool
$c< :: forall r. Ord r => SearchResult r -> SearchResult r -> Bool
compare :: SearchResult r -> SearchResult r -> Ordering
$ccompare :: forall r. Ord r => SearchResult r -> SearchResult r -> Ordering
$cp1Ord :: forall r. Ord r => Eq (SearchResult r)
Ord, Typeable (SearchResult r)
DataType
Constr
Typeable (SearchResult r)
-> (forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r))
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r))
-> (SearchResult r -> Constr)
-> (SearchResult r -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c (SearchResult r)))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c (SearchResult r)))
-> ((forall b. Data b => b -> b)
-> SearchResult r -> SearchResult r)
-> (forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r)
-> (forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r)
-> (forall u.
(forall d. Data d => d -> u) -> SearchResult r -> [u])
-> (forall u.
Int -> (forall d. Data d => d -> u) -> SearchResult r -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r))
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r))
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r))
-> Data (SearchResult r)
SearchResult r -> DataType
SearchResult r -> Constr
(forall d. Data d => c (t d)) -> Maybe (c (SearchResult r))
(forall b. Data b => b -> b) -> SearchResult r -> SearchResult r
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r)
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r)
forall r. Data r => Typeable (SearchResult r)
forall r. Data r => SearchResult r -> DataType
forall r. Data r => SearchResult r -> Constr
forall r.
Data r =>
(forall b. Data b => b -> b) -> SearchResult r -> SearchResult r
forall r u.
Data r =>
Int -> (forall d. Data d => d -> u) -> SearchResult r -> u
forall r u.
Data r =>
(forall d. Data d => d -> u) -> SearchResult r -> [u]
forall r r r'.
Data r =>
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
forall r r r'.
Data r =>
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
forall r (m :: * -> *).
(Data r, Monad m) =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
forall r (m :: * -> *).
(Data r, MonadPlus m) =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
forall r (c :: * -> *).
Data r =>
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r)
forall r (c :: * -> *).
Data r =>
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r)
forall r (t :: * -> *) (c :: * -> *).
(Data r, Typeable t) =>
(forall d. Data d => c (t d)) -> Maybe (c (SearchResult r))
forall r (t :: * -> * -> *) (c :: * -> *).
(Data r, Typeable t) =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c (SearchResult r))
forall a.
Typeable a
-> (forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> a -> c a)
-> (forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c a)
-> (a -> Constr)
-> (a -> DataType)
-> (forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c a))
-> (forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c a))
-> ((forall b. Data b => b -> b) -> a -> a)
-> (forall r r'.
(r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall r r'.
(r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> a -> r)
-> (forall u. (forall d. Data d => d -> u) -> a -> [u])
-> (forall u. Int -> (forall d. Data d => d -> u) -> a -> u)
-> (forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> (forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d) -> a -> m a)
-> Data a
forall u.
Int -> (forall d. Data d => d -> u) -> SearchResult r -> u
forall u. (forall d. Data d => d -> u) -> SearchResult r -> [u]
forall r r'.
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
forall r r'.
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
forall (m :: * -> *).
Monad m =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
forall (m :: * -> *).
MonadPlus m =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
forall (c :: * -> *).
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r)
forall (c :: * -> *).
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r)
forall (t :: * -> *) (c :: * -> *).
Typeable t =>
(forall d. Data d => c (t d)) -> Maybe (c (SearchResult r))
forall (t :: * -> * -> *) (c :: * -> *).
Typeable t =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c (SearchResult r))
$cHere :: Constr
$cStop :: Constr
$cContinue :: Constr
$tSearchResult :: DataType
gmapMo :: (forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
$cgmapMo :: forall r (m :: * -> *).
(Data r, MonadPlus m) =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
gmapMp :: (forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
$cgmapMp :: forall r (m :: * -> *).
(Data r, MonadPlus m) =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
gmapM :: (forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
$cgmapM :: forall r (m :: * -> *).
(Data r, Monad m) =>
(forall d. Data d => d -> m d)
-> SearchResult r -> m (SearchResult r)
gmapQi :: Int -> (forall d. Data d => d -> u) -> SearchResult r -> u
$cgmapQi :: forall r u.
Data r =>
Int -> (forall d. Data d => d -> u) -> SearchResult r -> u
gmapQ :: (forall d. Data d => d -> u) -> SearchResult r -> [u]
$cgmapQ :: forall r u.
Data r =>
(forall d. Data d => d -> u) -> SearchResult r -> [u]
gmapQr :: (r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
$cgmapQr :: forall r r r'.
Data r =>
(r' -> r -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
gmapQl :: (r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
$cgmapQl :: forall r r r'.
Data r =>
(r -> r' -> r)
-> r -> (forall d. Data d => d -> r') -> SearchResult r -> r
gmapT :: (forall b. Data b => b -> b) -> SearchResult r -> SearchResult r
$cgmapT :: forall r.
Data r =>
(forall b. Data b => b -> b) -> SearchResult r -> SearchResult r
dataCast2 :: (forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c (SearchResult r))
$cdataCast2 :: forall r (t :: * -> * -> *) (c :: * -> *).
(Data r, Typeable t) =>
(forall d e. (Data d, Data e) => c (t d e))
-> Maybe (c (SearchResult r))
dataCast1 :: (forall d. Data d => c (t d)) -> Maybe (c (SearchResult r))
$cdataCast1 :: forall r (t :: * -> *) (c :: * -> *).
(Data r, Typeable t) =>
(forall d. Data d => c (t d)) -> Maybe (c (SearchResult r))
dataTypeOf :: SearchResult r -> DataType
$cdataTypeOf :: forall r. Data r => SearchResult r -> DataType
toConstr :: SearchResult r -> Constr
$ctoConstr :: forall r. Data r => SearchResult r -> Constr
gunfold :: (forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r)
$cgunfold :: forall r (c :: * -> *).
Data r =>
(forall b r. Data b => c (b -> r) -> c r)
-> (forall r. r -> c r) -> Constr -> c (SearchResult r)
gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r)
$cgfoldl :: forall r (c :: * -> *).
Data r =>
(forall d b. Data d => c (d -> b) -> d -> c b)
-> (forall g. g -> c g) -> SearchResult r -> c (SearchResult r)
$cp1Data :: forall r. Data r => Typeable (SearchResult r)
Data, Typeable)
fromSearchResult :: SearchResult a -> Maybe a
fromSearchResult :: SearchResult a -> Maybe a
fromSearchResult (Here a
r) = a -> Maybe a
forall a. a -> Maybe a
Just a
r
fromSearchResult SearchResult a
_ = Maybe a
forall a. Maybe a
Nothing
codeAction :: PluginMethodHandler IdeState TextDocumentCodeAction
codeAction :: PluginMethodHandler IdeState 'TextDocumentCodeAction
codeAction IdeState
state PluginId
plId (CodeActionParams _ _ docId ran _) = IO (Either ResponseError (List (Command |? CodeAction)))
-> LspT
Config IO (Either ResponseError (List (Command |? CodeAction)))
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (Either ResponseError (List (Command |? CodeAction)))
-> LspT
Config IO (Either ResponseError (List (Command |? CodeAction))))
-> IO (Either ResponseError (List (Command |? CodeAction)))
-> LspT
Config IO (Either ResponseError (List (Command |? CodeAction)))
forall a b. (a -> b) -> a -> b
$
(Maybe (List (Command |? CodeAction))
-> Either ResponseError (List (Command |? CodeAction)))
-> IO (Maybe (List (Command |? CodeAction)))
-> IO (Either ResponseError (List (Command |? CodeAction)))
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap (Either ResponseError (List (Command |? CodeAction))
-> (List (Command |? CodeAction)
-> Either ResponseError (List (Command |? CodeAction)))
-> Maybe (List (Command |? CodeAction))
-> Either ResponseError (List (Command |? CodeAction))
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (List (Command |? CodeAction)
-> Either ResponseError (List (Command |? CodeAction))
forall a b. b -> Either a b
Right (List (Command |? CodeAction)
-> Either ResponseError (List (Command |? CodeAction)))
-> List (Command |? CodeAction)
-> Either ResponseError (List (Command |? CodeAction))
forall a b. (a -> b) -> a -> b
$ [Command |? CodeAction] -> List (Command |? CodeAction)
forall a. [a] -> List a
List []) List (Command |? CodeAction)
-> Either ResponseError (List (Command |? CodeAction))
forall a b. b -> Either a b
Right) (IO (Maybe (List (Command |? CodeAction)))
-> IO (Either ResponseError (List (Command |? CodeAction))))
-> IO (Maybe (List (Command |? CodeAction)))
-> IO (Either ResponseError (List (Command |? CodeAction)))
forall a b. (a -> b) -> a -> b
$
MaybeT IO (List (Command |? CodeAction))
-> IO (Maybe (List (Command |? CodeAction)))
forall (m :: * -> *) a. MaybeT m a -> m (Maybe a)
runMaybeT (MaybeT IO (List (Command |? CodeAction))
-> IO (Maybe (List (Command |? CodeAction))))
-> MaybeT IO (List (Command |? CodeAction))
-> IO (Maybe (List (Command |? CodeAction)))
forall a b. (a -> b) -> a -> b
$ do
NormalizedFilePath
fp <- IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath
forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT (IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath)
-> IO (Maybe NormalizedFilePath) -> MaybeT IO NormalizedFilePath
forall a b. (a -> b) -> a -> b
$ Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath)
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath))
-> Maybe NormalizedFilePath -> IO (Maybe NormalizedFilePath)
forall a b. (a -> b) -> a -> b
$ NormalizedUri -> Maybe NormalizedFilePath
uriToNormalizedFilePath (NormalizedUri -> Maybe NormalizedFilePath)
-> NormalizedUri -> Maybe NormalizedFilePath
forall a b. (a -> b) -> a -> b
$ Uri -> NormalizedUri
toNormalizedUri Uri
theUri
ParsedModule {[String]
ApiAnns
ModSummary
ParsedSource
pm_parsed_source :: ParsedModule -> ParsedSource
pm_extra_src_files :: ParsedModule -> [String]
pm_annotations :: ParsedModule -> ApiAnns
pm_annotations :: ApiAnns
pm_extra_src_files :: [String]
pm_parsed_source :: ParsedSource
pm_mod_summary :: ModSummary
pm_mod_summary :: ParsedModule -> ModSummary
..} <-
IO (Maybe ParsedModule) -> MaybeT IO ParsedModule
forall (m :: * -> *) a. m (Maybe a) -> MaybeT m a
MaybeT (IO (Maybe ParsedModule) -> MaybeT IO ParsedModule)
-> (Action (Maybe ParsedModule) -> IO (Maybe ParsedModule))
-> Action (Maybe ParsedModule)
-> MaybeT IO ParsedModule
forall b c a. (b -> c) -> (a -> b) -> a -> c
. String
-> IdeState
-> Action (Maybe ParsedModule)
-> IO (Maybe ParsedModule)
forall a. String -> IdeState -> Action a -> IO a
runAction String
"splice.codeAction.GitHieAst" IdeState
state (Action (Maybe ParsedModule) -> MaybeT IO ParsedModule)
-> Action (Maybe ParsedModule) -> MaybeT IO ParsedModule
forall a b. (a -> b) -> a -> b
$
GetParsedModule
-> NormalizedFilePath -> Action (Maybe ParsedModule)
forall k v.
IdeRule k v =>
k -> NormalizedFilePath -> Action (Maybe v)
use GetParsedModule
GetParsedModule NormalizedFilePath
fp
let spn :: RealSrcSpan
spn = NormalizedFilePath -> Range -> RealSrcSpan
rangeToRealSrcSpan NormalizedFilePath
fp Range
ran
mouterSplice :: Maybe (RealSrcSpan, SpliceContext)
mouterSplice = GenericQ (SearchResult (RealSrcSpan, SpliceContext))
-> ParsedSource -> Maybe (RealSrcSpan, SpliceContext)
forall a. GenericQ (SearchResult a) -> GenericQ (Maybe a)
something' (RealSrcSpan -> GenericQ (SearchResult (RealSrcSpan, SpliceContext))
detectSplice RealSrcSpan
spn) ParsedSource
pm_parsed_source
Maybe [Command |? CodeAction]
mcmds <- Maybe (RealSrcSpan, SpliceContext)
-> ((RealSrcSpan, SpliceContext)
-> MaybeT IO [Command |? CodeAction])
-> MaybeT IO (Maybe [Command |? CodeAction])
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
t a -> (a -> m b) -> m (t b)
forM Maybe (RealSrcSpan, SpliceContext)
mouterSplice (((RealSrcSpan, SpliceContext)
-> MaybeT IO [Command |? CodeAction])
-> MaybeT IO (Maybe [Command |? CodeAction]))
-> ((RealSrcSpan, SpliceContext)
-> MaybeT IO [Command |? CodeAction])
-> MaybeT IO (Maybe [Command |? CodeAction])
forall a b. (a -> b) -> a -> b
$
\(RealSrcSpan
spliceSpan, SpliceContext
spliceContext) ->
[(ExpandStyle, (Text, CommandId))]
-> ((ExpandStyle, (Text, CommandId))
-> MaybeT IO (Command |? CodeAction))
-> MaybeT IO [Command |? CodeAction]
forall (t :: * -> *) (m :: * -> *) a b.
(Traversable t, Monad m) =>
t a -> (a -> m b) -> m (t b)
forM [(ExpandStyle, (Text, CommandId))]
expandStyles (((ExpandStyle, (Text, CommandId))
-> MaybeT IO (Command |? CodeAction))
-> MaybeT IO [Command |? CodeAction])
-> ((ExpandStyle, (Text, CommandId))
-> MaybeT IO (Command |? CodeAction))
-> MaybeT IO [Command |? CodeAction]
forall a b. (a -> b) -> a -> b
$ \(ExpandStyle
_, (Text
title, CommandId
cmdId)) -> do
let params :: ExpandSpliceParams
params = ExpandSpliceParams :: Uri -> RealSrcSpan -> SpliceContext -> ExpandSpliceParams
ExpandSpliceParams {uri :: Uri
uri = Uri
theUri, RealSrcSpan
SpliceContext
spliceContext :: SpliceContext
spliceSpan :: RealSrcSpan
spliceContext :: SpliceContext
spliceSpan :: RealSrcSpan
..}
act :: Command
act = PluginId -> CommandId -> Text -> Maybe [Value] -> Command
mkLspCommand PluginId
plId CommandId
cmdId Text
title ([Value] -> Maybe [Value]
forall a. a -> Maybe a
Just [ExpandSpliceParams -> Value
forall a. ToJSON a => a -> Value
toJSON ExpandSpliceParams
params])
(Command |? CodeAction) -> MaybeT IO (Command |? CodeAction)
forall (f :: * -> *) a. Applicative f => a -> f a
pure ((Command |? CodeAction) -> MaybeT IO (Command |? CodeAction))
-> (Command |? CodeAction) -> MaybeT IO (Command |? CodeAction)
forall a b. (a -> b) -> a -> b
$
CodeAction -> Command |? CodeAction
forall a b. b -> a |? b
InR (CodeAction -> Command |? CodeAction)
-> CodeAction -> Command |? CodeAction
forall a b. (a -> b) -> a -> b
$
Text
-> Maybe CodeActionKind
-> Maybe (List Diagnostic)
-> Maybe Bool
-> Maybe Reason
-> Maybe WorkspaceEdit
-> Maybe Command
-> Maybe Value
-> CodeAction
CodeAction Text
title (CodeActionKind -> Maybe CodeActionKind
forall a. a -> Maybe a
Just CodeActionKind
CodeActionRefactorRewrite) Maybe (List Diagnostic)
forall a. Maybe a
Nothing Maybe Bool
forall a. Maybe a
Nothing Maybe Reason
forall a. Maybe a
Nothing Maybe WorkspaceEdit
forall a. Maybe a
Nothing (Command -> Maybe Command
forall a. a -> Maybe a
Just Command
act) Maybe Value
forall a. Maybe a
Nothing
List (Command |? CodeAction)
-> MaybeT IO (List (Command |? CodeAction))
forall (f :: * -> *) a. Applicative f => a -> f a
pure (List (Command |? CodeAction)
-> MaybeT IO (List (Command |? CodeAction)))
-> List (Command |? CodeAction)
-> MaybeT IO (List (Command |? CodeAction))
forall a b. (a -> b) -> a -> b
$ List (Command |? CodeAction)
-> ([Command |? CodeAction] -> List (Command |? CodeAction))
-> Maybe [Command |? CodeAction]
-> List (Command |? CodeAction)
forall b a. b -> (a -> b) -> Maybe a -> b
maybe List (Command |? CodeAction)
forall a. Monoid a => a
mempty [Command |? CodeAction] -> List (Command |? CodeAction)
forall a. [a] -> List a
List Maybe [Command |? CodeAction]
mcmds
where
theUri :: Uri
theUri = TextDocumentIdentifier
docId TextDocumentIdentifier
-> Getting Uri TextDocumentIdentifier Uri -> Uri
forall s a. s -> Getting a s a -> a
^. Getting Uri TextDocumentIdentifier Uri
forall s a. HasUri s a => Lens' s a
J.uri
detectSplice ::
RealSrcSpan ->
GenericQ (SearchResult (RealSrcSpan, SpliceContext))
detectSplice :: RealSrcSpan -> GenericQ (SearchResult (RealSrcSpan, SpliceContext))
detectSplice RealSrcSpan
spn =
SearchResult (RealSrcSpan, SpliceContext)
-> (LHsExpr GhcPs -> SearchResult (RealSrcSpan, SpliceContext))
-> a
-> SearchResult (RealSrcSpan, SpliceContext)
forall a b r. (Typeable a, Typeable b) => r -> (b -> r) -> a -> r
mkQ
SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Continue
( \case
(L l :: SrcSpan
l@(RealSrcSpan RealSrcSpan
spLoc) HsExpr GhcPs
expr :: LHsExpr GhcPs)
| RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spn SrcSpan -> SrcSpan -> Bool
`isSubspanOf` SrcSpan
l ->
case HsExpr GhcPs
expr of
HsSpliceE {} -> (RealSrcSpan, SpliceContext)
-> SearchResult (RealSrcSpan, SpliceContext)
forall r. r -> SearchResult r
Here (RealSrcSpan
spLoc, SpliceContext
Expr)
HsExpr GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Continue
LHsExpr GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Stop
)
(a -> SearchResult (RealSrcSpan, SpliceContext))
-> (Located (Pat GhcPs)
-> SearchResult (RealSrcSpan, SpliceContext))
-> a
-> SearchResult (RealSrcSpan, SpliceContext)
forall a b q.
(Typeable a, Typeable b) =>
(a -> q) -> (b -> q) -> a -> q
`extQ` \case
#if __GLASGOW_HASKELL__ == 808
(dL @(Pat GhcPs) -> L l@(RealSrcSpan spLoc) pat :: Located (Pat GhcPs))
#else
(L l@(RealSrcSpan spLoc) pat :: LPat GhcPs)
#endif
| RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spn SrcSpan -> SrcSpan -> Bool
`isSubspanOf` SrcSpan
l ->
case Pat GhcPs
pat of
SplicePat{} -> (RealSrcSpan, SpliceContext)
-> SearchResult (RealSrcSpan, SpliceContext)
forall r. r -> SearchResult r
Here (RealSrcSpan
spLoc, SpliceContext
Pat)
Pat GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Continue
Located (Pat GhcPs)
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Stop
(a -> SearchResult (RealSrcSpan, SpliceContext))
-> (LHsType GhcPs -> SearchResult (RealSrcSpan, SpliceContext))
-> a
-> SearchResult (RealSrcSpan, SpliceContext)
forall a b q.
(Typeable a, Typeable b) =>
(a -> q) -> (b -> q) -> a -> q
`extQ` \case
(L l :: SrcSpan
l@(RealSrcSpan RealSrcSpan
spLoc) HsType GhcPs
ty :: LHsType GhcPs)
| RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spn SrcSpan -> SrcSpan -> Bool
`isSubspanOf` SrcSpan
l ->
case HsType GhcPs
ty of
HsSpliceTy {} -> (RealSrcSpan, SpliceContext)
-> SearchResult (RealSrcSpan, SpliceContext)
forall r. r -> SearchResult r
Here (RealSrcSpan
spLoc, SpliceContext
HsType)
HsType GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Continue
LHsType GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Stop
(a -> SearchResult (RealSrcSpan, SpliceContext))
-> (LHsDecl GhcPs -> SearchResult (RealSrcSpan, SpliceContext))
-> a
-> SearchResult (RealSrcSpan, SpliceContext)
forall a b q.
(Typeable a, Typeable b) =>
(a -> q) -> (b -> q) -> a -> q
`extQ` \case
(L l :: SrcSpan
l@(RealSrcSpan RealSrcSpan
spLoc) HsDecl GhcPs
decl :: LHsDecl GhcPs)
| RealSrcSpan -> SrcSpan
RealSrcSpan RealSrcSpan
spn SrcSpan -> SrcSpan -> Bool
`isSubspanOf` SrcSpan
l ->
case HsDecl GhcPs
decl of
SpliceD {} -> (RealSrcSpan, SpliceContext)
-> SearchResult (RealSrcSpan, SpliceContext)
forall r. r -> SearchResult r
Here (RealSrcSpan
spLoc, SpliceContext
HsDecl)
HsDecl GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Continue
LHsDecl GhcPs
_ -> SearchResult (RealSrcSpan, SpliceContext)
forall r. SearchResult r
Stop
something' :: forall a. GenericQ (SearchResult a) -> GenericQ (Maybe a)
something' :: GenericQ (SearchResult a) -> GenericQ (Maybe a)
something' GenericQ (SearchResult a)
f = a -> Maybe a
GenericQ (Maybe a)
go
where
go :: GenericQ (Maybe a)
go :: a -> Maybe a
go a
x =
case a -> SearchResult a
GenericQ (SearchResult a)
f a
x of
SearchResult a
Stop -> Maybe a
forall a. Maybe a
Nothing
SearchResult a
resl -> (Maybe a -> Maybe a -> Maybe a) -> Maybe a -> [Maybe a] -> Maybe a
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl' ((Maybe a -> Maybe a -> Maybe a) -> Maybe a -> Maybe a -> Maybe a
forall a b c. (a -> b -> c) -> b -> a -> c
flip Maybe a -> Maybe a -> Maybe a
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
(<|>)) (SearchResult a -> Maybe a
forall a. SearchResult a -> Maybe a
fromSearchResult SearchResult a
resl) (GenericQ (Maybe a) -> a -> [Maybe a]
forall a u. Data a => (forall d. Data d => d -> u) -> a -> [u]
gmapQ GenericQ (Maybe a)
go a
x)