-
Notifications
You must be signed in to change notification settings - Fork 195
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[WIP] GHC 8.10.7 #1522
base: master
Are you sure you want to change the base?
[WIP] GHC 8.10.7 #1522
Conversation
There is an issue compiling `codeworld-base`
Hmm, that's too bad. The good news, though, is that CodeWorld already builds its own patched version of GHCJS, if someone is willing to backport this fix. It doesn't look too difficult to do (it's a small patch!) But I haven't checked whether the surrounding code has changed much since 8.10.7 |
@@ -10,3 +10,6 @@ packages: | |||
codeworld-server/ | |||
codeworld-base/ | |||
funblocks-client/ | |||
|
|||
constraints: | |||
ghcjs-dom ==0.9.* |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd rather keep all the version constraints in one place. Can this be kept in the cabal file?
@@ -61,7 +61,7 @@ Library | |||
mtl >= 2.2.1 && < 2.3, | |||
random >= 1.1 && < 1.2, | |||
ref-tf >= 0.4 && < 0.5, | |||
reflex >= 0.6.3 && < 0.7, | |||
reflex >= 0.6.3, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I believe we need upper bounds on versions to upload to hackage. So feel free to relax bounds, but let's leave them in place for codeworld-api. Other packages don't need upper bounds, since they don't get released to hackage.
ghc == 8.10.*, | ||
ghc-boot, | ||
ghc-boot-th == 8.10.*, | ||
ghc-lib-parser, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't see where this is used.
If it's needed, ghc-lib-parser changes dramatically between versions (it's just a copy of parts of ghc), so it needs version bounds. But it would be better to leave it out and update the ghc code, if it's not too difficult.
|
||
fakeDynFlags :: GHC.DynFlags | ||
fakeDynFlags = GHC.defaultDynFlags fakeSettings fakeLlvmConfig | ||
|
||
fakePlatformMisc :: GHC.PlatformMisc | ||
fakePlatformMisc = GHC.PlatformMisc |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I almost cringe to ask it, but can you include field names here so the reader has some hope of finding what they need to change in the future?
@@ -39,7 +39,7 @@ Executable codeworld-server | |||
fast-logger, | |||
filelock, | |||
filepath, | |||
haskell-src-exts < 1.21, | |||
haskell-src-exts, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! I looked up the history, and this was originally added to keep hindent working, but CodeWorld now uses Ormolu instead of hindent, so dropping the restriction is fine.
Here is the backport; it solves the error: https://gitlab.haskell.org/ghc/ghc/-/merge_requests/6554 |
Cool! I'm not sure whether there will be a new GHC release in the 8.x series, but if you make a patch (test case not necessary) and drop it in https://github.com/google/codeworld/tree/master/ghc-artifacts, and then apply the patch in install.sh near https://github.com/google/codeworld/blob/master/install.sh#L226, then CodeWorld will build with the change. That should unblock you. Speaking of patches there, I wonder whether the remaining patches in that directory are still needed. The default main patch was contributed upstream, and has probably made it into GHC 8.10, but I'll verify that. The dedup fix for the linker was a GHCJS patch, and my hope is that it's also merged in the 8.10 branch. Again, I'll try to find evidence for this and report back. |
I've confirmed that the default main patch does NOT need to be ported. It's already part of GHC 8.10. Unfortunately, ghcjs/ghcjs#788 still isn't merged, so this one needs to be ported forward. There have been changes to that file, so it's not immediately obvious to me how to do so, but @3noch or @tomsmalley may know. |
There is an issue compiling
codeworld-base
:This appears to be an instance of https://gitlab.haskell.org/ghc/ghc/-/issues/18708
Cabal 3.6.1.0
GHC 8.10.7
Debian Bullseye