.. | ||
src | ||
CHANGELOG | ||
hpath.cabal | ||
LICENSE | ||
README.md | ||
run-doctests.sh | ||
Setup.hs |
HPath
Support for well-typed paths in Haskell.
Motivation
The motivation came during development of hsfm which has a pretty strict File type, but lacks a strict Path type, e.g. for user input.
The library that came closest to my needs was path, but the API turned out to be oddly complicated for my use case, so I decided to fork it.
Goals
- well-typed paths
- safe filepath manipulation, never using String as filepath, but ByteString
Note: this library was written for posix systems and it will probably not support other systems.
Differences to 'path'
- doesn't attempt to fake IO-related information into the path, so whether a path points to a file or directory is up to your IO-code to decide...
- trailing path separators will be preserved if they exist, no messing with that
- uses safe ByteString for filepaths under the hood instead of unsafe String
- fixes broken dirname
- renames dirname/filename to basename/dirname to match the POSIX shell functions
- introduces a new
Path Fn
for safe filename guarantees and aRelC
class - allows pattern matching via unidirectional PatternSynonym
- uses simple doctest for testing
- allows
~/
as relative path, because on posix level~
is just a regular filename that does NOT point to$HOME
- remove TH, it sucks