module Distribution.Types.Executable.Lens ( Executable, module Distribution.Types.Executable.Lens, ) where import Distribution.Compat.Lens import Distribution.Compat.Prelude import Prelude () import Distribution.Types.BuildInfo (BuildInfo) import Distribution.Types.Executable (Executable) import Distribution.Types.ExecutableScope (ExecutableScope) import Distribution.Types.UnqualComponentName (UnqualComponentName) import qualified Distribution.Types.Executable as T exeName :: Lens' Executable UnqualComponentName exeName :: LensLike f Executable Executable UnqualComponentName UnqualComponentName exeName UnqualComponentName -> f UnqualComponentName f Executable s = (UnqualComponentName -> Executable) -> f UnqualComponentName -> f Executable forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b fmap (\UnqualComponentName x -> Executable s { exeName :: UnqualComponentName T.exeName = UnqualComponentName x }) (UnqualComponentName -> f UnqualComponentName f (Executable -> UnqualComponentName T.exeName Executable s)) {-# INLINE exeName #-} modulePath :: Lens' Executable String modulePath :: LensLike f Executable Executable String String modulePath String -> f String f Executable s = (String -> Executable) -> f String -> f Executable forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b fmap (\String x -> Executable s { modulePath :: String T.modulePath = String x }) (String -> f String f (Executable -> String T.modulePath Executable s)) {-# INLINE modulePath #-} exeScope :: Lens' Executable ExecutableScope exeScope :: LensLike f Executable Executable ExecutableScope ExecutableScope exeScope ExecutableScope -> f ExecutableScope f Executable s = (ExecutableScope -> Executable) -> f ExecutableScope -> f Executable forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b fmap (\ExecutableScope x -> Executable s { exeScope :: ExecutableScope T.exeScope = ExecutableScope x }) (ExecutableScope -> f ExecutableScope f (Executable -> ExecutableScope T.exeScope Executable s)) {-# INLINE exeScope #-} exeBuildInfo :: Lens' Executable BuildInfo exeBuildInfo :: LensLike f Executable Executable BuildInfo BuildInfo exeBuildInfo BuildInfo -> f BuildInfo f Executable s = (BuildInfo -> Executable) -> f BuildInfo -> f Executable forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b fmap (\BuildInfo x -> Executable s { buildInfo :: BuildInfo T.buildInfo = BuildInfo x }) (BuildInfo -> f BuildInfo f (Executable -> BuildInfo T.buildInfo Executable s)) {-# INLINE exeBuildInfo #-}