commit
95fab22567
1
.gitignore
vendored
1
.gitignore
vendored
@ -7,3 +7,4 @@ cabal-dev/
|
|||||||
TAGS
|
TAGS
|
||||||
tags
|
tags
|
||||||
*.tag
|
*.tag
|
||||||
|
.stack-work/
|
||||||
|
34
src/Path.hs
34
src/Path.hs
@ -31,6 +31,10 @@ module Path
|
|||||||
,dirname
|
,dirname
|
||||||
-- * Conversion
|
-- * Conversion
|
||||||
,toFilePath
|
,toFilePath
|
||||||
|
,fromAbsDir
|
||||||
|
,fromRelDir
|
||||||
|
,fromAbsFile
|
||||||
|
,fromRelFile
|
||||||
)
|
)
|
||||||
where
|
where
|
||||||
|
|
||||||
@ -81,7 +85,7 @@ parseAbsDir :: MonadThrow m
|
|||||||
parseAbsDir filepath =
|
parseAbsDir filepath =
|
||||||
if FilePath.isAbsolute filepath &&
|
if FilePath.isAbsolute filepath &&
|
||||||
not (null (normalizeDir filepath)) &&
|
not (null (normalizeDir filepath)) &&
|
||||||
not (isPrefixOf "~/" filepath) &&
|
not ("~/" `isPrefixOf` filepath) &&
|
||||||
not (hasParentDir filepath)
|
not (hasParentDir filepath)
|
||||||
then return (Path (normalizeDir filepath))
|
then return (Path (normalizeDir filepath))
|
||||||
else throwM (InvalidAbsDir filepath)
|
else throwM (InvalidAbsDir filepath)
|
||||||
@ -96,7 +100,7 @@ parseRelDir :: MonadThrow m
|
|||||||
parseRelDir filepath =
|
parseRelDir filepath =
|
||||||
if not (FilePath.isAbsolute filepath) &&
|
if not (FilePath.isAbsolute filepath) &&
|
||||||
not (null filepath) &&
|
not (null filepath) &&
|
||||||
not (isPrefixOf "~/" filepath) &&
|
not ("~/" `isPrefixOf` filepath) &&
|
||||||
not (hasParentDir filepath) &&
|
not (hasParentDir filepath) &&
|
||||||
not (null (normalizeDir filepath)) &&
|
not (null (normalizeDir filepath)) &&
|
||||||
filepath /= ".."
|
filepath /= ".."
|
||||||
@ -112,7 +116,7 @@ parseAbsFile :: MonadThrow m
|
|||||||
parseAbsFile filepath =
|
parseAbsFile filepath =
|
||||||
if FilePath.isAbsolute filepath &&
|
if FilePath.isAbsolute filepath &&
|
||||||
not (FilePath.hasTrailingPathSeparator filepath) &&
|
not (FilePath.hasTrailingPathSeparator filepath) &&
|
||||||
not (isPrefixOf "~/" filepath) &&
|
not ("~/" `isPrefixOf` filepath) &&
|
||||||
not (hasParentDir filepath) &&
|
not (hasParentDir filepath) &&
|
||||||
not (null (normalizeFile filepath)) &&
|
not (null (normalizeFile filepath)) &&
|
||||||
filepath /= ".."
|
filepath /= ".."
|
||||||
@ -129,7 +133,7 @@ parseRelFile filepath =
|
|||||||
if not (FilePath.isAbsolute filepath ||
|
if not (FilePath.isAbsolute filepath ||
|
||||||
FilePath.hasTrailingPathSeparator filepath) &&
|
FilePath.hasTrailingPathSeparator filepath) &&
|
||||||
not (null filepath) &&
|
not (null filepath) &&
|
||||||
not (isPrefixOf "~/" filepath) &&
|
not ("~/" `isPrefixOf` filepath) &&
|
||||||
not (hasParentDir filepath) &&
|
not (hasParentDir filepath) &&
|
||||||
not (null (normalizeFile filepath)) &&
|
not (null (normalizeFile filepath)) &&
|
||||||
filepath /= ".."
|
filepath /= ".."
|
||||||
@ -140,9 +144,9 @@ parseRelFile filepath =
|
|||||||
-- This handles the logic of checking for different path separators on Windows.
|
-- This handles the logic of checking for different path separators on Windows.
|
||||||
hasParentDir :: FilePath -> Bool
|
hasParentDir :: FilePath -> Bool
|
||||||
hasParentDir filepath' =
|
hasParentDir filepath' =
|
||||||
(isSuffixOf "/.." filepath) ||
|
("/.." `isSuffixOf` filepath) ||
|
||||||
(isInfixOf "/../" filepath) ||
|
("/../" `isInfixOf` filepath) ||
|
||||||
(isPrefixOf "../" filepath)
|
("../" `isPrefixOf` filepath)
|
||||||
where
|
where
|
||||||
filepath =
|
filepath =
|
||||||
case FilePath.pathSeparator of
|
case FilePath.pathSeparator of
|
||||||
@ -203,6 +207,22 @@ mkRelFile s =
|
|||||||
toFilePath :: Path b t -> FilePath
|
toFilePath :: Path b t -> FilePath
|
||||||
toFilePath (Path l) = l
|
toFilePath (Path l) = l
|
||||||
|
|
||||||
|
-- | Convert absolute path to directory to 'FilePath' type.
|
||||||
|
fromAbsDir :: Path Abs Dir -> FilePath
|
||||||
|
fromAbsDir = toFilePath
|
||||||
|
|
||||||
|
-- | Convert relative path to directory to 'FilePath' type.
|
||||||
|
fromRelDir :: Path Rel Dir -> FilePath
|
||||||
|
fromRelDir = toFilePath
|
||||||
|
|
||||||
|
-- | Convert absolute path to file to 'FilePath' type.
|
||||||
|
fromAbsFile :: Path Abs File -> FilePath
|
||||||
|
fromAbsFile = toFilePath
|
||||||
|
|
||||||
|
-- | Convert relative path to file to 'FilePath' type.
|
||||||
|
fromRelFile :: Path Rel File -> FilePath
|
||||||
|
fromRelFile = toFilePath
|
||||||
|
|
||||||
--------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------
|
||||||
-- Operations
|
-- Operations
|
||||||
|
|
||||||
|
@ -1,6 +1,4 @@
|
|||||||
{-# LANGUAGE StandaloneDeriving #-}
|
|
||||||
{-# LANGUAGE DeriveDataTypeable #-}
|
{-# LANGUAGE DeriveDataTypeable #-}
|
||||||
{-# LANGUAGE GeneralizedNewtypeDeriving #-}
|
|
||||||
|
|
||||||
-- | Internal types and functions.
|
-- | Internal types and functions.
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user