Streamly.Internal.FileSystem.PosixPath.Seg
This module provides a type safe path append operation by distinguishing
paths between rooted paths and branches. Rooted paths are represented by the
Rooted PosixPath
type and branches are represented by the Branch PosixPath
type. Rooted paths are paths that are attached to specific roots in the file
system. Rooted paths could be absolute or relative e.g. /usr/bin
,
./local/bin
, or .
. Branches are a paths that are not attached to a
specific root e.g. usr/bin
, local/bin
, or ../bin
are branches.
This distinction provides a safe path append operation which cannot fail. These types do not allow appending a rooted path to any other path. Only branches can be appended.
Types
Constructors
Rooted a |
Constructors
Branch a |
Constraint to check if a type has Rooted or Branch annotations.
Instances
IsSeg (Branch a) Source # | |
Defined in Streamly.Internal.FileSystem.PosixPath.Seg | |
IsSeg (Rooted a) Source # | |
Defined in Streamly.Internal.FileSystem.PosixPath.Seg |
Statically Verified Path Literals
Quasiquoters.
rt :: QuasiQuoter Source #
Generates a Rooted Path
type from a quoted literal.
>>>
Path.toString ([rt|/usr|] :: Rooted PosixPath)
"/usr"
br :: QuasiQuoter Source #
Generates a Branch Path
type from a quoted literal.
>>>
Path.toString ([br|usr|] :: Branch PosixPath)
"usr"
Statically Verified Path Strings
Template Haskell expression splices.