From: Drew Adams <drew.adams@oracle.com>
To: Marcin Borkowski <mbork@mbork.pl>,
Joost Kremers <joostkremers@fastmail.fm>
Cc: Eric Abrahamsen <eric@ericabrahamsen.net>, help-gnu-emacs@gnu.org
Subject: RE: Persistence of variables
Date: Sun, 25 Mar 2018 11:57:38 -0700 (PDT) [thread overview]
Message-ID: <a7361e3f-6632-4845-a66b-706bbab8d2c0@default> (raw)
In-Reply-To: <87efk813h9.fsf@mbork.pl>
> >>> If you only want to save one variable, just use an option.
> >> Of course!
> >> What Drew said. The whole thing was in front of us all, we
> >> just had to squint the right way.
> >
> > Well, that depends on the variable. Options (i.e., those defined with
> > defcustom) are really meant for user customisation: meant to be set
> > explicitly by the user, and meant to be forgotten once set.
Yes - although it is not necessarily meant to be forgotten
once set. It is sometimes useful for a user to change an
option during the same session, sometimes even multiple times.
And it can be useful for a user to have a command that changes
some option. The rule that code should not trample on user
options does not apply to a command that a user invokes
explicitly, voluntarily, to make such a change.
> > If you want to save a variable that changes regularly and
> > that the user doesn't set explicitly, then a user option is
> > a bad fit.
Yes (although "changes regularly" is not relevant here, IMO).
In that case, the persistence is not to provide a user with
a persistent cache as much as it is to provide the code with
a persistent cache.
But is it really the case that the persistence is intended
across Emacs sessions for all users? If not, it is, in
effect, something personal for the user, regardless of how
"regular" the updating might be, and regardless of which
file the value is persisted in.
> > IMHO the best
> > way to deal with that is indeed to use a separate file and to provide
> > a user option to set the file path & name. That way, users can decide
> > for themselves if they want to keep the file under version control,
> > sync it across machines, or not.
If the user specifies the file then this is, in effect,
user-specific. Whether you make the variable itself a user
option, or you put its value in a file whose name is a user
option, does not change the fact that the variable value is
essentially user-specific. All you're talking about in that
case is which file to save the value in: (1) `custom-file'
or init file versus (2) some other file.
> And this is exactly my use-case: a variable whose value will be
> periodically changed.
When and how often a variable gets changed doesn't enter
into it. What's important wrt user options is whether the
variable is user-specific.
> And I don't like the hassle of having an option
> to a separate file with just this one variable... Of course, if the
> only user beside me won't like Emacs messing around with his init.el,
> I'll do it that way.
If you don't want to save the value in your init file or your
`custom-file', and you don't want to save it in some other
file whose name you have to specify as an option value, then
consider using your bookmark file (which you presumably have
already). If you want to do that, just create a variable-list
bookmark (using Bookmark+) - it persists and restores any
number of variables, including just one.
"Jumping" to the bookmark restores the saved variable value.
Use command `bmkp-set-variable-list-bookmark' to create and
update the value. When you save your bookmark list (or when
it is saved automatically), the variable is persisted.
next prev parent reply other threads:[~2018-03-25 18:57 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-03-21 6:08 Persistence of variables Marcin Borkowski
2018-03-21 6:55 ` Eli Zaretskii
2018-03-21 7:25 ` Marcin Borkowski
2018-03-21 9:13 ` Marcin Borkowski
2018-03-21 9:27 ` tomas
2018-03-21 9:51 ` Marcin Borkowski
2018-03-21 10:23 ` tomas
2018-03-25 17:10 ` Marcin Borkowski
2018-03-21 11:34 ` Emanuel Berg
[not found] ` <mailman.11020.1521632103.27995.help-gnu-emacs@gnu.org>
2018-03-21 11:38 ` Emanuel Berg
2018-03-21 9:53 ` Eric Abrahamsen
2018-03-21 10:26 ` Marcin Borkowski
2018-03-21 15:12 ` Drew Adams
2018-03-21 15:19 ` tomas
2018-03-21 22:16 ` Joost Kremers
2018-03-25 17:15 ` Marcin Borkowski
2018-03-25 18:57 ` Drew Adams [this message]
[not found] ` <mailman.11217.1521998149.27995.help-gnu-emacs@gnu.org>
2018-03-28 0:21 ` Emanuel Berg
2018-03-28 5:05 ` Marcin Borkowski
[not found] ` <mailman.11329.1522213571.27995.help-gnu-emacs@gnu.org>
2018-03-28 13:09 ` Emanuel Berg
[not found] ` <mailman.11032.1521645579.27995.help-gnu-emacs@gnu.org>
2018-03-21 21:43 ` Emanuel Berg
2018-03-24 23:54 ` Robert L.
2018-03-25 17:12 ` Marcin Borkowski
2018-03-26 1:48 ` Eric Abrahamsen
2018-03-28 19:12 ` Marcin Borkowski
[not found] ` <mailman.11031.1521645187.27995.help-gnu-emacs@gnu.org>
2018-03-21 18:00 ` Emanuel Berg
2018-03-21 18:23 ` Eli Zaretskii
[not found] ` <mailman.11045.1521656612.27995.help-gnu-emacs@gnu.org>
2018-03-21 21:30 ` Emanuel Berg
2018-03-22 1:36 ` Rolf Ade
2018-03-22 7:02 ` Eli Zaretskii
[not found] ` <mailman.11076.1521702135.27995.help-gnu-emacs@gnu.org>
2018-03-24 3:06 ` Emanuel Berg
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
List information: https://www.gnu.org/software/emacs/
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=a7361e3f-6632-4845-a66b-706bbab8d2c0@default \
--to=drew.adams@oracle.com \
--cc=eric@ericabrahamsen.net \
--cc=help-gnu-emacs@gnu.org \
--cc=joostkremers@fastmail.fm \
--cc=mbork@mbork.pl \
/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.
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).