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.TypesandGHC.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 thehaskelinepackage.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, theWin32package has been supporting the acquisition of Windows handles for quite some time. In fact, the code ofWin32’sSystem.Win32.Types.withHandleToHANDLEoperation is essentially the same as the code ofhaskeline’sSystem.Console.Haskeline.Backend.Win32.Echo.withHandleToHANDLEoperation.The present pull request changes
haskelineto use the new operationwithFileDescriptorReadingBiasedRawfrom the above-mentioned draft implementation for acquiring POSIX file descriptors andwithHandleToHANDLEfromWin32for 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
withHandleToHANDLEalso 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,withHandleToHANDLEdoes 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,
haskelineused to requireWin32of at least version 2.5.0, while with the changes introduced by this pull request it requiresWin32of at least version 2.5.1. This is because version 2.5.1 ofWin32introduced thewithHandleToHANDLEoperation, 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 oldWin32version.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.