From mboxrd@z Thu Jan  1 00:00:00 1970
Return-Path: <emacs-orgmode-bounces+larch=yhetil.org@gnu.org>
Received: from mp2.migadu.com ([2001:41d0:403:58f0::])
	(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits))
	by ms13.migadu.com with LMTPS
	id ABowGrqwbmaCLwEAe85BDQ:P1
	(envelope-from <emacs-orgmode-bounces+larch=yhetil.org@gnu.org>)
	for <larch@yhetil.org>; Sun, 16 Jun 2024 09:30:34 +0000
Received: from aspmx1.migadu.com ([2001:41d0:403:58f0::])
	(using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits))
	by mp2.migadu.com with LMTPS
	id ABowGrqwbmaCLwEAe85BDQ
	(envelope-from <emacs-orgmode-bounces+larch=yhetil.org@gnu.org>)
	for <larch@yhetil.org>; Sun, 16 Jun 2024 11:30:34 +0200
X-Envelope-To: larch@yhetil.org
Authentication-Results: aspmx1.migadu.com;
	dkim=pass header.d=posteo.net header.s=2017 header.b=grsEVWCp;
	dmarc=pass (policy=none) header.from=posteo.net;
	spf=pass (aspmx1.migadu.com: domain of "emacs-orgmode-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="emacs-orgmode-bounces+larch=yhetil.org@gnu.org"
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=yhetil.org;
	s=key1; t=1718530234;
	h=from:from:sender:sender:reply-to:subject:subject:date:date:
	 message-id:message-id:to:to:cc:cc:mime-version:mime-version:
	 content-type:content-type:in-reply-to:in-reply-to:
	 references:references:list-id:list-help:list-unsubscribe:
	 list-subscribe:list-post:dkim-signature;
	bh=I7Bk+Zj8JTQansw4eAoowSomliTrHoOStOg4lAr0btM=;
	b=KbPo71bplcZaVblhZvLXDMmFvgVGa8fYnsDYWN5WGXlbVC635FCtPhJpJxCsBvmD+TN40h
	4SbPipnmmp/Ukn02/G6m8o+uHPCl7TPv2h52lSWB+ucvRbyY1wNZ+35InL431zx0hw+tbG
	bKw9d0kgCHzXl4djbcxWTefm02u0cSg3TFvViGDwDW52rbmb3ymNHv9HUfTcHkQpbOIu9D
	8khPT4B3bN5IyO36fwpzNI+wsgZB93t3nt+NLxAooDoeWRt79ITFnZIIeMxU6lKgUEI0h/
	DFvNMtaPcy6Jt9kj1+83XMO8gEpfiEwd7VWWusHTZY3wAEmyp7OmMCgtRZv7Tw==
ARC-Seal: i=1; s=key1; d=yhetil.org; t=1718530234; a=rsa-sha256; cv=none;
	b=c6RcIxjojrggmoL0A/IaoBMmmbNtqJapUh9g/bR4bOZBPGnZbQ6YsAnuhTZxHr1aXpaqXe
	K5E56wZ7f6xI4vuyIqHoJ3Cp9u/CQY3d7Q9Sjq+M6Bm6yiR4OZyMnDfTZ4jhv2WJxN+j2k
	i16xi8+tqO1S3x/a22myB/WH9NywQJa2nUZTyaQ9oAKpgtXBmlRR+XF/045FQiLEbPHRIn
	J3XpdW8o1RkoLCdeQRLEy6mBTFHvs52bkblkscLBoOyIVxiy86mr+xFfUIqnA9NOAoyowS
	1fCi8cS+DHBTIZc0XZvof0ht6nnz8zTXS5CRH8rO91MDYX4VqGRPChRu0UolAw==
ARC-Authentication-Results: i=1;
	aspmx1.migadu.com;
	dkim=pass header.d=posteo.net header.s=2017 header.b=grsEVWCp;
	dmarc=pass (policy=none) header.from=posteo.net;
	spf=pass (aspmx1.migadu.com: domain of "emacs-orgmode-bounces+larch=yhetil.org@gnu.org" designates 209.51.188.17 as permitted sender) smtp.mailfrom="emacs-orgmode-bounces+larch=yhetil.org@gnu.org"
Received: from lists.gnu.org (lists.gnu.org [209.51.188.17])
	(using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits))
	(No client certificate requested)
	by aspmx1.migadu.com (Postfix) with ESMTPS id 2135066FC9
	for <larch@yhetil.org>; Sun, 16 Jun 2024 11:30:34 +0200 (CEST)
Received: from localhost ([::1] helo=lists1p.gnu.org)
	by lists.gnu.org with esmtp (Exim 4.90_1)
	(envelope-from <emacs-orgmode-bounces@gnu.org>)
	id 1sImCz-0000SW-Td; Sun, 16 Jun 2024 05:29:57 -0400
Received: from eggs.gnu.org ([2001:470:142:3::10])
 by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)
 (Exim 4.90_1) (envelope-from <yantar92@posteo.net>)
 id 1sImCx-0000Qc-SG
 for emacs-orgmode@gnu.org; Sun, 16 Jun 2024 05:29:55 -0400
Received: from mout01.posteo.de ([185.67.36.65])
 by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256)
 (Exim 4.90_1) (envelope-from <yantar92@posteo.net>)
 id 1sImCu-0002K0-Tk
 for emacs-orgmode@gnu.org; Sun, 16 Jun 2024 05:29:55 -0400
Received: from submission (posteo.de [185.67.36.169]) 
 by mout01.posteo.de (Postfix) with ESMTPS id CA745240028
 for <emacs-orgmode@gnu.org>; Sun, 16 Jun 2024 11:29:50 +0200 (CEST)
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=posteo.net; s=2017;
 t=1718530190; bh=1685cfvoPNtZLKn6oivGyj625oY3z8H8MQIE5IuuObc=;
 h=From:To:Cc:Subject:Date:Message-ID:MIME-Version:Content-Type:
 From;
 b=grsEVWCpxMZz1Zt5ME7k6URs1hPHlCaUdJGRZ8suKlSYfFEVifCPFisPa4SYqCHuJ
 +1BdB5Af5cCNyBTycxFKsv4WONcwPxEg/cIidify7TIOlBMd+/YiRqU7xq6wXOuyWC
 m1xAjBPbhXRgqXvf9MVjReiitLueCYuJNHr2WL6EvXYILyOFYbz9Fo9FQ/KLBiho9S
 HbPuzkijZjdoGh4bbTlEB6pyOnB6xotU6+do6g/oHnsYjlkwxzJKaHFDMkqGB/dn84
 FiEYJaiNZSlj4cCz5LbSR7tvzKaOUYjSi1G6h9lmH0lpFmJd721YE0eQnAsrHzAkY0
 BiUuVcY+2FGXQ==
Received: from customer (localhost [127.0.0.1])
 by submission (posteo.de) with ESMTPSA id 4W275V1mqFz6twc;
 Sun, 16 Jun 2024 11:29:50 +0200 (CEST)
From: Ihor Radchenko <yantar92@posteo.net>
To: Bruno Barbier <brubar.cs@gmail.com>
Cc: emacs-orgmode <emacs-orgmode@gnu.org>, Jack Kamm <jackkamm@gmail.com>,
 Matt <matt@excalamus.com>
Subject: Re: Pending contents in org documents
In-Reply-To: <666d4779.050a0220.13efd.8a2d@mx.google.com>
References: <87o7d0mm54.fsf@localhost> <87ttlhki9e.fsf@localhost>
 <65eb1e60.050a0220.337b2.a0f4@mx.google.com> <87frwuxy1b.fsf@localhost>
 <65f95bf2.050a0220.6d051.c8b1@mx.google.com> <87plvpjj76.fsf@localhost>
 <65fc06c1.5d0a0220.0d53.efdc@mx.google.com> <87frwjlr1a.fsf@localhost>
 <6601b872.050a0220.31a67.5a55@mx.google.com> <87le63c3qy.fsf@localhost>
 <660ed63d.050a0220.36fdd.af23@mx.google.com> <87cyqwyvgw.fsf@localhost>
 <66225435.5d0a0220.f60e4.c590@mx.google.com> <87r0f02vq2.fsf@localhost>
 <664f6f54.050a0220.10342.b002@mx.google.com> <87o78vwnds.fsf@localhost>
 <6658cd1f.050a0220.f6605.de1a@mx.google.com> <87jzja71n7.fsf@localhost>
 <665abf9f.050a0220.d2a6e.ef6b@mx.google.com> <87plsyz3rn.fsf@localhost>
 <666d4779.050a0220.13efd.8a2d@mx.google.com>
Date: Sun, 16 Jun 2024 09:31:35 +0000
Message-ID: <87ed8xi688.fsf@localhost>
MIME-Version: 1.0
Content-Type: text/plain
Received-SPF: pass client-ip=185.67.36.65; envelope-from=yantar92@posteo.net;
 helo=mout01.posteo.de
X-Spam_score_int: -43
X-Spam_score: -4.4
X-Spam_bar: ----
X-Spam_report: (-4.4 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1,
 DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1,
 RCVD_IN_DNSWL_MED=-2.3, RCVD_IN_MSPIKE_H3=0.001, RCVD_IN_MSPIKE_WL=0.001,
 SPF_HELO_NONE=0.001, SPF_PASS=-0.001,
 T_SCC_BODY_TEXT_LINE=-0.01 autolearn=ham autolearn_force=no
X-Spam_action: no action
X-BeenThere: emacs-orgmode@gnu.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: "General discussions about Org-mode." <emacs-orgmode.gnu.org>
List-Unsubscribe: <https://lists.gnu.org/mailman/options/emacs-orgmode>,
 <mailto:emacs-orgmode-request@gnu.org?subject=unsubscribe>
List-Archive: <https://lists.gnu.org/archive/html/emacs-orgmode>
List-Post: <mailto:emacs-orgmode@gnu.org>
List-Help: <mailto:emacs-orgmode-request@gnu.org?subject=help>
List-Subscribe: <https://lists.gnu.org/mailman/listinfo/emacs-orgmode>,
 <mailto:emacs-orgmode-request@gnu.org?subject=subscribe>
Errors-To: emacs-orgmode-bounces+larch=yhetil.org@gnu.org
Sender: emacs-orgmode-bounces+larch=yhetil.org@gnu.org
X-Migadu-Flow: FLOW_IN
X-Migadu-Country: US
X-Migadu-Spam-Score: -5.07
X-Spam-Score: -5.07
X-Migadu-Queue-Id: 2135066FC9
X-Migadu-Scanner: mx11.migadu.com
X-TUID: 7IzU4uKWf2wE

Bruno Barbier <brubar.cs@gmail.com> writes:

>>    - After failure, the "!" fringe indicator is visible, but it is not
>>      obvious at all that user can click to get details
>>      I first tried to click on the fringe itself to no avail. Then, I
>>      randomly clicked on the text and got the description buffer; but
>>      that was unexpected - the text I clicked did not have any
>>      indication of its "clickability" - neither some kind of underline
>>      face, nor an overlay or a mouse hint.
>
> I couldn't find a way to answer a click on a fringe.  Is there a way?

Well. I do not know a way either :)

> About how much to decorate, it depends on the user, I guess.  For
> example, when org-pending is used for org babel, it should be obvious
> that one has to click on "#+RESULTS:".
>
> The current decoration is not the best for discoverability, indeed.
> But decorating the whole outcome region would be too much IMHO, and,
> it might interfer with other buffer fontifications.

We may do what flycheck/flyspell do. Maybe fontifying not the whole
region, but at least the region part where the indication was placed.

I really find the current behavior unintuitive even for experienced Emacs
users.

> I've refactored the code and added two variables so that it's now
> configurable, see 'org-pending-outcome-pre-display-function' and
> 'org-pending-outcome-post-display-function'.

Makes sense. Although, "display" part in the names is very confusing -
it sounds way too similar to `pre-redisplay-functions', which is
something entirely different.

What about removing org-pending-output-pre-display-function entirely (we
can add it later, if necessary) and renaming
org-pending-outcome-post-display-function to

`org-pending-on-outcome-functions' - an abnormal hook executed after
ON-OUTCOME action.

>> 2. I tried to do M-x undo while the reglock was active, and got an
>>    error. I'd expect that undo would work, skipping the region.
>
> I'm not sure exactly what you did, nor which error you got.  I've
> noticed that the hacks (to handle indirect buffers) were flagging the
> buffer as "modified" (using text properties).  I've fixed that.
>
> Is the problem solved now ?

No.

What I did is:

1. make repro
2. Insert the example code from the top comment and uncomment it
3. M-x eval-buffer
4. *While regloc is active*, press C-x u
5. Observe

Debugger entered--Lisp error: (org-pending-error "Cannot modify a region containing pending content")
  signal(org-pending-error ("Cannot modify a region containing pending content"))
  (closure (t) (&rest _) (signal 'org-pending-error (list "Cannot modify a region containing pending content")))(1 81)
  primitive-undo(1 ((1 . 81) (t . 0)))
  undo-more(1)
  undo(nil)
  funcall-interactively(undo nil)
  command-execute(undo)

>> 3. I tried M-x undo _after_ reglock was unlocked, and I got "TO REPLACE"
>>    word highlighted. I did not expect it to be highlighted.
>
> I couldn't get that behavior, but the undo wasn't correct either.
>
> org-pending is now directly instrumenting the buffer-undo-list, and
> manually adding an undo-boundary.
>
> Do you still see your problem ?

No, this problem is solved now.

>> 4. If I try to cancel the reglock, it does get canceled, but *Region
>>    Lock* buffer is not updated - Live? still displays "yes Cancel".
>
> It's by design.
>
> The function `org-pending-describe-reglock' works like
> `describe-variable' and other similar functions.  You need to revert
> the buffer (g) to update it.

I still find it confusing.
Mostly because it is not clear if pressing "cancel" does anything.

> The reglock is live in its buffer.

What do you mean by that??
How can reglock be active in the buffer that does not contain the locked
text? How can even have different state in different buffers?

>> Does it mean that clicking "cancel" does not guarantee that the region
>> will not be updated by the running process/timer?
>
> Yes, org-pending does not enforce that; and it should not, else it
> would forbid valid use cases of org-pending. A given user of
> org-pending may decide to garantuee that though (using a suitable
> function for :on-outcome).

Imagine that the process that locked the region hangs. As a user, I'd
like to be able to edit text in buffer if I see that the lock is taking
too long. How can I do it without closing the buffer?

>> In my eyes, there is no difference between user request and "kill". If
>> users asks things to stop, no modifications should be allowed to
>> the region.
>
> There is no relation between "kill" and "cancel".
>
> For "kill", *Emacs* is killing the owner of the lock; there is nothing
> to update.  This is synchronous, immediate and definitive.
>
> For "cancel", the *user* is sending an asynchronous message to
> org-pending that it would be nice to release this particular lock
> sooner, if possible; that message implies that the user doesn't care
> about the outcome, but, if that outcome is available, then, just don't
> waste it: insert it in the document.
>
> Should I rename "kill" and "cancel" to something better ?

See my example above. For me, users should have access to "kill" - to
unlock the pending region and make sure that nothing unexpected happens
henceforth with that text. The unrelying Elisp that is creating the lock
should indeed be able to intercept such user request and process it, but
not refuse it, keeping the region locked.

> I simplified the pcase.  I switched back to the "my-" prefix.  I'm not
> sure why you're using quoted lambdas, as if we were in 2011 ;) I guess
> it's so that this example works when copy/pasted to scratch for
> evaluation in a non lexical-binding buffer.

Yes.

> I've left the 'warn' messages, but, I'm not sure we should. In my
> case, they are just killing my window configuration, even stealing the
> window where the lock itself was.

You can use (message ...) instead. It is also fine.

>> In the above, it is not fully clear for me what BEG and END arguments in
>> `org-pending-reglock-insert-details-function' mean and where the
>> insertion happens.
>
> I've removed '_start' and '_end' from the example: they are advanced
> features (see the documentation of the field insert-details-function).

Please link to that documentation somewhere in top comment, linking to
the defstruct. Maybe something like:

   Elisp programs can further alter various fields of REGLOCK object to
   alter its behavior. See the docstrings in `org-pending-reglock'.

-- 
Ihor Radchenko // yantar92,
Org mode contributor,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>