unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* calling desktop-read interactively
@ 2019-09-26  2:52 Juanma Barranquero
  2019-09-26  7:30 ` Eli Zaretskii
  2019-09-26 12:36 ` Stefan Monnier
  0 siblings, 2 replies; 13+ messages in thread
From: Juanma Barranquero @ 2019-09-26  2:52 UTC (permalink / raw)
  To: Emacs developers


[-- Attachment #1.1: Type: text/plain, Size: 138 bytes --]

I've implemented an old FIXME in desktop.el

;; FIXME Interactively, this should have the option to prompt for dirname.

Ok to push this?

[-- Attachment #1.2: Type: text/html, Size: 230 bytes --]

[-- Attachment #2: desktop.patch --]
[-- Type: application/octet-stream, Size: 1889 bytes --]

diff --git i/etc/NEWS w/etc/NEWS
index 9a0b6333e4..79e9655350 100644
--- i/etc/NEWS
+++ w/etc/NEWS
@@ -543,4 +543,9 @@ network connection information (in addition to the host name).
 ** The 'cl' package is now officially deprecated in favor of 'cl-lib'.
 
+---
+** desktop
+*** When called interactively with a prefix arg 'C-u', 'desktop-read'
+now prompts the user for the directory containing the desktop file.
+
 +++
 ** winner
diff --git i/lisp/desktop.el w/lisp/desktop.el
index 59610a128a..498f769bd3 100644
--- i/lisp/desktop.el
+++ w/lisp/desktop.el
@@ -1192,7 +1192,6 @@ desktop-buffer-ok-count
 (defvar desktop-buffer-fail-count)
 
-;; FIXME Interactively, this should have the option to prompt for dirname.
 ;;;###autoload
-(defun desktop-read (&optional dirname)
+(defun desktop-read (&optional dirname ask)
   "Read and process the desktop file in directory DIRNAME.
 Look for a desktop file in DIRNAME, or if DIRNAME is omitted, look in
@@ -1200,7 +1199,9 @@ desktop-read
 is processed and `desktop-after-read-hook' is run.  If no desktop file
 is found, clear the desktop and run `desktop-no-desktop-file-hook'.
+Interactively, with prefix arg \\[universal-argument], ask for DIRNAME.
 This function is a no-op when Emacs is running in batch mode.
-It returns t if a desktop file was loaded, nil otherwise."
-  (interactive)
+It returns t if a desktop file was loaded, nil otherwise.
+\n(fn DIRNAME)"
+  (interactive "i\nP")
   (unless noninteractive
     (setq desktop-dirname
@@ -1210,4 +1211,6 @@ desktop-read
              ;; If DIRNAME is specified, use it.
              (and (< 0 (length dirname)) dirname)
+             ;; Else, with a prefix arg, ask for a directory name.
+             (and ask (read-directory-name "Directory for desktop file: " nil nil t))
              ;; Otherwise search desktop file in desktop-path.
              (let ((dirs desktop-path))

^ permalink raw reply related	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26  2:52 calling desktop-read interactively Juanma Barranquero
@ 2019-09-26  7:30 ` Eli Zaretskii
  2019-09-26 12:36 ` Stefan Monnier
  1 sibling, 0 replies; 13+ messages in thread
From: Eli Zaretskii @ 2019-09-26  7:30 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: emacs-devel

> From: Juanma Barranquero <lekktu@gmail.com>
> Date: Thu, 26 Sep 2019 04:52:46 +0200
> 
> I've implemented an old FIXME in desktop.el
> 
> ;; FIXME Interactively, this should have the option to prompt for dirname.
> 
> Ok to push this?

Yes, and thanks.



^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26  2:52 calling desktop-read interactively Juanma Barranquero
  2019-09-26  7:30 ` Eli Zaretskii
@ 2019-09-26 12:36 ` Stefan Monnier
  2019-09-26 12:53   ` Juanma Barranquero
  1 sibling, 1 reply; 13+ messages in thread
From: Stefan Monnier @ 2019-09-26 12:36 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Emacs developers

> +*** When called interactively with a prefix arg 'C-u', 'desktop-read'
> +now prompts the user for the directory containing the desktop file.

Thanks Juanma,

The next step is to allow the user to give the actual desktop *file*
name ;-)


        Stefan




^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 12:36 ` Stefan Monnier
@ 2019-09-26 12:53   ` Juanma Barranquero
  2019-09-26 15:32     ` Stefan Monnier
  0 siblings, 1 reply; 13+ messages in thread
From: Juanma Barranquero @ 2019-09-26 12:53 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: Emacs developers

[-- Attachment #1: Type: text/plain, Size: 743 bytes --]

On Thu, Sep 26, 2019 at 2:36 PM Stefan Monnier <monnier@iro.umontreal.ca>
wrote:

> The next step is to allow the user to give the actual desktop *file*
> name ;-)

There's no use case for that. Or, let me put it differently. I think
there's no use case, with the current code, to read from a different
desktop file.

The use case for reading it from different directories is built-in in the
current desktop.el (DIRNAME is passed as an argument back and forth), but
the desktop file name is a defcustom'd variable.

So, if we were to support multiple filenames, it surely wouldn't just be
changing desktop-read to ask for the file name, but fully support multiple
desktop files everywhere. That's a feature nobody's asked for before, I
think.

[-- Attachment #2: Type: text/html, Size: 924 bytes --]

^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 12:53   ` Juanma Barranquero
@ 2019-09-26 15:32     ` Stefan Monnier
  2019-09-26 16:06       ` Juanma Barranquero
                         ` (2 more replies)
  0 siblings, 3 replies; 13+ messages in thread
From: Stefan Monnier @ 2019-09-26 15:32 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: Emacs developers

> So, if we were to support multiple filenames, it surely wouldn't just be
> changing desktop-read to ask for the file name, but fully support multiple
> desktop files everywhere.

Indeed.

> That's a feature nobody's asked for before, I think.

It just seems so weird to only be able to specify the file indirectly via
the dir in which it lives.  It works OK if you have different "desktops"
for different projects placed in different subdirectories, but if you
have different "desktops" for different kinds of sessions (e.g. one for
email, one for programming, ...) then having to place the desktops in
different subdirectories feels awkward (especially since there isn't
necessarily many more files to put in those directories).

Being *able* to specify a directory is great.  Being limited to that is odd.


        Stefan




^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 15:32     ` Stefan Monnier
@ 2019-09-26 16:06       ` Juanma Barranquero
  2019-09-26 16:31         ` Eli Zaretskii
  2019-09-26 16:20       ` Drew Adams
  2019-09-26 16:28       ` Eli Zaretskii
  2 siblings, 1 reply; 13+ messages in thread
From: Juanma Barranquero @ 2019-09-26 16:06 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: Emacs developers

[-- Attachment #1: Type: text/plain, Size: 826 bytes --]

On Thu, Sep 26, 2019 at 5:32 PM Stefan Monnier <monnier@iro.umontreal.ca>
wrote:

> but if you
> have different "desktops" for different kinds of sessions (e.g. one for
> email, one for programming, ...) then having to place the desktops in
> different subdirectories feels awkward (especially since there isn't
> necessarily many more files to put in those directories).

My use of desktop.el is very simple, so I've never had that problem. I
don't even use desktop files in project directories, just one in ~/.emacs.d/

But for the sessions case you point out, I would definitely create
subdirectories under ~/.emacs.d/desktop-sessions/ or somesuch. Not
particularly awkward, IMO.

> Being *able* to specify a directory is great.  Being limited to that is
odd.

Yes, I agree. It's something to work on, if there's interest.

[-- Attachment #2: Type: text/html, Size: 1086 bytes --]

^ permalink raw reply	[flat|nested] 13+ messages in thread

* RE: calling desktop-read interactively
  2019-09-26 15:32     ` Stefan Monnier
  2019-09-26 16:06       ` Juanma Barranquero
@ 2019-09-26 16:20       ` Drew Adams
  2019-09-26 16:28       ` Eli Zaretskii
  2 siblings, 0 replies; 13+ messages in thread
From: Drew Adams @ 2019-09-26 16:20 UTC (permalink / raw)
  To: Stefan Monnier, Juanma Barranquero; +Cc: Emacs developers

> > So, if we were to support multiple filenames, it surely wouldn't just be
> > changing desktop-read to ask for the file name, but fully support multiple
> > desktop files everywhere.
> 
> Indeed.
> 
> > That's a feature nobody's asked for before, I think.

See below.

> It just seems so weird to only be able to specify the file indirectly via
> the dir in which it lives.

Seems weird indeed.  I've never understood the why of
that design.

> It works OK if you have different "desktops"
> for different projects placed in different subdirectories, but if you
> have different "desktops" for different kinds of sessions (e.g. one for
> email, one for programming, ...) then having to place the desktops in
> different subdirectories feels awkward (especially since there isn't
> necessarily many more files to put in those directories).
> 
> Being *able* to specify a directory is great.  Being limited to that is odd.

Sincere apologies for jumping in here, especially without
reading all of the thread.

FWIW, I have, I'm pretty sure, asked for exactly that feature.
Or at least I've mentioned that it is, IMO, a failing that the
design of desktop.el is _only_ directory-oriented, assuming
that you want/need at most one desktop file per directory.
(Why was such an assumption made?  I've never understood it.)

Long ago I implemented this feature - ability to read a
desktop file anywhere, i.e., by file name, in the Bookmark+
code.  There, users can have any number of desktop files, in
any directories.  They can create bookmarks for them, and so
restore desktops by jumping to bookmarks.

Function `bmkp-desktop-read' reads a desktop file.  Maybe it
will help, e.g. by saving a little time, to take a look at
that code.  It's in file bookmark+-1.el, here:

https://www.emacswiki.org/emacs/download/bookmark%2b-1.el

Anyway, here is that code:

;; Derived from code in `desktop-read'.
(defun bmkp-desktop-read (file)
  "Load desktop-file FILE, then run `desktop-after-read-hook'.
Return t if FILE was loaded, nil otherwise."
  (interactive)
  (unless (file-name-absolute-p file) ; Should never happen.
    (setq file  (expand-file-name file bmkp-desktop-default-directory)))
  (when (file-directory-p file) (error "`%s' is a directory, not a file" file))
  (setq desktop-dirname  (file-name-directory file))
  (if (not (file-readable-p file))
      nil                               ; Return nil, meaning not loaded.
    (let ((desktop-restore-eager      t) ; Don't bother with lazy restore.
          (desktop-first-buffer       nil)
          (desktop-buffer-ok-count    0)
          (desktop-buffer-fail-count  0)
          (desktop-save               nil)) ; Prevent desktop saving during eval of desktop buffer.
      (when (fboundp 'desktop-lazy-abort) (desktop-lazy-abort)) ; Emacs 22+.
      (load file t t t)
      (when (boundp 'desktop-file-modtime) ; Emacs 22+
        (setq desktop-file-modtime  (nth 5 (file-attributes file))))
      ;; `desktop-create-buffer' puts buffers at end of the buffer list.
      ;; We want buffers existing prior to evaluating the desktop (and not reused) to be placed
      ;; at the end of the buffer list, so we move them here.
      (mapc 'bury-buffer (nreverse (cdr (memq desktop-first-buffer (nreverse (buffer-list))))))
      (bmkp--pop-to-buffer-same-window (car (buffer-list)))
      (run-hooks 'desktop-delay-hook)
      (setq desktop-delay-hook  ())
      (run-hooks 'desktop-after-read-hook)
      (when (boundp 'desktop-buffer-ok-count) ; Emacs 22+
        (message "Desktop: %d buffer%s restored%s%s." desktop-buffer-ok-count
                 (if (= 1 desktop-buffer-ok-count) "" "s")
                 (if (< 0 desktop-buffer-fail-count)
                     (format ", %d failed to restore" desktop-buffer-fail-count)
                   "")
                 (if (and (boundp 'desktop-buffer-args-list)  desktop-buffer-args-list)
                     (format ", %d to be restored lazily" (length desktop-buffer-args-list))
                   "")))
      t)))

If something that offers the same thing becomes available
in vanilla Emacs then, at least for the most recent
releases, the Bookmark+ code can just make use of the
vanilla function.  If not, that's OK too.  HTH.



^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 15:32     ` Stefan Monnier
  2019-09-26 16:06       ` Juanma Barranquero
  2019-09-26 16:20       ` Drew Adams
@ 2019-09-26 16:28       ` Eli Zaretskii
  2019-09-26 19:42         ` Stefan Monnier
  2 siblings, 1 reply; 13+ messages in thread
From: Eli Zaretskii @ 2019-09-26 16:28 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: lekktu, emacs-devel

> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Date: Thu, 26 Sep 2019 11:32:38 -0400
> Cc: Emacs developers <emacs-devel@gnu.org>
> 
> if you have different "desktops" for different kinds of sessions
> (e.g. one for email, one for programming, ...)

Why would you want that, when Emacs has frames, and each frame can be
set up for different kinds of jobs?

Or, if I turn the table, do you know of any other case or other
software that support reading init-kind of information from a file
whose name can change?



^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 16:06       ` Juanma Barranquero
@ 2019-09-26 16:31         ` Eli Zaretskii
  2019-09-26 16:52           ` Juanma Barranquero
  0 siblings, 1 reply; 13+ messages in thread
From: Eli Zaretskii @ 2019-09-26 16:31 UTC (permalink / raw)
  To: Juanma Barranquero; +Cc: monnier, emacs-devel

> From: Juanma Barranquero <lekktu@gmail.com>
> Date: Thu, 26 Sep 2019 18:06:52 +0200
> Cc: Emacs developers <emacs-devel@gnu.org>
> 
> I don't even use desktop files in project directories

I do.  A very useful feature.



^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 16:31         ` Eli Zaretskii
@ 2019-09-26 16:52           ` Juanma Barranquero
  0 siblings, 0 replies; 13+ messages in thread
From: Juanma Barranquero @ 2019-09-26 16:52 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: Stefan Monnier, Emacs developers

[-- Attachment #1: Type: text/plain, Size: 414 bytes --]

> I do.  A very useful feature.

I'm sure most desktop.el users do.

My point was that I'm particularly inadequate to think how to extend the
desktop feature, because my use of Emacs in general is atypically
simplistic: one frame (two on very specific occasions), no speedbar, no
toolbar, few windows. And I don't keep Emacs running for long or use it in
daemon mode. I usually start Emacs many, many times a day.

[-- Attachment #2: Type: text/html, Size: 517 bytes --]

^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 16:28       ` Eli Zaretskii
@ 2019-09-26 19:42         ` Stefan Monnier
  2019-09-27  4:59           ` Eli Zaretskii
  0 siblings, 1 reply; 13+ messages in thread
From: Stefan Monnier @ 2019-09-26 19:42 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: lekktu, emacs-devel

>> if you have different "desktops" for different kinds of sessions
>> (e.g. one for email, one for programming, ...)
> Why would you want that, when Emacs has frames, and each frame can be
> set up for different kinds of jobs?

I always have 2 Emacs sessions running, one for email and one
for programming.  Each session uses many frames.  I use separate
sessions for them because I don't want to have one operation block
the other (mostly: my email-session being blocked while
sending/receiving messages).


        Stefan




^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-26 19:42         ` Stefan Monnier
@ 2019-09-27  4:59           ` Eli Zaretskii
  2019-09-27 12:45             ` Stefan Monnier
  0 siblings, 1 reply; 13+ messages in thread
From: Eli Zaretskii @ 2019-09-27  4:59 UTC (permalink / raw)
  To: Stefan Monnier; +Cc: lekktu, emacs-devel

> From: Stefan Monnier <monnier@iro.umontreal.ca>
> Cc: lekktu@gmail.com,  emacs-devel@gnu.org
> Date: Thu, 26 Sep 2019 15:42:48 -0400
> 
> >> if you have different "desktops" for different kinds of sessions
> >> (e.g. one for email, one for programming, ...)
> > Why would you want that, when Emacs has frames, and each frame can be
> > set up for different kinds of jobs?
> 
> I always have 2 Emacs sessions running, one for email and one
> for programming.  Each session uses many frames.  I use separate
> sessions for them because I don't want to have one operation block
> the other (mostly: my email-session being blocked while
> sending/receiving messages).

Starting Emacs from different directories for each session should
satisfy this use case.  Although I don't think I understand why the
email session needs a desktop file anyway -- what important
information is saved in that desktop file?



^ permalink raw reply	[flat|nested] 13+ messages in thread

* Re: calling desktop-read interactively
  2019-09-27  4:59           ` Eli Zaretskii
@ 2019-09-27 12:45             ` Stefan Monnier
  0 siblings, 0 replies; 13+ messages in thread
From: Stefan Monnier @ 2019-09-27 12:45 UTC (permalink / raw)
  To: Eli Zaretskii; +Cc: lekktu, emacs-devel

> Starting Emacs from different directories for each session should
> satisfy this use case.

Indeed, as I said, you can always use "artificial" directories.
It just seems like an unnatural restriction.

> Although I don't think I understand why the email session needs
> a desktop file anyway -- what important information is saved in that
> desktop file?

The shape and position of the frames, as well as a few files I use to
handle the review of admissions requests (which are mostly processed
via email exchanges).


        Stefan




^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2019-09-27 12:45 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-09-26  2:52 calling desktop-read interactively Juanma Barranquero
2019-09-26  7:30 ` Eli Zaretskii
2019-09-26 12:36 ` Stefan Monnier
2019-09-26 12:53   ` Juanma Barranquero
2019-09-26 15:32     ` Stefan Monnier
2019-09-26 16:06       ` Juanma Barranquero
2019-09-26 16:31         ` Eli Zaretskii
2019-09-26 16:52           ` Juanma Barranquero
2019-09-26 16:20       ` Drew Adams
2019-09-26 16:28       ` Eli Zaretskii
2019-09-26 19:42         ` Stefan Monnier
2019-09-27  4:59           ` Eli Zaretskii
2019-09-27 12:45             ` Stefan Monnier

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).