From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!.POSTED!not-for-mail From: Alan Mackenzie Newsgroups: gmane.emacs.devel Subject: Re: forward-comment and syntax-ppss Date: Fri, 9 Dec 2016 18:00:59 +0000 Message-ID: <20161209180059.GB2203@acm.fritz.box> References: <20161206195507.GA2996@acm.fritz.box> <83fd1db0-7362-6117-c5cd-715398c0dea4@gmail.com> <20161207220447.GA4503@acm.fritz.box> <20161208201517.GB3120@acm.fritz.box> NNTP-Posting-Host: blaine.gmane.org Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Trace: blaine.gmane.org 1481306538 21926 195.159.176.226 (9 Dec 2016 18:02:18 GMT) X-Complaints-To: usenet@blaine.gmane.org NNTP-Posting-Date: Fri, 9 Dec 2016 18:02:18 +0000 (UTC) User-Agent: Mutt/1.5.24 (2015-08-30) Cc: emacs-devel@gnu.org To: Stefan Monnier Original-X-From: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Fri Dec 09 19:02:09 2016 Return-path: Envelope-to: ged-emacs-devel@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 1cFPUn-0004Tl-2y for ged-emacs-devel@m.gmane.org; Fri, 09 Dec 2016 19:02:09 +0100 Original-Received: from localhost ([::1]:48131 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cFPUq-0004nS-V4 for ged-emacs-devel@m.gmane.org; Fri, 09 Dec 2016 13:02:12 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:44972) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1cFPU6-0004Vj-Qz for emacs-devel@gnu.org; Fri, 09 Dec 2016 13:01:31 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1cFPU2-0004f9-Kz for emacs-devel@gnu.org; Fri, 09 Dec 2016 13:01:26 -0500 Original-Received: from ocolin.muc.de ([193.149.48.4]:29599 helo=mail.muc.de) by eggs.gnu.org with smtp (Exim 4.71) (envelope-from ) id 1cFPU2-0004et-BM for emacs-devel@gnu.org; Fri, 09 Dec 2016 13:01:22 -0500 Original-Received: (qmail 72530 invoked by uid 3782); 9 Dec 2016 18:01:20 -0000 Original-Received: from acm.muc.de (p548C753B.dip0.t-ipconnect.de [84.140.117.59]) by colin.muc.de (tmda-ofmipd) with ESMTP; Fri, 09 Dec 2016 19:01:19 +0100 Original-Received: (qmail 2345 invoked by uid 1000); 9 Dec 2016 18:00:59 -0000 Content-Disposition: inline In-Reply-To: X-Delivery-Agent: TMDA/1.1.12 (Macallan) X-Primary-Address: acm@muc.de X-detected-operating-system: by eggs.gnu.org: FreeBSD 9.x [fuzzy] X-Received-From: 193.149.48.4 X-BeenThere: emacs-devel@gnu.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: "Emacs development discussions." List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: emacs-devel-bounces+ged-emacs-devel=m.gmane.org@gnu.org Original-Sender: "Emacs-devel" Xref: news.gmane.org gmane.emacs.devel:210198 Archived-At: Hello, Stefan. On Thu, Dec 08, 2016 at 04:13:04PM -0500, Stefan Monnier wrote: > >> And how would the new function not face the same breakage that can't be > >> fixed? > > It would have a sensible definition. "Returns the equivalent of > > (parse-partial-sexp (point-min) POS)" is a silly definition which cannot > > be coded up in any reasonable fashion. > Oh, it can be coded alright if we want it (it's not terribly hard, > actually). The choice was largely arbitrary and indeed the behavior is > currently an unreliable mix of point-min and 1. Indeed. > Changing syntax-ppss to reliably return (parse-partial-sexp (point-min) POS) > or (parse-partial-sexp 1 POS), is not terribly hard. The issue is > mostly one of choosing between the two, where some cases want one and > others want the other, which is why so far I haven't actually decided > and left it simply unreliable when used in a narrowed buffer. Thanks for the explanation for leaving it unfixed, which I understand and accept. Why don't you chose both (i.e. two distinct functions)? :-) > >> As you should know, your comment-cache code suffers from the exact same > >> problem. > > Rubbish. Modulo any remaining bugs, it does what it says it does. > Without your cache, the behavior of forward-comment is consistent with > a semantics like (parse-partial-sexp (point-min) POS), whereas with your > cache, forward-comment suddenly gets a new semantics similar to > (parse-partial-sexp 1 POS). OK, maybe. I'm struggling a bit with your analogies. But I think I see what you're trying to say. > I don't claim the new behavior is worse, but it will introduce breakage > in some existing code (just like my syntax-ppss patch, of course, for > the same reasons). So does it "[do] what it says it does"? Yes. It certainly doesn't fail in anything like the fashion that syntax-ppss does. Modulo any remaining bugs. > > Nor should it. Our primitives `car', `cdr', `list', etc. also don't say > > what the intention behind them is; they just work. Narrowing is what it > > is. Simple and austere. Complexifying narrowing by introducing a > > notion of "intention" would surely make it more difficult to use and > > possibly foul things up massively. > Yet, you want to use (parse-partial-sexp 1 POS), which only makes sense > if you treat narrowing as having a particular intention. No. It makes sense, full stop. If it doesn't, then the notion of narrowing doesn't make sense either. Plainly it does. The definition of a primitive cannot be dependent upon the psychology of the hacker using it. There is nothing in the notion of narrowing which suggests that it should change the syntactic context of any text - if a certain buffer position is inside a string, it is inside the string; it doesn't suddenly become outside the string by virtue of where the buffer is narrowed. Were that not the case, the notion "inside a string" would become meaningless. > > Rubbish again. "Returns the equivalent of (parse-partial-sexp > > (point-min) POS)" cannot be implemented in any reasonable fashion, > Of course it can. Here are two easy options: > - flush the cache if point-min is different from last time. Likely, the cache would be flushed so much it wouldn't really serve much purpose. > - index the cache with point-min. I don't understand what you mean by this. > I'm sure you too can come up with other solutions. Maybe I could. > This is a non-issue. The real issue is to decide which behavior to get when. > > and just putting a `widen' into the current code won't change that > > one bit. > It would change the behavior to (parse-partial-sexp 1 POS) so of course, > the doc would be changed accordingly. You would then have a different function. Something I've been suggesting for a long while. > Currently any code which relies on syntax-ppss returning > (parse-partial-sexp (point-min) POS) when narrowed is broken anyway, > so we can easily make such a change. No, that code is not broken. It is syntax-ppss that is broken. If you replace syntax-ppss with a different function (as I have been advocating), that is going to break some code which uses syntax-ppss. > > As I said above, I think syntax-ppss should be retired and replaced by a > > function which does parse-partial-sexp starting at 1 rather than > > (point-min). > We're talking about changing 3 lines of doc and 2 lines of code. > Why would you describe such a trivial change as "retire and replace"? Because we're talking about a different function which does a job different from what syntax-ppss is specified to do. That is not a minor change, regardless of how few lines of code and documentation need to be changed. > Stefan -- Alan Mackenzie (Nuremberg, Germany).