From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED!not-for-mail From: Eli Zaretskii Newsgroups: gmane.emacs.bugs Subject: bug#25316: Patch for bug#25316: 26.0.50; Bugs in testcover-reinstrument Date: Fri, 29 Sep 2017 13:05:13 +0300 Message-ID: <83o9pt95wm.fsf@gnu.org> References: <87bmlybfjp.fsf@runbox.com> Reply-To: Eli Zaretskii NNTP-Posting-Host: blaine.gmane.org X-Trace: blaine.gmane.org 1506679602 4952 195.159.176.226 (29 Sep 2017 10:06:42 GMT) X-Complaints-To: usenet@blaine.gmane.org NNTP-Posting-Date: Fri, 29 Sep 2017 10:06:42 +0000 (UTC) Cc: 25316@debbugs.gnu.org To: Gemini Lasswell Original-X-From: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Fri Sep 29 12:06:31 2017 Return-path: Envelope-to: geb-bug-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by blaine.gmane.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dxsBR-0007wL-6A for geb-bug-gnu-emacs@m.gmane.org; Fri, 29 Sep 2017 12:06:13 +0200 Original-Received: from localhost ([::1]:34456 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dxsBY-00077Q-BO for geb-bug-gnu-emacs@m.gmane.org; Fri, 29 Sep 2017 06:06:20 -0400 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:38414) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dxsBJ-00077J-Sr for bug-gnu-emacs@gnu.org; Fri, 29 Sep 2017 06:06:12 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dxsBG-00056Q-K5 for bug-gnu-emacs@gnu.org; Fri, 29 Sep 2017 06:06:05 -0400 Original-Received: from debbugs.gnu.org ([208.118.235.43]:57170) by eggs.gnu.org with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.71) (envelope-from ) id 1dxsBG-00056M-F1 for bug-gnu-emacs@gnu.org; Fri, 29 Sep 2017 06:06:02 -0400 Original-Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.84_2) (envelope-from ) id 1dxsBG-0002fR-7F for bug-gnu-emacs@gnu.org; Fri, 29 Sep 2017 06:06:02 -0400 X-Loop: help-debbugs@gnu.org Resent-From: Eli Zaretskii Original-Sender: "Debbugs-submit" Resent-CC: bug-gnu-emacs@gnu.org Resent-Date: Fri, 29 Sep 2017 10:06:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 25316 X-GNU-PR-Package: emacs X-GNU-PR-Keywords: patch Original-Received: via spool by 25316-submit@debbugs.gnu.org id=B25316.150667953710211 (code B ref 25316); Fri, 29 Sep 2017 10:06:02 +0000 Original-Received: (at 25316) by debbugs.gnu.org; 29 Sep 2017 10:05:37 +0000 Original-Received: from localhost ([127.0.0.1]:37618 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dxsAr-0002ed-ET for submit@debbugs.gnu.org; Fri, 29 Sep 2017 06:05:37 -0400 Original-Received: from eggs.gnu.org ([208.118.235.92]:47388) by debbugs.gnu.org with esmtp (Exim 4.84_2) (envelope-from ) id 1dxsAq-0002eN-F0 for 25316@debbugs.gnu.org; Fri, 29 Sep 2017 06:05:36 -0400 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1dxsAi-0004re-78 for 25316@debbugs.gnu.org; Fri, 29 Sep 2017 06:05:31 -0400 Original-Received: from fencepost.gnu.org ([2001:4830:134:3::e]:34691) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1dxsAi-0004rY-2m; Fri, 29 Sep 2017 06:05:28 -0400 Original-Received: from 84.94.185.246.cable.012.net.il ([84.94.185.246]:1118 helo=home-c4e4a596f7) by fencepost.gnu.org with esmtpsa (TLS1.2:RSA_AES_256_CBC_SHA1:256) (Exim 4.82) (envelope-from ) id 1dxsAg-0005M3-FM; Fri, 29 Sep 2017 06:05:27 -0400 In-reply-to: <87bmlybfjp.fsf@runbox.com> (message from Gemini Lasswell on Mon, 25 Sep 2017 15:04:58 -0700) X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.18 Precedence: list X-detected-operating-system: by eggs.gnu.org: GNU/Linux 2.2.x-3.x [generic] X-Received-From: 208.118.235.43 X-BeenThere: bug-gnu-emacs@gnu.org List-Id: "Bug reports for GNU Emacs, the Swiss army knife of text editors" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Original-Sender: "bug-gnu-emacs" Xref: news.gmane.org gmane.emacs.bugs:137573 Archived-At: > From: Gemini Lasswell > Date: Mon, 25 Sep 2017 15:04:58 -0700 > > The attached patches fix the 5 bugs in this bug report, as well as > 11307, 24509, 24688, 24743 and 25326. > > testcover-reinstrument is a code walker which rewrites Edebug's > instrumented code replacing Edebug's functions edebug-enter, > edebug-before and edebug-after with Testcover's functions (some with > different call signatures), and at the same time determining which > forms might only return a single value and treating them > differently. Since it uses car and cdr to parse and rewrite the code, > it is consequently difficult to read and modify. Thanks, I have a few comments below. Please let others to comment for a week or so before installing on master. > > My original goal was to change testcover-reinstrument to use pcase, > but along the way I realized that I could simplify it and not only fix > all the bugs where one of Edebug's functions gets left in the > instrumented code, but remove the possibility of undiscovered or > future ones by not doing code rewriting and instead adding a hook > mechanism to make Edebug's functions call Testcover's. So in these > patches testcover-reinstrument has become testcover-analyze-coverage, > which uses pcase to walk Edebug's instrumented code and save the > results of its analysis of single-value forms in Edebug's code > coverage vector. > > > [2:text/plain Hide Save:0001-Allow-Edebug-s-instrumentation-to-be-used-for-other-.patch (10kB)] > > >From c0e8293a9b4919b22e3d409acddc9bde49021bc8 Mon Sep 17 00:00:00 2001 > From: Gemini Lasswell > Date: Sat, 16 Sep 2017 14:23:35 -0700 > Subject: [PATCH 1/2] Allow Edebug's instrumentation to be used for other > purposes > > * lisp/emacs-lisp/edebug.el: > (edebug-after-instrumentation-functions) > (edebug-new-definition-functions): New hook variables. > (edebug-behavior-alist): New variable. > (edebug-read-and-maybe-wrap-form): Run a hook after a form is > wrapped. > (edebug-make-form-wrapper): Run a hook after a definition is > wrapped. > (edebug-default-enter): New name for edebug-enter. > (edebug-enter): New function which changes behavior of Edebug based > on symbol property 'edebug-behavior and edebug-behavior-alist. > (edebug-run-slow, edebug-run-fast): Modify edebug-behavior-alist. > --- > lisp/emacs-lisp/edebug.el | 154 ++++++++++++++++++++++++++++++---------------- > 1 file changed, 100 insertions(+), 54 deletions(-) > > diff --git a/lisp/emacs-lisp/edebug.el b/lisp/emacs-lisp/edebug.el > index dbc56e272f..ca1f55cb6a 100644 > --- a/lisp/emacs-lisp/edebug.el > +++ b/lisp/emacs-lisp/edebug.el > @@ -1065,6 +1065,29 @@ edebug-old-def-name > (defvar edebug-error-point nil) > (defvar edebug-best-error nil) > > +;; Hooks which may be used to extend Edebug's functionality. See > +;; Testcover for an example. > +(defvar edebug-after-instrumentation-functions nil > + "Abnormal hook run on code after instrumentation for debugging. > +Each function is called with one argument, a form which has just > +been instrumented for Edebugging.") > +(defvar edebug-new-definition-functions '(edebug-announce-definition) > + "Abnormal hook run after Edebug wraps a new definition. > +After Edebug has initialized its own data, each hook function is > +called with one argument, the symbol associated with the > +definition, which may be the actual symbol defined or one > +generated by Edebug.") These hooks should be documented in the ELisp manual and in NEWS. Also, please have an empty line between the defvar's. > @@ -1330,10 +1354,7 @@ edebug-make-form-wrapper > form-data-entry edebug-def-name ;; in case name is changed > form-begin form-end)) > > - ;; (message "defining: %s" edebug-def-name) (sit-for 2) > (edebug-make-top-form-data-entry form-data-entry) > - (message "Edebug: %s" edebug-def-name) > - ;;(debug edebug-def-name) Why are you removing this? It looks like debugging code that could be useful to someone, no? > +(defun edebug-announce-definition (def-name) > + "Announce Edebug's processing of DEF-NAME." > + (message "Edebug: %s" def-name)) This new function is not mentioned in the commit log message. > -(defun edebug-enter (function args body) > +(defun edebug-enter (func args body) This function is indicated as "new" in the commit log, but it isn't new. > +(defalias 'edebug-before nil > + "Function called by Edebug before a form is evaluated. > +See `edebug-behavior-alist' for implementations.") > +(defalias 'edebug-after nil > + "Function called by Edebug after a form is evaluated. > +See `edebug-behavior-alist' for implementations.") These are not in the commit log. > +** Testcover > + > +--- > +*** If you've tried to use Testcover before and were blocked by > +unhelpful error messages, give it another try. Many bugs have been > +fixed. Please make this a more informative entry. I would remove the 1st sentence, and instead describe what new features are available and what could users do with them. Since this is not documented in the manuals (and you suggest to leave it at that with the "---" marker), the NEWS entry should do a better job describing the changes. (You don't need to describe which bugs were fixed, only the new and changed behavior.) > +;;; Coverage Analysis > + > +;; The top level function for initializing code coverage is > +;; `testcover-analyze-coverage', which recursively walks the form it is > +;; passed, which should have already been instrumented by > +;; edebug-read-and-maybe-wrap-form, and initializes the associated > +;; code coverage vectors, which should have already been created by > +;; `edebug-clear-coverage'. > +;; > +;; The purpose of the analysis is to identify forms which can only > +;; ever return a single value. These forms can be considered to have > +;; adequate code coverage even if only executed once. In addition, > +;; forms which will never return, such as error signals, can be > +;; identified and treated correctly. This text uses one space between sentences, whereas our convention is to use 2. Thanks again for working on this.