Switch to high-level operations for obtaining OS handles#211
Switch to high-level operations for obtaining OS handles#211jeltsch wants to merge 2 commits intohaskell:masterfrom
Conversation
What are the implications of this? I know nothing about Windows I/O. Will any users notice? |
Those operations, which only work when using the Windows I/O manager, aren’t used by the code in this pull request. Instead, this pull requests replaces the use of I mentioned the new operations for acquiring Windows handles from !14732 only to explain why this pull request doesn’t use them. It uses operations from !14732 only to acquire file descriptors on POSIX systems. |
|
Apologies for not getting back to this. CI is failing, but the logs are gone. I'll see if I can get it to re-run. |
|
Does this depend on a module that was not added to GHC until very recently? Haskeline currently works on even very old GHC's, and I'm somewhat reluctant to change that. |
|
Yes, it relies on a new module: |
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.