[Haskell-cafe] Issue building with ghc-9.8.2 and packages unix, directory, filepath and os-string
Tom Smeding
x at tomsmeding.com
Thu May 30 21:00:21 UTC 2024
`os-string` has been split from `filepath` in filepath 1.5.0.0. If you
search for "flag(os-string)" in unix' cabal file here:
https://hackage.haskell.org/package/unix-2.8.5.1/unix.cabal
you'll see that the package has been set up to use `os-string` if
`filepath >= 1.5.0.0`, and to not depend on `os-string` otherwise.
For filepath < 1.5.0.0, the modules in question are in the `filepath`
package. You can get them by manually depending on `filepath` too.
If you want the post-`os-string` split `filepath`, simply add a lower
bound on the version of `filepath` in your thing.cabal file: `filepath
>= 1.5.0.0`. As you can see, the diagnostic you got shows that you were
indeed using an older `filepath` version.
- Tom
On 30/05/2024 22:22, Andrew Lelechenko wrote:
> Normally you do not need to set `constraints: unix +os-string, directory +os-string`. It’s better to let Cabal figure out a build plan without forcing its hand.
>
> Sharing your project would help, otherwise it’s hard to diagnose.
>
> Best regards,
> Andrew
>
>> On 30 May 2024, at 08:54, Daniel Trstenjak <daniel.trstenjak at gmail.com> wrote:
>>
>> Hi,
>>
>> I'm trying to get my program to compile with ghc-9.8.2. Raising the
>> upper bounds of my dependencies I'm running into a compile error
>> for the unix-2.8.5.1 package:
>>
>> [15 of 53] Compiling System.Posix.Env.PosixString ( /home/dan/sources/unix-2.8.5.1/dist-newstyle/build/x86_64-linux/ghc-9.8.2/unix-2.8.5.1/build/System/Posix/Env/PosixString.hs, /home/dan/sources/unix-2.8.5.1/dist-newstyle/build/x86_64-linux/ghc-9.8.2/unix-2.8.5.1/build/System/Posix/Env/PosixString.o, /home/dan/sources/unix-2.8.5.1/dist-newstyle/build/x86_64-linux/ghc-9.8.2/unix-2.8.5.1/build/System/Posix/Env/PosixString.dyn_o )
>>
>> System/Posix/Env/PosixString.hsc:45:1: error: [GHC-87110]
>> Could not load module ‘System.OsString.Internal.Types’.
>> It is a member of the hidden package ‘os-string-2.0.3’.
>> Perhaps you need to add ‘os-string’ to the build-depends in your .cabal file.
>> It is a member of the hidden package ‘filepath-1.4.200.1’.
>> Perhaps you need to add ‘filepath’ to the build-depends in your .cabal file.
>> Use -v to see a list of the files searched for.
>> |
>> 45 | import System.OsString.Internal.Types
>> | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>
>> System/Posix/Env/PosixString.hsc:47:1: error: [GHC-61948]
>> Could not find module ‘System.OsString.Data.ByteString.Short’.
>> Perhaps you meant
>> System.OsString.Data.ByteString.Short (needs flag -package-id os-string-2.0.3)
>> System.OsPath.Data.ByteString.Short (needs flag -package-id filepath-1.4.200.1)
>> System.OsString.Data.ByteString.Short.Word16 (needs flag -package-id os-string-2.0.3)
>> |
>> 47 | import qualified "os-string" System.OsString.Data.ByteString.Short as B
>> | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>
>> System/Posix/PosixPath/FilePath.hsc:50:1: error: [GHC-61948]
>> Could not find module ‘System.OsString.Data.ByteString.Short’.
>> Perhaps you meant
>> System.OsString.Data.ByteString.Short (needs flag -package-id os-string-2.0.3)
>> System.OsPath.Data.ByteString.Short (needs flag -package-id filepath-1.4.200.1)
>> System.OsString.Data.ByteString.Short.Word16 (needs flag -package-id os-string-2.0.3)
>> |
>> 50 | import "os-string" System.OsString.Data.ByteString.Short as BSS
>> | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>
>> System/Posix/PosixPath/FilePath.hsc:55:1: error: [GHC-87110]
>> Could not load module ‘System.OsString.Internal.Types’.
>> It is a member of the hidden package ‘os-string-2.0.3’.
>> Perhaps you need to add ‘os-string’ to the build-depends in your .cabal file.
>> It is a member of the hidden package ‘filepath-1.4.200.1’.
>> Perhaps you need to add ‘filepath’ to the build-depends in your .cabal file.
>> Use -v to see a list of the files searched for.
>> |
>> 55 | import System.OsString.Internal.Types (PosixString(..), pattern PS)
>> | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
>>
>> I can get rid of this compile error and a similar one for the directory
>> package by setting the flag os-string in my cabal.project file:
>> constraints: unix +os-string, directory +os-string
>>
>> Now I'm wondering what is the right way to handle this case?
>> Thanks for any hints!
>>
>> Greetings,
>> Daniel
>> _______________________________________________
>> Haskell-Cafe mailing list
>> To (un)subscribe, modify options or view archives go to:
>> http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe
>> Only members subscribed via the mailman list are allowed to post.
> _______________________________________________
> Haskell-Cafe mailing list
> To (un)subscribe, modify options or view archives go to:
> http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe
> Only members subscribed via the mailman list are allowed to post.
More information about the Haskell-Cafe
mailing list