~niklaseklund/detached.el

This thread contains a patchset. You're looking at the original emails, but you may wish to use the patch review UI. Review patch
3 3

[PATCH detached.el 0/1] Detached Shell Command buffer reuse

Details
Message ID
<166655715395.26669.13315656559238290410-0@git.sr.ht>
DKIM signature
missing
Download raw message
Copyright assignment done

Daniel Pettersson (1):
  Reuse detached shell buffers with <NUMBER> suffix

 detached.el | 22 +++++++++++++++++++---
 1 file changed, 19 insertions(+), 3 deletions(-)

-- 
2.34.5

[PATCH detached.el 1/1] Reuse detached shell buffers with <NUMBER> suffix

Details
Message ID
<166655715395.26669.13315656559238290410-1@git.sr.ht>
In-Reply-To
<166655715395.26669.13315656559238290410-0@git.sr.ht> (view parent)
DKIM signature
missing
Download raw message
Patch: +19 -3
From: Daniel Pettersson <daniel@dpettersson.net>

Currently only the first shell command buffer "*Detached Shell
Command*" is reused if `get-buffer-process` fails to get process.

Buffers named "*Detached Shell Command*<NUMBER>" are handled
differently and if "*Detached Shell Command*" is attached to a long
running process. New *Detached Shell Command*<NUMBER> will fill up the
buffer list.

This is fixed by doing the same check process check for
*Detached Shell Command*<NUMBER> buffers as well before creating a new
buffer.
---
Hey again Niklas!

I sent a PR/Feature request when the repo was hosted at gitlab,
regarding having last shell-command as initial input for completing-
read.

Pushing changes that I had locally. I have a FSF copyright assignment
for emacs pending, but while that is pending I thought I would send this
patch before I forget.

Can ping you when the assignment is completed.

Also having some issues with "tail" on OSX as --lines is not supported,
the replacement would be "tail -10" for 10 lines.

Can create a patch for when I have some time left over.

PS: I could not find a mail address in the README so I am hoping this
the correct one.

- daniel pettersson

detached.el | 22 +++++++++++++++++++---
1 file changed, 19 insertions(+), 3 deletions(-)

diff --git a/detached.el b/detached.el
index 0c5c4be..b878ea6 100644
--- a/detached.el
+++ b/detached.el
@@ -694,10 +694,10 @@ Optionally SUPPRESS-OUTPUT."
                  (or detached--current-session
                      (detached-create-session command)))
                 ((symbol-function #'set-process-sentinel) #'ignore)
                 (buffer (get-buffer-create detached--shell-command-buffer))
                 (buffer (detached--generate-buffer detached--shell-command-buffer
                                                    (lambda (buffer)
                                                      (not (get-buffer-process buffer)))))
                 (command (detached--shell-command detached--current-session t)))
        (when (get-buffer-process buffer)
          (setq buffer (generate-new-buffer (buffer-name buffer))))
        (setq detached-enabled nil)
        (funcall #'async-shell-command command buffer)
        (with-current-buffer buffer
@@ -1651,6 +1651,22 @@ If event is cased by an update to the `detached' database, re-initialize
                                    (seq-max)
                                    (min width)))))

(defun detached--generate-buffer (name reuse-p &optional number)
  "Reuse or generate new buffer like built-in function `generate-new-buffer'.
NAME is used the same way as `generate-new-buffer' but if a buffer which
REUSE-P for buffer returns nil, return buffer instead.

NUMBER is used internaly for recursive calls, but can be used to start searching
at NUMBER offset."
  (let* ((buffer-name (if number
                          (format "%s<%d>" name number)
                        name))
         (buffer (get-buffer buffer-name))
         (number (or number 1)))
    (if (and buffer (not (funcall reuse-p buffer)))
        (detached--generate-buffer name reuse-p (1+ number))
      (get-buffer-create buffer-name))))

(defun detached--metadata-git-branch ()
  "Return current git branch."
  (let ((args '("symbolic-ref" "HEAD" "--short")))
-- 
2.34.5

[detached.el/patches/.build.yml] build failed

builds.sr.ht <builds@sr.ht>
Details
Message ID
<CNTL8BTYUT7N.29T7Y1DGT3439@cirno>
In-Reply-To
<166655715395.26669.13315656559238290410-1@git.sr.ht> (view parent)
DKIM signature
missing
Download raw message
detached.el/patches/.build.yml: FAILED in 1m9s

[Detached Shell Command buffer reuse][0] from [~dpettersson][1]

[0]: https://lists.sr.ht/~niklaseklund/detached.el/patches/36333
[1]: daniel@dpettersson.net

✗ #867899 FAILED detached.el/patches/.build.yml https://builds.sr.ht/~niklaseklund/job/867899

Re: [PATCH detached.el 1/1] Reuse detached shell buffers with <NUMBER> suffix

Details
Message ID
<eruuehsfjd5kra.fsf@posteo.net>
In-Reply-To
<166655715395.26669.13315656559238290410-1@git.sr.ht> (view parent)
DKIM signature
missing
Download raw message
~dpettersson <dpettersson@git.sr.ht> writes:

thanks for the patch Daniel, it is a nice improvement to the way the
buffers are generated! I fixed a small spelling mistake in the
documentation before adding the patch. Otherwise I have pushed it
upstream now.

I was going to add your name in the list of code contributors, but I
realized I didn't if you have a website, gitlab/sourcehut or similar
that you would like me to link to your name in the list? This is what I
have added for the other contributors

https://git.sr.ht/~niklaseklund/detached.el/tree/master/README.md#L331

/Niklas

> From: Daniel Pettersson <daniel@dpettersson.net>
>
> Currently only the first shell command buffer "*Detached Shell
> Command*" is reused if `get-buffer-process` fails to get process.
>
> Buffers named "*Detached Shell Command*<NUMBER>" are handled
> differently and if "*Detached Shell Command*" is attached to a long
> running process. New *Detached Shell Command*<NUMBER> will fill up the
> buffer list.
>
> This is fixed by doing the same check process check for
> *Detached Shell Command*<NUMBER> buffers as well before creating a new
> buffer.
> ---
> Hey again Niklas!
>
> I sent a PR/Feature request when the repo was hosted at gitlab,
> regarding having last shell-command as initial input for completing-
> read.
>
> Pushing changes that I had locally. I have a FSF copyright assignment
> for emacs pending, but while that is pending I thought I would send this
> patch before I forget.
>
> Can ping you when the assignment is completed.
>
> Also having some issues with "tail" on OSX as --lines is not supported,
> the replacement would be "tail -10" for 10 lines.
>
> Can create a patch for when I have some time left over.
>
> PS: I could not find a mail address in the README so I am hoping this
> the correct one.
>
> -- daniel pettersson
>
>  detached.el | 22 +++++++++++++++++++---
>  1 file changed, 19 insertions(+), 3 deletions(-)
>
> diff --git a/detached.el b/detached.el
> index 0c5c4be..b878ea6 100644
> --- a/detached.el
> +++ b/detached.el
> @@ -694,10 +694,10 @@ Optionally SUPPRESS-OUTPUT."
>                    (or detached--current-session
>                        (detached-create-session command)))
>                   ((symbol-function #'set-process-sentinel) #'ignore)
> -                 (buffer (get-buffer-create detached--shell-command-buffer))
> +                 (buffer (detached--generate-buffer detached--shell-command-buffer
> +                                                    (lambda (buffer)
> +                                                      (not (get-buffer-process buffer)))))
>                   (command (detached--shell-command detached--current-session t)))
> -        (when (get-buffer-process buffer)
> -          (setq buffer (generate-new-buffer (buffer-name buffer))))
>          (setq detached-enabled nil)
>          (funcall #'async-shell-command command buffer)
>          (with-current-buffer buffer
> @@ -1651,6 +1651,22 @@ If event is cased by an update to the `detached' database, re-initialize
>                                      (seq-max)
>                                      (min width)))))
>  
> +(defun detached--generate-buffer (name reuse-p &optional number)
> +  "Reuse or generate new buffer like built-in function `generate-new-buffer'.
> +NAME is used the same way as `generate-new-buffer' but if a buffer which
> +REUSE-P for buffer returns nil, return buffer instead.
> +
> +NUMBER is used internaly for recursive calls, but can be used to start searching
> +at NUMBER offset."
> +  (let* ((buffer-name (if number
> +                          (format "%s<%d>" name number)
> +                        name))
> +         (buffer (get-buffer buffer-name))
> +         (number (or number 1)))
> +    (if (and buffer (not (funcall reuse-p buffer)))
> +        (detached--generate-buffer name reuse-p (1+ number))
> +      (get-buffer-create buffer-name))))
> +
>  (defun detached--metadata-git-branch ()
>    "Return current git branch."
>    (let ((args '("symbolic-ref" "HEAD" "--short")))
> -- 
> 2.34.5
Reply to thread Export thread (mbox)