Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
Synopsis
- data FileOrDir
- data AllowAbsolute
- data CWD
- data Pkg
- data Dist
- data Source
- data Include
- data Lib
- data Framework
- data Build
- data Artifacts
- data PkgDB
- data DataDir
- data Mix
- data Tix
- data Tmp
- data Response
- data PkgConf
- type RelativePath = SymbolicPathX 'OnlyRelative
- type SymbolicPath = SymbolicPathX 'AllowAbsolute
- newtype AbsolutePath (to :: FileOrDir) = AbsolutePath (forall from. SymbolicPath from to)
- data SymbolicPathX (allowAbsolute :: AllowAbsolute) (from :: Type) (to :: FileOrDir)
- getSymbolicPath :: SymbolicPathX allowAbsolute from to -> FilePath
- getAbsolutePath :: AbsolutePath to -> FilePath
- sameDirectory :: SymbolicPathX allowAbsolute from (Dir to)
- makeRelativePathEx :: HasCallStack => FilePath -> RelativePath from to
- makeSymbolicPath :: FilePath -> SymbolicPath from to
- unsafeMakeSymbolicPath :: FilePath -> SymbolicPathX allowAbs from to
- coerceSymbolicPath :: SymbolicPathX allowAbsolute from to1 -> SymbolicPathX allowAbsolute from to2
- unsafeCoerceSymbolicPath :: SymbolicPathX allowAbsolute from1 to1 -> SymbolicPathX allowAbsolute from2 to2
- relativeSymbolicPath :: RelativePath from to -> SymbolicPath from to
- symbolicPathRelative_maybe :: SymbolicPath from to -> Maybe (RelativePath from to)
- interpretSymbolicPath :: Maybe (SymbolicPath CWD (Dir from)) -> SymbolicPathX allowAbsolute from to -> FilePath
- interpretSymbolicPathAbsolute :: AbsolutePath (Dir Pkg) -> SymbolicPathX allowAbsolute Pkg to -> FilePath
- (</>) :: PathLike p q r => p -> q -> r
- (<.>) :: FileLike p => p -> String -> p
- takeDirectorySymbolicPath :: SymbolicPathX allowAbsolute from File -> SymbolicPathX allowAbsolute from (Dir to')
- dropExtensionsSymbolicPath :: SymbolicPathX allowAbsolute from File -> SymbolicPathX allowAbsolute from File
- replaceExtensionSymbolicPath :: SymbolicPathX allowAbsolute from File -> String -> SymbolicPathX allowAbsolute from File
- normaliseSymbolicPath :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to
- interpretSymbolicPathCWD :: SymbolicPathX allowAbsolute from to -> FilePath
- absoluteWorkingDir :: Maybe (SymbolicPath CWD to) -> IO (AbsolutePath to)
- tryMakeRelative :: Maybe (SymbolicPath CWD (Dir dir)) -> SymbolicPath dir to -> IO (SymbolicPath dir to)
- moduleNameSymbolicPath :: ModuleName -> SymbolicPathX allowAbsolute Source File
Symbolic path endpoints
A type-level symbolic name, to an abstract file or directory (e.g. the Cabal package directory).
data AllowAbsolute Source #
Is this symbolic path allowed to be absolute, or must it be relative?
AllowAbsolute | The path may be absolute, or it may be relative. |
OnlyRelative | The path must be relative. |
Abstract directory locations
Abstract directory: current working directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: package directory (e.g. a directory containing the .cabal
file).
See Note [Symbolic paths] in Distribution.Utils.Path.
Instances
Newtype [RelativePath Pkg 'File] CompatLicenseFile Source # | |
Defined in Distribution.PackageDescription.FieldGrammar pack :: [RelativePath Pkg 'File] -> CompatLicenseFile Source # unpack :: CompatLicenseFile -> [RelativePath Pkg 'File] Source # | |
Newtype (SymbolicPath Pkg ('Dir DataDir)) CompatDataDir Source # | |
Defined in Distribution.PackageDescription.FieldGrammar pack :: SymbolicPath Pkg ('Dir DataDir) -> CompatDataDir Source # unpack :: CompatDataDir -> SymbolicPath Pkg ('Dir DataDir) Source # |
Abstract directory: dist directory (e.g. dist-newstyle
).
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: source directory (a search directory for source files).
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: include directory (a search directory for CPP includes like header files, e.g. with ghc -I
).
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: search directory for extra libraries.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: MacOS framework directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: build directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: directory for build artifacts, such as documentation or .hie
files.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: package database directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: data files directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Instances
Newtype (SymbolicPath Pkg ('Dir DataDir)) CompatDataDir Source # | |
Defined in Distribution.PackageDescription.FieldGrammar pack :: SymbolicPath Pkg ('Dir DataDir) -> CompatDataDir Source # unpack :: CompatDataDir -> SymbolicPath Pkg ('Dir DataDir) Source # |
Abstract directory: directory for HPC .mix
files.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: directory for HPC .tix
files.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: a temporary directory.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: directory for response files.
See Note [Symbolic paths] in Distribution.Utils.Path.
Abstract directory: directory for pkg-config files.
See Note [Symbolic paths] in Distribution.Utils.Path.
Symbolic paths
type RelativePath = SymbolicPathX 'OnlyRelative Source #
A symbolic relative path, relative to an abstract location specified
by the from
type parameter.
They are *symbolic*, which means we cannot perform any IO
until we interpret them (using e.g. interpretSymbolicPath
).
type SymbolicPath = SymbolicPathX 'AllowAbsolute Source #
A symbolic path which is allowed to be absolute.
They are *symbolic*, which means we cannot perform any IO
until we interpret them (using e.g. interpretSymbolicPath
).
newtype AbsolutePath (to :: FileOrDir) Source #
AbsolutePath (forall from. SymbolicPath from to) |
data SymbolicPathX (allowAbsolute :: AllowAbsolute) (from :: Type) (to :: FileOrDir) Source #
A symbolic path, possibly relative to an abstract location specified
by the from
type parameter.
They are *symbolic*, which means we cannot perform any IO
until we interpret them (using e.g. interpretSymbolicPath
).
Instances
Newtype [RelativePath Pkg 'File] CompatLicenseFile Source # | |
Defined in Distribution.PackageDescription.FieldGrammar pack :: [RelativePath Pkg 'File] -> CompatLicenseFile Source # unpack :: CompatLicenseFile -> [RelativePath Pkg 'File] Source # | |
Newtype (SymbolicPath Pkg ('Dir DataDir)) CompatDataDir Source # | |
Defined in Distribution.PackageDescription.FieldGrammar pack :: SymbolicPath Pkg ('Dir DataDir) -> CompatDataDir Source # unpack :: CompatDataDir -> SymbolicPath Pkg ('Dir DataDir) Source # | |
Newtype (RelativePath from to) (RelativePathNT from to) Source # | |
Defined in Distribution.FieldGrammar.Newtypes pack :: RelativePath from to -> RelativePathNT from to Source # unpack :: RelativePathNT from to -> RelativePath from to Source # | |
Newtype (SymbolicPath from to) (SymbolicPathNT from to) Source # | |
Defined in Distribution.FieldGrammar.Newtypes pack :: SymbolicPath from to -> SymbolicPathNT from to Source # unpack :: SymbolicPathNT from to -> SymbolicPath from to Source # | |
Parsec (SymbolicPathX 'AllowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path parsec :: CabalParsing m => m (SymbolicPathX 'AllowAbsolute from to) Source # | |
Parsec (SymbolicPathX 'OnlyRelative from to) Source # | |
Defined in Distribution.Utils.Path parsec :: CabalParsing m => m (SymbolicPathX 'OnlyRelative from to) Source # | |
Pretty (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path pretty :: SymbolicPathX allowAbsolute from to -> Doc Source # prettyVersioned :: CabalSpecVersion -> SymbolicPathX allowAbsolute from to -> Doc Source # | |
(Typeable allowAbsolute, Typeable from, Typeable to) => Structured (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path structure :: Proxy (SymbolicPathX allowAbsolute from to) -> Structure Source # structureHash' :: Tagged (SymbolicPathX allowAbsolute from to) MD5 | |
(Typeable from, Typeable allowAbsolute, Typeable to) => Data (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path gfoldl :: (forall d b. Data d => c (d -> b) -> d -> c b) -> (forall g. g -> c g) -> SymbolicPathX allowAbsolute from to -> c (SymbolicPathX allowAbsolute from to) # gunfold :: (forall b r. Data b => c (b -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (SymbolicPathX allowAbsolute from to) # toConstr :: SymbolicPathX allowAbsolute from to -> Constr # dataTypeOf :: SymbolicPathX allowAbsolute from to -> DataType # dataCast1 :: Typeable t => (forall d. Data d => c (t d)) -> Maybe (c (SymbolicPathX allowAbsolute from to)) # dataCast2 :: Typeable t => (forall d e. (Data d, Data e) => c (t d e)) -> Maybe (c (SymbolicPathX allowAbsolute from to)) # gmapT :: (forall b. Data b => b -> b) -> SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to # gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> SymbolicPathX allowAbsolute from to -> r # gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> SymbolicPathX allowAbsolute from to -> r # gmapQ :: (forall d. Data d => d -> u) -> SymbolicPathX allowAbsolute from to -> [u] # gmapQi :: Int -> (forall d. Data d => d -> u) -> SymbolicPathX allowAbsolute from to -> u # gmapM :: Monad m => (forall d. Data d => d -> m d) -> SymbolicPathX allowAbsolute from to -> m (SymbolicPathX allowAbsolute from to) # gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> SymbolicPathX allowAbsolute from to -> m (SymbolicPathX allowAbsolute from to) # gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> SymbolicPathX allowAbsolute from to -> m (SymbolicPathX allowAbsolute from to) # | |
Generic (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path type Rep (SymbolicPathX allowAbsolute from to) :: Type -> Type # from :: SymbolicPathX allowAbsolute from to -> Rep (SymbolicPathX allowAbsolute from to) x # to :: Rep (SymbolicPathX allowAbsolute from to) x -> SymbolicPathX allowAbsolute from to # | |
Read (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path readsPrec :: Int -> ReadS (SymbolicPathX allowAbsolute from to) # readList :: ReadS [SymbolicPathX allowAbsolute from to] # readPrec :: ReadPrec (SymbolicPathX allowAbsolute from to) # readListPrec :: ReadPrec [SymbolicPathX allowAbsolute from to] # | |
Show (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path showsPrec :: Int -> SymbolicPathX allowAbsolute from to -> ShowS # show :: SymbolicPathX allowAbsolute from to -> String # showList :: [SymbolicPathX allowAbsolute from to] -> ShowS # | |
Binary (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path put :: SymbolicPathX allowAbsolute from to -> Put # get :: Get (SymbolicPathX allowAbsolute from to) # putList :: [SymbolicPathX allowAbsolute from to] -> Put # | |
NFData (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path rnf :: SymbolicPathX allowAbsolute from to -> () # | |
Eq (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path (==) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # (/=) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # | |
Ord (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path compare :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Ordering # (<) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # (<=) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # (>) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # (>=) :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> Bool # max :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to # min :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to # | |
type Rep (SymbolicPathX allowAbsolute from to) Source # | |
Defined in Distribution.Utils.Path type Rep (SymbolicPathX allowAbsolute from to) = D1 ('MetaData "SymbolicPathX" "Distribution.Utils.Path" "Cabal-syntax-3.14.1.0-Cm6co4XoXcLG0FTMtu5Sqa" 'True) (C1 ('MetaCons "SymbolicPath" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 FilePath))) |
Symbolic path API
getSymbolicPath :: SymbolicPathX allowAbsolute from to -> FilePath Source #
Extract the FilePath
underlying a SymbolicPathX
or RelativePath
,
without interpreting it.
Use this function e.g. to validate the underlying filepath.
When interacting with the file system, you should instead use
interpretSymbolicPath
or interpretSymbolicPathCWD
.
See Note [Symbolic paths] in Distribution.Utils.Path.
getAbsolutePath :: AbsolutePath to -> FilePath Source #
sameDirectory :: SymbolicPathX allowAbsolute from (Dir to) Source #
A symbolic path from a directory to itself.
makeRelativePathEx :: HasCallStack => FilePath -> RelativePath from to Source #
Make a RelativePath
, ensuring the path is not absolute,
but performing no further checks.
makeSymbolicPath :: FilePath -> SymbolicPath from to Source #
Make a SymbolicPathX
, which may be relative or absolute.
unsafeMakeSymbolicPath :: FilePath -> SymbolicPathX allowAbs from to Source #
Make a SymbolicPathX
which may be relative or absolute,
without performing any checks.
Avoid using this function in new code.
coerceSymbolicPath :: SymbolicPathX allowAbsolute from to1 -> SymbolicPathX allowAbsolute from to2 Source #
Change what a symbolic path is pointing to.
unsafeCoerceSymbolicPath :: SymbolicPathX allowAbsolute from1 to1 -> SymbolicPathX allowAbsolute from2 to2 Source #
Change both what a symbolic path is pointing from and pointing to.
Avoid using this in new code.
relativeSymbolicPath :: RelativePath from to -> SymbolicPath from to Source #
Weakening: convert a relative symbolic path to a symbolic path, "forgetting" that it is relative.
symbolicPathRelative_maybe :: SymbolicPath from to -> Maybe (RelativePath from to) Source #
Is this symbolic path a relative symbolic path?
interpretSymbolicPath :: Maybe (SymbolicPath CWD (Dir from)) -> SymbolicPathX allowAbsolute from to -> FilePath Source #
Interpret a symbolic path with respect to the given directory.
Use this function before directly interacting with the file system in order to take into account a working directory argument.
NB: when invoking external programs (such as GHC
), it is preferable to set
the working directory of the process and use interpretSymbolicPathCWD
rather than calling this function, as this function will turn relative paths
into absolute paths if the working directory is an absolute path.
This can degrade error messages, or worse, break the behaviour entirely
(because the program might expect certain paths to be relative).
See Note [Symbolic paths] in Distribution.Utils.Path.
interpretSymbolicPathAbsolute :: AbsolutePath (Dir Pkg) -> SymbolicPathX allowAbsolute Pkg to -> FilePath Source #
General filepath API
(</>) :: PathLike p q r => p -> q -> r infixr 5 Source #
Like </>
, but also supporting symbolic paths.
(<.>) :: FileLike p => p -> String -> p infixr 7 Source #
Like <.>
, but also supporting symbolic paths.
takeDirectorySymbolicPath :: SymbolicPathX allowAbsolute from File -> SymbolicPathX allowAbsolute from (Dir to') Source #
Like takeDirectory
, for symbolic paths.
dropExtensionsSymbolicPath :: SymbolicPathX allowAbsolute from File -> SymbolicPathX allowAbsolute from File Source #
Like dropExtensions
, for symbolic paths.
replaceExtensionSymbolicPath :: SymbolicPathX allowAbsolute from File -> String -> SymbolicPathX allowAbsolute from File Source #
Like replaceExtension
, for symbolic paths.
normaliseSymbolicPath :: SymbolicPathX allowAbsolute from to -> SymbolicPathX allowAbsolute from to Source #
Like normalise
, for symbolic paths.
Working directory handling
interpretSymbolicPathCWD :: SymbolicPathX allowAbsolute from to -> FilePath Source #
Interpret a symbolic path, **under the assumption that the working directory is the package directory**.
Use interpretSymbolicPath
instead if you need to take into account a
working directory argument before directly interacting with the file system.
Use this function instead of interpretSymbolicPath
when invoking a child
process: set the working directory of the sub-process, and use this function,
e.g.:
callGhc :: Maybe (SymbolicPath CWD (Dir Pkg)) -> SymbolicPath (Dir Pkg) File -> IO () callGhc mbWorkDir inputFile = runProgramInvocation $ programInvocationCwd mbWorkDir ghcProg [interpretSymbolicPathCWD inputFile]
In this example, programInvocationCwd
sets the working directory, so it is
appropriate to use interpretSymbolicPathCWD
to provide its arguments.
See Note [Symbolic paths] in Distribution.Utils.Path.
absoluteWorkingDir :: Maybe (SymbolicPath CWD to) -> IO (AbsolutePath to) Source #
Absolute path to the current working directory.
tryMakeRelative :: Maybe (SymbolicPath CWD (Dir dir)) -> SymbolicPath dir to -> IO (SymbolicPath dir to) Source #
Try to make a symbolic path relative.
This function does nothing if the path is already relative.
NB: this function may fail to make the path relative.
Module names
moduleNameSymbolicPath :: ModuleName -> SymbolicPathX allowAbsolute Source File Source #
Retrieve the relative symbolic path to a Haskell module.