all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
From: Stefan Kangas <stefankangas@gmail.com>
To: Eli Zaretskii <eliz@gnu.org>, Michael Albinus <michael.albinus@gmx.de>
Cc: 75306@debbugs.gnu.org
Subject: bug#75306: 31.0.50; Make `small-temporary-file-directory` variable obsolete
Date: Fri, 3 Jan 2025 03:15:49 -0600	[thread overview]
Message-ID: <CADwFkmkVQoTvj4i=3F=WuYvDsY6cCHw5WUWaa5V7fYg=MNBPGA@mail.gmail.com> (raw)
In-Reply-To: <86y0zsgukt.fsf@gnu.org>

Eli Zaretskii <eliz@gnu.org> writes:

>> Cc: 75306@debbugs.gnu.org
>> Date: Fri, 03 Jan 2025 06:56:03 +0100
>> From:  Michael Albinus via "Bug reports for GNU Emacs,
>>  the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
>>
>> Stefan Kangas <stefankangas@gmail.com> writes:
>>
>> Hi Stefan,
>>
>> > I think the variable doesn't make much sense these days, and should be
>> > made obsolete.  Note that it is barely used in Emacs and third-party
>> > packages.
>> >
>> > However, Tramp recently started using the variable as a place to create
>> > OpenSSH Unix domain sockets.  May I suggest that Tramp uses some other
>> > variable for this purpose, perhaps a Tramp specific one?
>>
>> Is there a reason that it must be changed? What are the advantages? Does
>> it hurt to keep the user option?
>
> Exactly my questions.
>
> The doc string says:
>
>   If non-nil, this directory is used instead of ‘temporary-file-directory’
>   by programs that create small temporary files.  This is for systems that
>   have fast storage with limited space, such as a RAM disk.
>
> This says nothing about MS-DOS,

The docstring is one thing, but the variable _definition_ reads the same
today as when it was first introduced (in ffc0e1caf1a6):

(defvar small-temporary-file-directory
  (if (eq system-type 'ms-dos) (getenv "TMPDIR"))

This makes it clear that the intention was, at least in part, to support
MS-DOS specifically, and it has remained that over the years.

> and makes perfect sense to me.  It gives our users a capability to
> direct small enough temporary files to a fast temporary filesystem ...
> From my POV, this feature needs zero maintenance.

This feature would need maintenance just like any other, but it hasn't
seen too much of that.  If people had taken it seriously, we would have
seen it used it in many more places.

I doubt that this micro-optimization (or whatever we should call it) is
likely to give much bang for your buck, especially not in an age when
users are starting to routinely throw 500 MiB or even 1 GiB at their
tmpfs RAM disks.  Not everyone, of course, but this has been the general
direction; even low end systems have at minimum an order of magnitude
more resources now than when this variable was introduced 24 years ago.

> But if some user has a good reason to customize this, why take that
> flexibility from them?  How do we justify removal of a feature which
> could be useful to someone?

Besides the Tramp use case (which is valid and deserves its own
variable), it is used only in some very old modules: vc-rcs.el and
cmacexp.el, in shell-command-on-region, and literally nowhere else.
I suspect that it's removal wouldn't be noticed by anyone, even if we
were to assume that someone somewhere is getting slightly better
performance out of RCS/C macro expansions/Shell commands from using this.

I do agree that there's no compelling reason why we must remove _this
particular piece of cruft_ specifically, but I also don't see any good
reason to keep it.





  reply	other threads:[~2025-01-03  9:15 UTC|newest]

Thread overview: 14+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2025-01-03  3:23 bug#75306: 31.0.50; Make `small-temporary-file-directory` variable obsolete Stefan Kangas
2025-01-03  5:56 ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-03  8:26   ` Stefan Kangas
2025-01-03  8:49     ` Eli Zaretskii
2025-01-03  8:39   ` Eli Zaretskii
2025-01-03  9:15     ` Stefan Kangas [this message]
2025-01-03 11:46       ` Eli Zaretskii
2025-01-04  9:54   ` Björn Bidar via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-04  9:54   ` Björn Bidar via Bug reports for GNU Emacs, the Swiss army knife of text editors
     [not found]   ` <87ttaezyyp.fsf@>
2025-01-04 11:26     ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-04 22:16       ` Björn Bidar via Bug reports for GNU Emacs, the Swiss army knife of text editors
2025-01-04 22:16       ` Björn Bidar via Bug reports for GNU Emacs, the Swiss army knife of text editors
     [not found]       ` <6779b38c.050a0220.be2ea.a6e0SMTPIN_ADDED_BROKEN@mx.google.com>
2025-01-05  5:30         ` Stefan Kangas
     [not found]       ` <8734hyw7g4.fsf@>
2025-01-05  8:18         ` Michael Albinus via Bug reports for GNU Emacs, the Swiss army knife of text editors

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to='CADwFkmkVQoTvj4i=3F=WuYvDsY6cCHw5WUWaa5V7fYg=MNBPGA@mail.gmail.com' \
    --to=stefankangas@gmail.com \
    --cc=75306@debbugs.gnu.org \
    --cc=eliz@gnu.org \
    --cc=michael.albinus@gmx.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this external index

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

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.