directory
Platform-agnostic library for filesystem operations
| Version on this page: | 1.3.9.0 | 
| LTS Haskell 24.16: | 1.3.8.5 | 
| Stackage Nightly 2025-10-25: | 1.3.9.0 | 
| Latest on Hackage: | 1.3.9.0@rev:2 | 
directory-1.3.9.0@sha256:ae73d4c39d18842f57d48649f4583347823ef7b1bc0bde786ca39141f7fd8c87,3167Module documentation for 1.3.9.0
- System- System.Directory
- System.Directory.Internal
- System.Directory.Internal.Prelude
 
- System.Directory.OsPath
 
- System.Directory.Internal
 
- System.Directory
directory
Documentation can be found on Hackage. Changes between versions are recorded in the change log.
Building from Git repository
When building this package directly from the Git repository, one must run
autoreconf -fi to generate the configure script needed by cabal configure.  This requires Autoconf to be installed.
autoreconf -fi
cabal install
There is no need to run the configure script manually however, as cabal configure does that automatically.
Changes
Changelog for the directory package
1.3.9.0 (Oct 2024)
- Rely on file-iofor file I/O.
- Drop support for baseolder than 4.12.0.
- Resolve TOCTOU issue with removeDirectoryRecursiveandremovePathForciblyon POSIX systems. (part of #97)
- findExecutable ""now returns- Nothing, matching non-Windows systems (#180)
1.3.8.5 (May 2024)
- Fix regression that causes copying of nonexistent files to create empty files. (#177)
1.3.8.4 (Apr 2024)
- Relax timeversion bounds to support 1.14. (#171)
- Relax baseversion bounds to support 4.20. (#173)
- Relax filepathversion bounds to support 1.4.300 whenos-stringis unavailable. (#175)
1.3.8.3 (Jan 2024)
- Relax Win32version bounds to support 2.14.0.0. (#166)
- Fix regression in canonicalizePathon Windows UNC paths. (#170)
1.3.8.2 (Dec 2023)
1.3.8.1 (Feb 2023)
1.3.8.0 (Sep 2022)
- Drop support for baseolder than 4.11.0.
- Drop support for filepatholder than 1.4.100.
- Drop support for timeolder than 1.8.0.
- Drop support for unixolder than 2.8.0.
- Drop support for Win32older than 2.13.3.
- Modules in directoryare no longer considered Safe because theSystem.OsPathdependency is no longer Safe.
- A new module, System.Directory.OsPath, has been introduced to support AFPP (OsPathandOsString) with an analogous API. The old module,System.Directory, shall be in maintenance mode as new features will no longer be accepted there. (#136)
- removePathForciblyno longer changes permissions of files on non-Windows systems. (#135)
1.3.7.1 (Jul 2022)
- Relax timeversion bounds to support 1.12.
- Relax Win32version bounds to support 2.13.
- Relax baseversion bounds to support 4.17.
1.3.7.0 (Sep 2021)
- getXdgDirectorynow supports- XdgState(- XDG_STATE_HOME). (#121)
1.3.6.2 (May 2021)
- Relax Win32version bounds to support 2.11.
- Relax timeversion bounds to support 1.11.
- Relax baseversion bounds to support 4.16.
1.3.6.1 (March 2020)
- Relax timeversion bounds to support 1.10.
1.3.6.0 (January 2020)
- On non-Windows platforms, getHomeDirectorywill fall back togetpwuid_rifHOMEis not set. (#102)
1.3.5.0 (December 2019)
- Revert change introduced in the version 1.3.3.2: Non-absoluteXDG_*environment variables are ignored. This behavior is according to XDG Base Directory Specification version 0.7 (#100)
1.3.4.0 (July 2019)
- getXdgDirectoryand- getXdgDirectoryListon Windows will now respect the XDG environment variables if present. (#95)
1.3.3.2 (January 2019)
- getXdgDirectorywill no longer reject environment variables containing relative paths. (#87)
1.3.3.1 (August 2018)
- doesDirectoryExistand- doesPathExistreject empty paths once again, reversing an undocumented change introduced in 1.3.1.1. (#84)
1.3.3.0 (June 2018)
- 
Relax unixversion bounds to support 2.8.
- 
Relax Win32version bounds to support 2.8.
- 
Use SYMBOLIC_LINK_FLAG_ALLOW_UNPRIVILEGED_CREATEwhen creating symbolic links on Windows, if possible. (#83)
1.3.2.2 (April 2018)
- Relax baseversion bounds to support 4.12.
1.3.2.1 (March 2018)
- Relax Win32version bounds to support 2.7.
1.3.2.0 (January 2018)
- 
Relax timeversion bounds to support 1.9.
- 
Implement getXdgDirectoryListandXdgDirectoryList. (#78)
1.3.1.5 (October 2017)
- Rename the internal header windows.hto avoid GHC#14312. (#77)
1.3.1.4 (September 2017)
- Fix Win32version 2.6 compatibility. (#75)
1.3.1.3 (September 2017)
- Relax Win32version bounds to support 2.6.
1.3.1.2 (September 2017)
- Relax baseversion bounds to support 4.11. (#74)
1.3.1.1 (March 2017)
- 
Fix a bug where createFileLinkandcreateDirectoryLinkfailed to handle..in absolute paths.
- 
Improve support (partially) for paths longer than 260 characters on Windows. To achieve this, many functions will now automatically prepend \\?\before calling the Windows API. As a side effect, the\\?\prefix may show up in the error messages of the affected functions.
- 
makeAbsolutecan now handle drive-relative paths on Windows such asC:foobar
1.3.1.0 (March 2017)
- 
findFile(and similar functions): when an absolute path is given, the list of search directories is now completely ignored. Previously, if the list was empty,findFilewould always fail. (#72)
- 
For symbolic links on Windows, the following functions had previously interpreted paths as referring to the links themselves rather than their targets. This was inconsistent with other platforms and has been fixed. - getFileSize
- doesPathExist
- doesDirectoryExist
- doesFileExist
 
- 
Fix incorrect location info in errors from pathIsSymbolicLink.
- 
Add functions for symbolic link manipulation: - createFileLink
- createDirectoryLink
- removeDirectoryLink
- getSymbolicLinkTarget
 
- 
canonicalizePathcan now resolve broken symbolic links too. (#64)
1.3.0.2 (February 2017)
- 
[optimization] Increase internal buffer size of copyFile(#69)
- 
Relax timeversion bounds to support 1.8.
1.3.0.1 (January 2017)
- Relax Win32version bounds to support 2.5. (#67)
1.3.0.0 (December 2016)
- 
[breaking] Drop trailing slashes in canonicalizePath(#63)
- 
[deprecation] Rename isSymbolicLinktopathIsSymbolicLink. The old name will remain available but may be removed in the next major release. (#52)
- 
Changed canonicalizePathto dereference symbolic links even if it points to a file and is not the last path segment
- 
On Windows, canonicalizePathnow canonicalizes the letter case too
- 
On Windows, canonicalizePathnow also dereferences symbolic links
- 
When exceptions are thrown, the error location will now contain additional information about the internal function(s) used. 
1.2.7.1 (November 2016)
- Don’t abort removePathForciblyif files or directories go missing. In addition, keep going even if an exception occurs. (#60)
1.2.7.0 (August 2016)
- 
Remove deprecated C bits. This means HsDirectory.hand its functions are no longer available. (#50)
- 
Add doesPathExistandgetFileSize(#57)
- 
Add renamePath(#58)
- 
Add removePathForcibly(#59)
1.2.6.3 (May 2016)
- Add missing import of (<*>)on Windows forbaseearlier than 4.8.0.0 (#53)
1.2.6.2 (April 2016)
- 
Bundled with GHC 8.0.1 
- 
Fix typo in file time functions when utimensatis not available and version ofunixpackage is lower than 2.7.0.0
1.2.6.1 (April 2016)
- Fix mistake in file time functions when utimensatis not available (#47)
1.2.6.0 (April 2016)
- 
Make findExecutable,findExecutables,findExecutablesInDirectories,findFile, andfindFilesWithlazier (#43)
- 
Add findFileWith
- 
Add copyFileWithMetadata, which copies additional metadata (#40)
- 
Improve error message of removeDirectoryRecursivewhen used on a directory symbolic link on Windows.
- 
Add isSymbolicLink
- 
Drop support for Hugs. 
1.2.5.1 (February 2016)
- 
Improve error message of getCurrentDirectorywhen the current working directory no longer exists (#39)
- 
Fix the behavior of trailing path separators in canonicalizePathas well asmakeAbsolutewhen applied to the current directory; they should now match the behavior ofcanonicalizePathprior to 1.2.3.0 (when the bug was introduced) (#42)
- 
Set the location in IO errors from makeAbsolute.
1.2.5.0 (December 2015)
- 
Add listDirectory, which is similar togetDirectoryContentsbut omits.and..(#36)
- 
Remove support for --with-cc=inconfigure; use theCC=flag instead (ghc:D1608)
1.2.4.0 (September 2015)
- 
Work around lack of #const_strwhen cross-compiling (haskell-cafe)
- 
Add findExecutablesInDirectories(#33)
- 
Add exeExtension
1.2.3.1 (August 2015)
- Restore support for Safe Haskell with base < 4.8 (#30)
1.2.3.0 (July 2015)
- 
Add support for XDG Base Directory Specification (#6) 
- 
Implement setModificationTimecounterpart togetModificationTime(#13)
- 
Implement getAccessTimeandsetAccessTime
- 
Set the filename in IO errors from the file time functions 
- 
Fix canonicalizePathso that it always returns a reasonable result even if the path is inaccessible and will not throw exceptions unless the current directory cannot be obtained (#23)
- 
Corrected the trailing slash behavior of makeAbsoluteso thatmakeAbsolute "" == makeAbsolute "."
- 
Deprecate use of HsDirectory.handHsDirectoryConfig.h
- 
Implement withCurrentDirectory
1.2.2.1 (Apr 2015)
- Fix dependency problem on NixOS when building with tests (#24)
1.2.2.0 (Mar 2015)
- 
Bundled with GHC 7.10.1 
- 
Make getModificationTimesupport sub-second resolution on Windows
- 
Fix silent failure in createDirectoryIfMissing
- 
Replace throwby better definedthrowIOs
- 
Avoid stack overflow in getDirectoryContents(#17)
- 
Expose findExecutables(#14)
- 
removeDirectoryRecursiveno longer follows symlinks under any circumstances (#15)
- 
Allow trailing path separators in getPermissionson Windows (#9)
- 
renameFilenow always throws the correct error type (InappropriateType) when the destination is a directory, as long as the filesystem is not being modified concurrently (#8)
- 
Add makeAbsolute, which should be preferred overcanonicalizePathunless one requires symbolic links to be resolved
1.2.1.0 (Mar 2014)
- 
Bundled with GHC 7.8.1 
- 
Add support for sub-second precision in getModificationTimewhen linked againstunix>=2.6.0.0
- 
Fix createDirectoryIfMissing _ "."inC:\on Windows
- 
Remove support for NHC98 compiler 
- 
Update package to cabal-version >= 1.10format
- 
Enhance Haddock documentation for doesDirectoryExistandcanonicalizePath
- 
Fix findExecutableto check that file permissions indicate executable
- 
New convenience functions findFilesandfindFilesWith
