path-io
Interface to ‘directory’ package for users of ‘path’
https://github.com/mrkkrp/path-io
| LTS Haskell 24.16: | 1.8.2 | 
| Stackage Nightly 2025-10-23: | 1.8.2 | 
| Latest on Hackage: | 1.8.2 | 
path-io-1.8.2@sha256:97725811b06f3fea7c1f2b0b39f21806c2f90470fc571acd75d3606b49b0f0d9,2009Module documentation for 1.8.2
- Path
Path IO
This package provides an interface to the
directory package for
users of path. It also
implements some extra functionality like recursive scanning and copying of
directories, working with temporary files/directories, etc.
Consult Haddocks for usage, which should be trivial.
Contribution
Issues, bugs, and questions may be reported in the GitHub issue tracker for this project.
Pull requests are also welcome.
License
Copyright © 2016–present Mark Karpov
Distributed under BSD 3 clause license.
Changes
Path IO follows SemVer.
Path IO 1.8.2
- Maintenance release, compatibility with GHC 9.6, 9.8, and 9.10.
Path IO 1.8.1
- Fixed a “permission denied” error occurring when copyDirRecuris used to copy a tree with non-empty read-only directories. PR 82.
Path IO 1.8.0
- Added instances of AnyPathforSomeBase. PR 72.
Path IO 1.7.0
- Added doesPathExist,getFileSize,renamePath, andremovePathForcibly.
Path IO 1.6.3
- 
Fixed a bug that caused removeDirLinkfail on Linux because of a trailing slash that used to be passed to the underlyingremoveDirectoryLinkfunction from thedirectorypackage. Issue 59.
- 
Works with GHC 9.0.1. 
Path IO 1.6.2
- Fixed a bug in the findFilesWithand based on itfindFilesfunctions.
Path IO 1.6.1
- Fixed a space leak in walkDirAccum. Issue 55.
Path IO 1.6.0
- 
Changed how copyDirRecurandcopyDirRecur'functions work. Previously, the functions created empty directories in the destination directory when the source directory contained directory symlinks. The symlinked directories were not recursively traversed. It also copied symlinked files creating normal regular files in the target directory as the result. This is fixed so that the function now behaves much like thecputility, not traversing symlinked directories, but recreating symlinks in the target directory according to their targets in the source directory.
- 
Fixed a bug in createDirLinkwhich would always fail complaining that its destination location does not exist.
- 
Dropped support for GHC 8.2. 
Path IO 1.5.0
- Dropped support for GHC 8.0 and older.
- Added new functions: getXdgDirList,createFileLink,createDirLink,removeDirLink,getSymlinkTarget.
Path IO 1.4.2
- Fixed various bugs in listDirRecurRel,walkDirRel, andwalkDirAccumReland clarified their behavior in the docs.
Path IO 1.4.1
- Fixed a bug in walkDirRelthat resulted inNotAProperPrefixexception every time the function was called.
Path IO 1.4.0
- 
Added relative versions of some actions: listDirRel,listDirRecurRel,walkDirRel, andwalkDirAccumRel.
- 
Dropped support for GHC 7.8. 
Path IO 1.3.3
- (Hopefully) fixed test suite failure with Cabal 2.0 and GHC 8.2.1.
Path IO 1.3.2
- Reduce a number of (MonadIO m, MonadThrow m)constraints to justMonadIO m#27
Path IO 1.3.1
- Made listDirRecurfaster for deep directory trees.
Path IO 1.3.0
- 
Change the default behavior of recursive traversal APIs to not follow symbolic links. The change affects the following functions: listDirRecur,copyDirRecur, andcopyDirRecur'.
- 
Add isSymlinkwhich allows to test whether a path is a symbolic link.
- 
Move the type functions AbsPathandRelPathto theAnyPathtype class (previously they were standalone closed type families, now they are associated types ofAnyPath).
- 
Improved the documentation and metadata. 
Path IO 1.2.3
- Allowed time-1.7.
Path IO 1.2.2
- 
Fixed a bug in setModificationTimefunction that previously calledsetAccessTimeinstead ofsetModificationTimefromdirectory.
- 
Added notes to all pieces of API that are conditional (some functions are only available if directory-1.2.3.0or later is used, now it’s mentioned for every such function explicitely).
Path IO 1.2.1
- 
Allowed directory-1.3.0.0.
- 
Added getXdgDir. Only available ofdirectory-1.2.3.0or later is used.
- 
Various cosmetic improvements. 
Path IO 1.2.0
- 
Added walkDirfunction to traverse a directory tree with a handler.
- 
Added walkDirAccumfunction which is likewalkDirbut also accepts an output writer and returns the accumulated output.
- 
All recursive traversal functions (existing and new) now safely handle directory loops due to symbolic or hard links. 
- 
Added “since” notes to public functions in API. 
Path IO 1.1.0
- 
Fixed bug in copyDirRecurwhen it was unable to fully copy read-only directories.
- 
Added copyDirRecur'function that works just likecopyDirRecur, but does not preserve directory permissions.
Path IO 1.0.1
- 
Fixed bug in copyDirRecurfor non-existing destination paths when directory to copy does not contain sub-directories.
- 
Made copyDirRecurtry to copy permissions for destination directory too (previously it only tried to copy them for sub-directories).
Path IO 1.0.0
- 
Changed signature of getAppUserDataDir, so it takesStringas the first argument.
- 
Removed deprecated forgivingAbsence'function.
- 
Made findFilelazier, it stops searching as soon as a file is found.
- 
Added some tests. 
Path IO 0.3.1
- 
Introduced synonym for forgivingAbsence'—ignoringAbsence.forgivingAbsence'is deprecated now, but it’s still there.
- 
Added a handy shortcut ensureDirthat is defined asensureDir = createDirIfMissing True.
- 
Made getHomeDirandgetTempDirmore robust when they are influenced by values of environment variables.
Path IO 0.3.0
- 
Added forgivingAbsence,resolveFile, andresolveDirfunctions, so the package now provides all functionality thatPath.IOmodule in Stack has.
- 
Added closed type family RelPath,makeRelative, andmakeRelativeToCurrentDirfunctions.
- 
Fixed signature of getAppUserDataDir.
Path IO 0.2.0
- Added functions from temporary:withTempFile,withTempDir,withSystemTempFile,withSystemTempDir,openTempFile,openBinaryTempFile, andcreateTempDir.temporaryis a lightweight and ubiquitous package, so depending on it should be OK.
Path IO 0.1.1
- Fixed type signatures of renameFileandcopyFile.
Path IO 0.1.0
- Initial release.
