On Sat, Feb 02, 2013 at 06:17:10PM +1100, Cameron Simpson wrote:
> | Or, to say it another way (from the manual):
> | 
> |    <save-message> s save message/attachment to a mailbox/file
> | 
> | ln != save-message.  
> 
> ln doesn't change the UI behaviour.

It does, in the sense that IN ONLY SOME CASES, the UI would cause a
different effect than it otherwise would.  But regardless, I think
you're missing the main point (which I'm getting to)...  

> Just because mbox _forces_ a wasteful copy doesn't imply maildir should
> behave the same way. 

I think it does, but regardless, I think the current behavior (sans
auto-deletion) is the ONLY behavior that is sensible.  For the TLDR
crowd, I'll respond to the rest of your message first, which mostly
gets the point across, and then provide the lengthy explanation
below...

And it isn't wasteful, if that's what the user actually wanted.  

> Speaking for myself, if messages have the same message-id I expect
> them to be essentially equivalent. I don't require them to be
> distinct files/copies.

Then you apparently do not need the save-message feature...
 
> As remarked elsewhere, mutt's capable of a server-side IMAP move
> message. Nothing says whether that's a copy or a hard link behind the
> scenes.

That is not "save-message"... that is "move-message", which I think
should also exist.  In fact, to make the UI most consistent and
logical, this is what you should have:

  save-message - copy messages to a file
  copy-message - copy messages to a folder, leave the current intact
  move-message - copy messages to a folder, IMMEDIATELY remove from
                 current folder, and DO NOT ASK ME TO CONFIRM DELETION

[There's a problem with the move-message behavior I described, which
since this is already long, I won't go into other than to say it's the
mbox folder sync problem... This also may explain why it does not
currently exist as a separate operation.  But it IS solvable... no
other client has this problem AFAIK.]


Now, coming back to this:

> ln doesn't change the UI behaviour.  Just because mbox _forces_ a
> wasteful copy doesn't imply maildir should behave the same way. 

First, let me say that I believe the reason you have what you have
today is precisely because the mail store was never completely treated
as an abstraction, and is not treated consistently regardless of the
format, as it should be.  Instead, the user interface and related
behaviors have always implicitly acknowledged the properties of the
mail store as a file or set of files, depending on what you use.  This
historically has been most evident with new mail handling, though
there have been some improvements more recently in that regard (still
a ways to go on that though, but getting it right probably requires
making mutt threaded or doing something even more crazy).  Your link()
case only makes this worse, if implemented.

Saving a message to a file is, in practice, the identical operation to
copying the file into an mbox folder, and *almost* the identical
operation to saving it to a maildir folder (there's a small bit of
extra logic to deal with the directory structure).  However
conceptually they are distinct, and the UI should acknowledge that
difference, and mutt should behave accordingly.  It does not.

The purpose of save-message is to extract a message out of the mail
store abstraction (whatever it may be) and save it *somewhere*... that
somewhere may be another mailbox, OR IT MAY BE A FILE.  If it's a
folder, it may be an mbox folder, or it may be... something else.  
Out of all the possibilities, the only case where using link() makes
any sense at all is if both the source folder and the target are
maildir folders.  But even in that case, if you use ln, you do not
achieve the purpose of the save-message function.  You still have one
copy of the message, which just happens to appear to be in two places
on the filesystem.  Mutt absolutely should NOT assume this is what you
want, as this does not satisfy the concept of "save-message". 

Now, I will grant you, this feature is a bit schizophrenic.  It also
assumes that once it has done whatever it's going to do, that you no
longer want the existing copy of the message, and marks it for
deletion.  At which point I have to go and undelete it, which I've
always found annoying.  Because when I use this feature, I do in fact
want a separate copy of the message.  Pretty much always.  I suspect
that it behaves this way because ME (I'm assuming) decided that the
two operations, moving a message to another folder, and saving a
message to a file, were functionally equivalent, and therefore elected
for the economy of only implementing one.  Trouble is, in neither case
does it really do what the user wants it to do, IMO.  What the user
really wants, I believe, are the three behaviors I described above.

-- 
Derek D. Martin    http://www.pizzashack.org/   GPG Key ID: 0xDFBEAD02
-=-=-=-=-
This message is posted from an invalid address.  Replying to it will result in
undeliverable mail due to spam prevention.  Sorry for the inconvenience.

Attachment: pgpRUMPr3FWkZ.pgp
Description: PGP signature

Reply via email to