Skip to content
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

fix: make "use `set_option diagnostics true" message conditional on current setting #4781

Merged
merged 2 commits into from
Jul 31, 2024

Conversation

kmill
Copy link
Collaborator

@kmill kmill commented Jul 18, 2024

It is confusing that the message suggesting to use the diagnostics option is given even when the option is already set. This PR makes use of lazy message data to make the message contingent on the option being false.

It also tones down the promise that there is any diagonostic information available, since sometimes there is nothing to report.

Suggested by Johan Commelin.

…urrent setting

It is confusing that the message suggesting to use the `diagnostics` option is given even when the option is already set. This PR makes use of lazy message data to make the message contingent on the option being false.

It also tones down the promise that there is any diagonostic information available, since sometimes there is nothing to report.

Suggested by Johan Commelin.
@github-actions github-actions bot added the toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN label Jul 18, 2024
@leanprover-community-mathlib4-bot
Copy link
Collaborator

Mathlib CI status (docs):

  • ❗ Batteries/Mathlib CI will not be attempted unless your PR branches off the nightly-with-mathlib branch. Try git rebase 490d16c80d7bdf96a43345d9b307c21d8fbb6a16 --onto ba3565f441a4533490c339ead6d9ee5b1220110b. (2024-07-18 05:23:14)

@kim-em kim-em added this pull request to the merge queue Jul 31, 2024
Merged via the queue into leanprover:master with commit d5e7dba Jul 31, 2024
12 checks passed
Comment on lines -303 to +315
let msg := s!"(deterministic) timeout{atModuleName}, maximum number of heartbeats ({max/1000}) has been reached\nuse `set_option {optionName} <num>` to set the limit\n{useDiagnosticMsg}"
throw <| Exception.error (← getRef) (MessageData.ofFormat (Std.Format.text msg))
throw <| Exception.error (← getRef) m!"\
(deterministic) timeout{atModuleName}, maximum number of heartbeats ({max/1000}) has been reached\n\
Use `set_option {optionName} <num>` to set the limit.\
{useDiagnosticMsg}"
Copy link
Contributor

@eric-wieser eric-wieser Oct 1, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change caused #5565, which probably has subtle fallout on mathlib. Can a fix (such as #5566) make it into a 4.12.1?

github-merge-queue bot pushed a commit that referenced this pull request Oct 9, 2024
Fixes #5565, by using tags instead of trying to string match on a
`MessageData`. This ends up reverting some unwanted test output changes
from #4781 too.

This changes `isMaxRecDepth` for good measure too.

This was a regression in Lean 4.11.0, so may be worth backporting to
4.12.x, if not also 4.11.x.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
toolchain-available A toolchain is available for this PR, at leanprover/lean4-pr-releases:pr-release-NNNN
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants