Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

Fix Issue 10523 - Enabled BigInt to work in CTFE #10725

Merged
merged 8 commits into from
Apr 2, 2025

Conversation

davidisinta
Copy link
Contributor

Added if statements to call free only at runtime so that the functions can also execute at compile time.

@dlang-bot
Copy link
Contributor

Thanks for your pull request and interest in making D better, @davidisinta! We are looking forward to reviewing it, and you should be hearing from a maintainer soon.
Please verify that your PR follows this checklist:

  • My PR is fully covered with tests (you can see the coverage diff by visiting the details link of the codecov check)
  • My PR is as minimal as possible (smaller, focused PRs are easier to review than big ones)
  • I have provided a detailed rationale explaining my changes
  • New or modified functions have Ddoc comments (with Params: and Returns:)

Please see CONTRIBUTING.md for more information.


If you have addressed all reviews or aren't sure how to proceed, don't hesitate to ping us with a simple comment.

Bugzilla references

Your PR doesn't reference any Bugzilla issue.

If your PR contains non-trivial changes, please reference a Bugzilla issue or create a manual changelog.

Testing this PR locally

If you don't have a local development environment setup, you can use Digger to test this PR:

dub run digger -- build "master + phobos#10725"

@ryuukk
Copy link

ryuukk commented Apr 1, 2025

Somebody should perhaps look into removing the useless allocations, that code must be very slow

@dkorpel
Copy link
Contributor

dkorpel commented Apr 1, 2025

I wonder if it would be better to put the __ctfe check in the implementation of GC.free, so you wouldn't need to guard every call site out there.

@davidisinta
Copy link
Contributor Author

@dkorpel I dont think putting the __ctfe check in GC.free would work. From my understanding free is always a runtime function so that check would never return true because free can only be called in a runtime context.

@thewilsonator thewilsonator merged commit 8233866 into dlang:master Apr 2, 2025
9 of 10 checks passed
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants