CurryInfo: filepath-3.0.0 / System.FilePath.normalise

definition:
normalise :: FilePath -> FilePath
normalise path = joinDrive (normaliseDrive drv) (f pth)
              ++ [pathSeparator | isDirPath pth]
  where
    (drv,pth) = splitDrive path
    isDirPath xs = lastSep xs
        || not (null xs) && last xs == '.' && lastSep (init xs)
    lastSep xs = not (null xs) && isPathSeparator (last xs)
    f = joinPath . dropDots . splitDirectories . propSep

    propSep []            = []
    propSep xs@[x]
      | isPathSeparator x = [pathSeparator]
      | otherwise         = xs
    propSep (x:y:xs)
      | isPathSeparator x && isPathSeparator y = propSep (x:xs)
      | isPathSeparator x                      = pathSeparator : propSep (y:xs)
      | otherwise                              = x : propSep (y:xs)

    dropDots xs | all (== ".") xs = ["."]
                | otherwise       = dropDots' [] xs

    dropDots' acc [] = reverse acc
    dropDots' acc (x:xs) | x == "."  = dropDots' acc xs
                         | otherwise = dropDots' (x:acc) xs
demand:
argument 1
deterministic:
deterministic operation
documentation:
-- | Normalise a file
--
-- * \/\/ outside of the drive can be made blank
--
-- * \/ -> 'pathSeparator'
--
-- * .\/ -> \"\"
--
-- > Posix:   normalise "/file/\\test////" == "/file/\\test/"
-- > Posix:   normalise "/file/./test" == "/file/test"
-- > Posix:   normalise "/test/file/../bob/fred/" == "/test/file/../bob/fred/"
-- > Posix:   normalise "../bob/fred/" == "../bob/fred/"
-- > Posix:   normalise "./bob/fred/" == "bob/fred/"
-- > Windows: normalise "c:\\file/bob\\" == "C:\\file\\bob\\"
-- > Windows: normalise "c:\\" == "C:\\"
-- > Windows: normalise "\\\\server\\test" == "\\\\server\\test"
-- > Windows: normalise "c:/file" == "C:\\file"
-- >          normalise "." == "."
-- > Posix:   normalise "./" == "./"
-- > Posix:   normalise "./." == "./"
-- > Posix:   normalise "bob/fred/." == "bob/fred/"
failfree:
<FAILING>
indeterministic:
referentially transparent operation
infix:
no fixity defined
iotype:
{(_) |-> _}
name:
normalise
precedence:
no precedence defined
result-values:
_
signature:
String -> String
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term