Safe Haskell | None |
---|---|
Language | Haskell2010 |
Path.Internal
Description
Internal types and functions.
Synopsis
- newtype Path b t = Path FilePath
- hasParentDir :: FilePath -> Bool
- relRootFP :: FilePath
- toFilePath :: Path b t -> FilePath
Documentation
Path of some base and type.
The type variables are:
b
— base, the base location of the path; absolute or relative.t
— type, whether file or directory.
Internally is a string. The string can be of two formats only:
- File format:
file.txt
,foo/bar.txt
,/foo/bar.txt
- Directory format:
foo/
,/foo/bar/
All directories end in a trailing separator. There are no duplicate
path separators //
, no ..
, no ./
, no ~/
, etc.
Constructors
Path FilePath |
Instances
(Typeable a, Typeable b) => Lift (Path a b :: Type) Source # | |
Eq (Path b t) Source # | String equality. The following property holds: show x == show y ≡ x == y |
(Data b, Data t) => Data (Path b t) Source # | |
Defined in Path.Internal Methods gfoldl :: (forall d b0. Data d => c (d -> b0) -> d -> c b0) -> (forall g. g -> c g) -> Path b t -> c (Path b t) gunfold :: (forall b0 r. Data b0 => c (b0 -> r) -> c r) -> (forall r. r -> c r) -> Constr -> c (Path b t) toConstr :: Path b t -> Constr dataTypeOf :: Path b t -> DataType dataCast1 :: Typeable t0 => (forall d. Data d => c (t0 d)) -> Maybe (c (Path b t)) dataCast2 :: Typeable t0 => (forall d e. (Data d, Data e) => c (t0 d e)) -> Maybe (c (Path b t)) gmapT :: (forall b0. Data b0 => b0 -> b0) -> Path b t -> Path b t gmapQl :: (r -> r' -> r) -> r -> (forall d. Data d => d -> r') -> Path b t -> r gmapQr :: forall r r'. (r' -> r -> r) -> r -> (forall d. Data d => d -> r') -> Path b t -> r gmapQ :: (forall d. Data d => d -> u) -> Path b t -> [u] gmapQi :: Int -> (forall d. Data d => d -> u) -> Path b t -> u gmapM :: Monad m => (forall d. Data d => d -> m d) -> Path b t -> m (Path b t) gmapMp :: MonadPlus m => (forall d. Data d => d -> m d) -> Path b t -> m (Path b t) gmapMo :: MonadPlus m => (forall d. Data d => d -> m d) -> Path b t -> m (Path b t) | |
Ord (Path b t) Source # | String ordering. The following property holds: show x `compare` show y ≡ x `compare` y |
Show (Path b t) Source # | Same as 'show . Path.toFilePath'. The following property holds: x == y ≡ show x == show y |
Generic (Path b t) Source # | |
NFData (Path b t) Source # | |
Defined in Path.Internal | |
FromJSON (Path Rel Dir) | |
Defined in Path.Posix | |
FromJSON (Path Rel File) | |
Defined in Path.Posix | |
FromJSON (Path Abs Dir) | |
Defined in Path.Posix | |
FromJSON (Path Abs File) | |
Defined in Path.Posix | |
FromJSON (Path Rel Dir) | |
Defined in Path.Windows | |
FromJSON (Path Rel File) | |
Defined in Path.Windows | |
FromJSON (Path Abs Dir) | |
Defined in Path.Windows | |
FromJSON (Path Abs File) | |
Defined in Path.Windows | |
FromJSONKey (Path Rel Dir) | |
Defined in Path.Posix Methods fromJSONKey :: FromJSONKeyFunction (Path Rel Dir) fromJSONKeyList :: FromJSONKeyFunction [Path Rel Dir] | |
FromJSONKey (Path Rel File) | |
Defined in Path.Posix Methods fromJSONKey :: FromJSONKeyFunction (Path Rel File) fromJSONKeyList :: FromJSONKeyFunction [Path Rel File] | |
FromJSONKey (Path Abs Dir) | |
Defined in Path.Posix Methods fromJSONKey :: FromJSONKeyFunction (Path Abs Dir) fromJSONKeyList :: FromJSONKeyFunction [Path Abs Dir] | |
FromJSONKey (Path Abs File) | |
Defined in Path.Posix Methods fromJSONKey :: FromJSONKeyFunction (Path Abs File) fromJSONKeyList :: FromJSONKeyFunction [Path Abs File] | |
FromJSONKey (Path Rel Dir) | |
Defined in Path.Windows Methods fromJSONKey :: FromJSONKeyFunction (Path Rel Dir) fromJSONKeyList :: FromJSONKeyFunction [Path Rel Dir] | |
FromJSONKey (Path Rel File) | |
Defined in Path.Windows Methods fromJSONKey :: FromJSONKeyFunction (Path Rel File) fromJSONKeyList :: FromJSONKeyFunction [Path Rel File] | |
FromJSONKey (Path Abs Dir) | |
Defined in Path.Windows Methods fromJSONKey :: FromJSONKeyFunction (Path Abs Dir) fromJSONKeyList :: FromJSONKeyFunction [Path Abs Dir] | |
FromJSONKey (Path Abs File) | |
Defined in Path.Windows Methods fromJSONKey :: FromJSONKeyFunction (Path Abs File) fromJSONKeyList :: FromJSONKeyFunction [Path Abs File] | |
ToJSON (Path b t) Source # | |
Defined in Path.Internal Methods toEncoding :: Path b t -> Encoding toJSONList :: [Path b t] -> Value toEncodingList :: [Path b t] -> Encoding | |
ToJSONKey (Path b t) Source # | |
Defined in Path.Internal | |
Hashable (Path b t) Source # | |
Defined in Path.Internal | |
type Rep (Path b t) Source # | |
Defined in Path.Internal type Rep (Path b t) = D1 ('MetaData "Path" "Path.Internal" "path-0.8.0-2eYvXA9K3VmBdhaapABtgm" 'True) (C1 ('MetaCons "Path" 'PrefixI 'False) (S1 ('MetaSel ('Nothing :: Maybe Symbol) 'NoSourceUnpackedness 'NoSourceStrictness 'DecidedLazy) (Rec0 FilePath))) |
hasParentDir :: FilePath -> Bool Source #
Helper function: check if the filepath has any parent directories in it. This handles the logic of checking for different path separators on Windows.
toFilePath :: Path b t -> FilePath Source #
Convert to a FilePath
type.
All directories have a trailing slash, so if you want no trailing
slash, you can use dropTrailingPathSeparator
from
the filepath package.