Skip to content

Commit

Permalink
add option to disable silent and switch back to old (buggy) behavior
Browse files Browse the repository at this point in the history
Add user option coq-run-completely-silent, which, when disabled,
switches Coq to old behavior where Coq is dynamically switched to
silent on longer action item lists.
  • Loading branch information
hendriktews committed Sep 30, 2024
1 parent fcc2b96 commit 837fae8
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 16 deletions.
3 changes: 3 additions & 0 deletions CHANGES
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,9 @@ the Git ChangeLog, the GitHub repo https://github.com/ProofGeneral/PG
during auto compilation.
*** Fix issues #687 and #688 where the omit-proofs feature causes
errors on correct code.
*** Run Coq completely silent to fix #568. If you experience unexpected
behavior, please report a bug and disable
`coq-run-completely-silent' to switch back to old behavior.


* Changes of Proof General 4.5 from Proof General 4.4
Expand Down
57 changes: 41 additions & 16 deletions coq/coq.el
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,24 @@
;; :type 'number
;; :group 'coq)

(defcustom coq-run-completely-silent t
"Run Coq completely silent if enabled.
Please restart Proof General after changing this setting!
If enabled, run Coq completely silent (Set Silent) and only issue
a show command when necessary to update the goals buffer. This
behavior is new. If you experience strange effects, please report
a bug and switch this flag off to return to old behavior. When
disabled, Coq is dynamically switched to silent for longer lists
of commands and switched to verbose before the last command. A
manual Show command (C-c C-p) is necessary if the last command
fails to update the goals buffer (e.g., if it is a comment or it
is not executed because some other command before failed, see
also bug report #568)."
:type 'boolean
:safe 'booleanp
:group 'coq)

(defcustom coq-user-init-cmd nil
"User defined init commands for Coq.
These are appended at the end of `coq-shell-init-cmd'."
Expand Down Expand Up @@ -122,16 +140,17 @@ Namely, goals that do not fit in the goals window."
;; should re-intialize to coq-search-blacklist-string instead of
;; keeping the current value (that may come from another file).
,(format "Add Search Blacklist %s." coq-search-blacklist-current-string))
'("Set Suggest Proof Using."
"Set Silent.")
'("Set Suggest Proof Using.")
(if coq-run-completely-silent '("Set Silent.") ())
coq-user-init-cmd)
"Commands for initial Coq configuration, Coq variant of `proof-shell-init-cmd'.
List of commands sent to the Coq background process just after it
has been started. This happens inside `proof-shell-config-done',
when the major mode `coq-shell-mode' is configured in the `*coq*'
buffer.
Sets silent mode.
Sets silent mode if `coq-run-completely-silent' is set. Note that
this constant is not updated when `coq-run-completely-silent' is changed.
In normal interaction, Coq is started because the user asserts
some commands. Therefore the commands here are followed by those
Expand Down Expand Up @@ -1246,15 +1265,17 @@ This function is called from `proof-shell-exec-loop' via
(and (string-match-p "BackTo\\s-" cmd)
(> (length coq-last-but-one-proofstack) coq--retract-naborts)))
(append
(unless coq-run-completely-silent '("Unset Silent."))
(if (coq--post-v810) (list (coq-diffs)) ())
;; '("Show.")
(coq--show-proof-stepwise-cmds)))

((or
;; If we go back in the buffer and not in the above case, i.e., outside a
;; proof, then only set the Diffs option.
(string-match-p "BackTo\\s-" cmd))
(if (coq--post-v810) (list (coq-diffs)) ()))
(append
(unless coq-run-completely-silent '("Unset Silent."))
(if (coq--post-v810) (list (coq-diffs)) ())))

((or
;; If starting a proof, Show Proof if need be
Expand Down Expand Up @@ -1968,8 +1989,9 @@ at `proof-assistant-settings-cmds' evaluation time.")
;; When proof-shell-start-silent-cmd and proof-shell-stop-silent-cmd stay at
;; their default value nil, the generic code won't switch Coq to silent and
;; noisy at, respectively, the beginning and end of longer asserted regions.
;; (setq proof-shell-start-silent-cmd "Set Silent."
;; proof-shell-stop-silent-cmd "Unset Silent.")
(unless coq-run-completely-silent
(setq proof-shell-start-silent-cmd "Set Silent."
proof-shell-stop-silent-cmd "Unset Silent."))

;; prooftree config
(setq
Expand Down Expand Up @@ -3103,22 +3125,25 @@ Important: Coq gives char positions in bytes instead of chars.


(defun coq-show-goals-inside-proof (keep-response)
"Update goals buffer when action item list has been processed.
Add a Show command as priority action, such that it will still be
processed if the generic machinery inside `proof-shell-filter'
believes it has processed the last item from the action list.
When Coq runs in silent mode, we need to update the goals
precisely when everything else from the action list has been
processed.
"Update goals when action item list has been processed, if running silent.
If `coq-run-completely-silent' is set, add a Show command as
priority action, such that it will still be processed if the
generic machinery inside `proof-shell-filter' believes it has
processed the last item from the action list. When Coq runs in
silent mode, we need to update the goals precisely when
everything else from the action list has been processed.
The Show command is only added inside proofs and only if the last
processed command was not a show command from this function. The
action item flag `'dont-show-when-silent' is used for the latter.
KEEP-RESPONSE should be set if the last command produced some
error or response that should be kept and shown to the user. If
set, the flag `'keep-response' is added to the action item."
(when (and coq-last-but-one-proofstack
set, the flag `'keep-response' is added to the action item.
Do nothing if `coq-run-completely-silent' is disabled."
(when (and coq-run-completely-silent
coq-last-but-one-proofstack
(not (member 'dont-show-when-silent
proof-shell-delayed-output-flags)))
(let* ((flags-1 (list 'dont-show-when-silent 'invisible 'empty-action-list))
Expand Down

0 comments on commit 837fae8

Please sign in to comment.