{-# LANGUAGE ExistentialQuantification #-}
module Neovim.Plugin.Internal (
ExportedFunctionality(..),
getFunction,
getDescription,
NeovimPlugin(..),
Plugin(..),
wrapPlugin,
) where
import Neovim.Context
import Neovim.Plugin.Classes
import Data.MessagePack
newtype ExportedFunctionality env
= EF (FunctionalityDescription, [Object] -> Neovim env Object)
getDescription :: ExportedFunctionality env -> FunctionalityDescription
getDescription :: ExportedFunctionality env -> FunctionalityDescription
getDescription (EF (FunctionalityDescription
d,[Object] -> Neovim env Object
_)) = FunctionalityDescription
d
getFunction :: ExportedFunctionality env -> [Object] -> Neovim env Object
getFunction :: ExportedFunctionality env -> [Object] -> Neovim env Object
getFunction (EF (FunctionalityDescription
_, [Object] -> Neovim env Object
f)) = [Object] -> Neovim env Object
f
instance HasFunctionName (ExportedFunctionality env) where
name :: ExportedFunctionality env -> FunctionName
name = FunctionalityDescription -> FunctionName
forall a. HasFunctionName a => a -> FunctionName
name (FunctionalityDescription -> FunctionName)
-> (ExportedFunctionality env -> FunctionalityDescription)
-> ExportedFunctionality env
-> FunctionName
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ExportedFunctionality env -> FunctionalityDescription
forall env. ExportedFunctionality env -> FunctionalityDescription
getDescription
nvimMethod :: ExportedFunctionality env -> NvimMethod
nvimMethod = FunctionalityDescription -> NvimMethod
forall a. HasFunctionName a => a -> NvimMethod
nvimMethod (FunctionalityDescription -> NvimMethod)
-> (ExportedFunctionality env -> FunctionalityDescription)
-> ExportedFunctionality env
-> NvimMethod
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ExportedFunctionality env -> FunctionalityDescription
forall env. ExportedFunctionality env -> FunctionalityDescription
getDescription
data Plugin env = Plugin
{ Plugin env -> env
environment :: env
, Plugin env -> [ExportedFunctionality env]
exports :: [ExportedFunctionality env]
}
data NeovimPlugin = forall env. NeovimPlugin (Plugin env)
wrapPlugin :: Applicative m => Plugin env -> m NeovimPlugin
wrapPlugin :: Plugin env -> m NeovimPlugin
wrapPlugin = NeovimPlugin -> m NeovimPlugin
forall (f :: * -> *) a. Applicative f => a -> f a
pure (NeovimPlugin -> m NeovimPlugin)
-> (Plugin env -> NeovimPlugin) -> Plugin env -> m NeovimPlugin
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Plugin env -> NeovimPlugin
forall env. Plugin env -> NeovimPlugin
NeovimPlugin