Skip to content

Commit

Permalink
Migrate file I/O to file-io
Browse files Browse the repository at this point in the history
  • Loading branch information
Rufflewind committed May 20, 2024
1 parent e8ee4d5 commit 971c6ca
Show file tree
Hide file tree
Showing 7 changed files with 18 additions and 62 deletions.
11 changes: 5 additions & 6 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,18 +14,17 @@ jobs:
fail-fast: false
matrix:
include:
- { os: macOS-13, stack: lts-12.26, stack-extra-deps: "bytestring-0.11.3.0, filepath-1.4.100.0, unix-2.8.0.0" }
- { os: macos-latest, stack: lts-22.7, stack-extra-deps: "bytestring-0.11.5.3, filepath-1.5.2.0, os-string-2.0.2, unix-2.8.5.1", stack-package-flags: "{directory: {os-string: true}, unix: {os-string: true}}", ghc-flags: -Werror=deprecations }
- { os: ubuntu-latest, ghc: 8.4.4, cabal: 3.0.0.0, overrides: "before_prepare() { sed -i.bak /utimensat/d configure.ac; }" }
- { os: macOS-13, stack: lts-12.26, stack-extra-deps: "bytestring-0.11.3.0, file-io-0.1.1, filepath-1.4.100.0, unix-2.8.0.0" }
- { os: macos-latest, stack: lts-22.7, stack-extra-deps: "bytestring-0.11.5.3, file-io-0.1.1, filepath-1.5.2.0, os-string-2.0.2, unix-2.8.5.1", stack-package-flags: "{directory: {os-string: true}, file-io: {os-string: true}, unix: {os-string: true}}", ghc-flags: -Werror=deprecations }
- { os: ubuntu-latest, ghc: 8.6.5, cabal: 3.0.0.0, overrides: "before_prepare() { sed -i.bak /utimensat/d configure.ac; }" }
- { os: ubuntu-latest, ghc: 8.10.7, cabal: 3.8.1.0 }
- { os: ubuntu-latest, ghc: 9.0.2, cabal: 3.8.1.0 }
- { os: ubuntu-latest, ghc: 9.2.4, cabal: 3.8.1.0 }
- { os: ubuntu-latest, ghc: 9.4.3, cabal: 3.8.1.0 }
- { os: ubuntu-latest, ghc: latest, cabal: latest, cabal-package-flags: +os-string, ghc-flags: -Werror=deprecations }
- { os: windows-latest, stack: lts-12.26, stack-extra-deps: "bytestring-0.11.3.0, filepath-1.4.100.0, time-1.8.0.2, Win32-2.13.3.0", overrides: "before_prepare() { sed -i.bak -e /CreateSymbolicLinkW/d -e /GetFinalPathNameByHandleW/d configure.ac; }" }
- { os: windows-latest, stack: lts-17.5, stack-extra-deps: "bytestring-0.11.3.0, filepath-1.4.100.0, time-1.9.3, Win32-2.13.3.0" }
- { os: windows-latest, stack: lts-22.7, stack-extra-deps: "bytestring-0.11.5.3, filepath-1.5.2.0, os-string-2.0.2, time-1.14, Win32-2.14.0.0", stack-package-flags: "{directory: {os-string: true}, Win32: {os-string: true}}", ghc-flags: -Werror=deprecations }
- { os: windows-latest, stack: lts-12.26, stack-extra-deps: "bytestring-0.11.3.0, file-io-0.1.1, filepath-1.4.100.0, time-1.8.0.2, Win32-2.13.3.0", overrides: "before_prepare() { sed -i.bak -e /CreateSymbolicLinkW/d -e /GetFinalPathNameByHandleW/d configure.ac; }" }
- { os: windows-latest, stack: lts-17.5, stack-extra-deps: "bytestring-0.11.3.0, file-io-0.1.1, filepath-1.4.100.0, time-1.9.3, Win32-2.13.3.0" }
- { os: windows-latest, stack: lts-22.7, stack-extra-deps: "bytestring-0.11.5.3, file-io-0.1.1, filepath-1.5.2.0, os-string-2.0.2, time-1.14, Win32-2.14.0.0", stack-package-flags: "{directory: {os-string: true}, file-io: {os-string: true}, Win32: {os-string: true}}", ghc-flags: -Werror=deprecations }
runs-on: ${{ matrix.os }}
env:
CABAL_PACKAGE_FLAGS: ${{ matrix.cabal-package-flags }}
Expand Down
9 changes: 0 additions & 9 deletions System/Directory/Internal/Common.hs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import System.Directory.Internal.Prelude
import GHC.IO.Encoding.Failure (CodingFailureMode(TransliterateCodingFailure))
import GHC.IO.Encoding.UTF16 (mkUTF16le)
import GHC.IO.Encoding.UTF8 (mkUTF8)
import System.IO (hSetBinaryMode)
import System.OsPath
( OsPath
, OsString
Expand Down Expand Up @@ -243,14 +242,6 @@ data Permissions
, searchable :: Bool
} deriving (Eq, Ord, Read, Show)

withBinaryHandle :: IO Handle -> (Handle -> IO r) -> IO r
withBinaryHandle open = bracket openBinary hClose
where
openBinary = do
h <- open
hSetBinaryMode h True
pure h

-- | Copy data from one handle to another until end of file.
copyHandleData :: Handle -- ^ Source handle
-> Handle -- ^ Destination handle
Expand Down
24 changes: 3 additions & 21 deletions System/Directory/Internal/Posix.hsc
Original file line number Diff line number Diff line change
Expand Up @@ -13,14 +13,14 @@ import System.Directory.Internal.Common
import System.Directory.Internal.Config (exeExtension)
import Data.Time (UTCTime)
import Data.Time.Clock.POSIX (POSIXTime)
import System.File.OsPath (withBinaryFile)
import System.OsPath ((</>), isRelative, splitSearchPath)
import System.OsString.Internal.Types (OsString(OsString, getOsString))
import qualified Data.Time.Clock.POSIX as POSIXTime
import qualified System.OsPath.Internal as OsPath
import qualified System.Posix.Directory.PosixPath as Posix
import qualified System.Posix.Env.PosixString as Posix
import qualified System.Posix.Files.PosixString as Posix
import qualified System.Posix.IO.PosixString as Posix
import qualified System.Posix.PosixPath.FilePath as Posix
import qualified System.Posix.Types as Posix
import qualified System.Posix.User.ByteString as Posix
Expand Down Expand Up @@ -244,24 +244,6 @@ tryCopyOwnerAndGroupFromStatus st dst = do
ignoreIOExceptions (copyOwnerFromStatus st dst)
ignoreIOExceptions (copyGroupFromStatus st dst)

defaultFlags :: Posix.OpenFileFlags
defaultFlags =
Posix.defaultFileFlags
{ Posix.noctty = True
, Posix.nonBlock = True
, Posix.cloexec = True
}

openFileForRead :: OsPath -> IO Handle
openFileForRead (OsString p) =
Posix.fdToHandle =<< Posix.openFd p Posix.ReadOnly defaultFlags

openFileForWrite :: OsPath -> IO Handle
openFileForWrite (OsString p) =
Posix.fdToHandle =<<
Posix.openFd p Posix.WriteOnly
defaultFlags { Posix.creat = Just 0o666, Posix.trunc = True }

-- | Truncate the destination file and then copy the contents of the source
-- file to the destination file. If the destination file already exists, its
-- attributes shall remain unchanged. Otherwise, its attributes are reset to
Expand All @@ -271,8 +253,8 @@ copyFileContents :: OsPath -- ^ Source filename
-> IO ()
copyFileContents fromFPath toFPath =
(`ioeAddLocation` "copyFileContents") `modifyIOError` do
withBinaryHandle (openFileForWrite toFPath) $ \ hTo -> do
withBinaryHandle (openFileForRead fromFPath) $ \ hFrom -> do
withBinaryFile toFPath WriteMode $ \ hTo -> do
withBinaryFile fromFPath ReadMode $ \ hFrom -> do
copyHandleData hFrom hTo

copyFileWithMetadataInternal :: (Metadata -> OsPath -> IO ())
Expand Down
22 changes: 0 additions & 22 deletions System/Directory/Internal/Windows.hsc
Original file line number Diff line number Diff line change
Expand Up @@ -105,28 +105,6 @@ maxShareMode =
Win32.fILE_SHARE_READ .|.
Win32.fILE_SHARE_WRITE

openFileForRead :: OsPath -> IO Handle
openFileForRead (OsString path) =
bracketOnError
(Win32.createFile
path
Win32.gENERIC_READ
maxShareMode
Nothing
Win32.oPEN_EXISTING
(Win32.fILE_ATTRIBUTE_NORMAL .|. possiblyOverlapped)
Nothing)
Win32.closeHandle
Win32.hANDLEToHandle

possiblyOverlapped :: Win32.FileAttributeOrFlag
#ifdef __IO_MANAGER_WINIO__
possiblyOverlapped | ioSubSystem == IoNative = Win32.fILE_FLAG_OVERLAPPED
| otherwise = 0
#else
possiblyOverlapped = 0
#endif

win32_getFinalPathNameByHandle :: Win32.HANDLE -> Win32.DWORD -> IO WindowsPath
#ifdef HAVE_GETFINALPATHNAMEBYHANDLEW
win32_getFinalPathNameByHandle h flags = do
Expand Down
3 changes: 2 additions & 1 deletion System/Directory/OsPath.hs
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,7 @@ module System.Directory.OsPath
import Prelude ()
import System.Directory.Internal
import System.Directory.Internal.Prelude
import System.File.OsPath (withBinaryFile)
import System.OsPath
( (<.>)
, (</>)
Expand Down Expand Up @@ -728,7 +729,7 @@ copyFileToHandle :: OsPath -- ^ Source file
-> IO ()
copyFileToHandle fromFPath hTo =
(`ioeAddLocation` "copyFileToHandle") `modifyIOError` do
withBinaryHandle (openFileForRead fromFPath) $ \ hFrom ->
withBinaryFile fromFPath ReadMode $ \ hFrom ->
copyHandleData hFrom hTo

-- | Copy the contents of a source file to a destination file, replacing the
Expand Down
4 changes: 4 additions & 0 deletions changelog.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
Changelog for the [`directory`][1] package
==========================================

## 1.3.9.0 (unreleased)

* Rely on `file-io` for file I/O.

## 1.3.8.5 (May 2024)

* Fix regression that causes copying of nonexistent files to create empty
Expand Down
7 changes: 4 additions & 3 deletions directory.cabal
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
cabal-version: 2.2
name: directory
version: 1.3.8.5
version: 1.3.9.0
license: BSD-3-Clause
license-file: LICENSE
maintainer: [email protected]
Expand Down Expand Up @@ -60,8 +60,9 @@ Library
include-dirs: .

build-depends:
base >= 4.11.0 && < 4.21,
time >= 1.8.0 && < 1.15
base >= 4.12.0 && < 4.21,
file-io >= 0.1.1 && < 0.2,
time >= 1.8.0 && < 1.15,
if os(windows)
build-depends: Win32 >= 2.13.3 && < 2.15
else
Expand Down

0 comments on commit 971c6ca

Please sign in to comment.