Switch to high-level operations for obtaining OS handles #211
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There is an effort to move some GHC-specific modules out of
base
. Candidates for such moving areGHC.IO.Handle.Types
andGHC.IO.Handle.Internals
. These modules are often used for obtaining operating-system handles (file descriptors, Windows handles) from Haskell handles. Such uses are also present in thehaskeline
package.There is a proposal to add dedicated operations for operating-system handle acquisition to
base
. A corresponding draft implementation can be found in GHC merge request !14732. Furthermore, theWin32
package has been supporting the acquisition of Windows handles for quite some time. In fact, the code ofWin32
’sSystem.Win32.Types.withHandleToHANDLE
operation is essentially the same as the code ofhaskeline
’sSystem.Console.Haskeline.Backend.Win32.Echo.withHandleToHANDLE
operation.The present pull request changes
haskeline
to use the new operationwithFileDescriptorReadingBiasedRaw
from the above-mentioned draft implementation for acquiring POSIX file descriptors andwithHandleToHANDLE
fromWin32
for acquiring Windows handles.There are a few things to be aware of:
The above-mentioned draft implementation also contains operations for acquiring Windows handles. However, these operations only work when using the Windows I/O manager, while
withHandleToHANDLE
also works when using the POSIX I/O manager on Windows, by performing an extra conversion from an acquired POSIX file descriptor to the corresponding Windows handle. Furthermore, unlike the operations from the draft implementation,withHandleToHANDLE
does not block operations on the given handle, which may or may not be relevant.For detecting whether a given handle refers to a MinTTY console,
haskeline
used to requireWin32
of at least version 2.5.0, while with the changes introduced by this pull request it requiresWin32
of at least version 2.5.1. This is because version 2.5.1 ofWin32
introduced thewithHandleToHANDLE
operation, and I did not deem it worthwhile to leave the previous, custom implementation of Windows handle acquisition in place just for supporting a single, rather oldWin32
version.When running the test suite on the code in this pull request using Ubuntu 24.04, several test failures are reported, but these are also reported when running the test suite on the unmodified code.