From: Eli Zaretskii <eliz@gnu.org>
To: Eli Barzilay <eli@barzilay.org>
Cc: 21699@debbugs.gnu.org
Subject: bug#21699: 24.5; Bug in backup-buffer-copy and/or set-file-extended-attributes etc [set-file-extended-attributes]
Date: Mon, 19 Oct 2015 13:14:35 +0300 [thread overview]
Message-ID: <83fv17go6s.fsf@gnu.org> (raw)
In-Reply-To: <CALO-gusnqMwKVCLLMG-Z0aFQv4h6Aug44Pnj0DnBvh=yyGr9bA@mail.gmail.com>
> Date: Mon, 19 Oct 2015 05:47:36 -0400
> From: Eli Barzilay <eli@barzilay.org>
> Cc: 21699@debbugs.gnu.org
>
> > I don't know if this is important, but it does change the semantics of
> > an interface that was already released. So I preferred a fix that
> > didn't involve such changes.
>
> OK, here's a version that does the decision in
> `set-file-extended-attributes', making it succeed if all of the given
> attributes were set but ignoring the "null" values. (Again, I verified
> that it works in my case.)
>
> -------------------------------------------------------------------------------
> (defun set-file-extended-attributes (filename attributes)
> "Set extended attributes of file FILENAME to ATTRIBUTES.
>
> ATTRIBUTES must be an alist of file attributes as returned by
> `file-extended-attributes'. Value is t if the function succeeds
> in setting all of the given attributes excluding ones that
> indicate \"no information\"."
> (let ((result t))
> (dolist (elt attributes)
> (let ((attr (car elt))
> (val (cdr elt)))
> (unless (cond ((eq attr 'acl)
> (or (equal val nil)
> (set-file-acl filename val)))
> ((eq attr 'selinux-context)
> (or (equal val '(nil nil nil nil))
> (set-file-selinux-context filename val))))
> (setq result nil))))
> result))
> -------------------------------------------------------------------------------
Thanks. I'll let others to express opinions on this alternative vs
the one I committed. The difference is what happens when all the
attribute values are "null" values: your version returns t in that
case, and I'm not sure that's correct, see below.
> >> With my fix, `file-extended-attributes' would just return nil in
> >> that case, and `set-file-extended-attributes' will succeed
> >> trivially.
> >
> > Why should set-file-extended-attributes succeed in this case? It
> > didn't set any extended attributes, right?
>
> Well, it did set all of the specified attributes, since there were none
> of them. My new fix above will succeed in this case because it will
> ignore all of them.
>
>
> > And if neither ACLs nor SELinux is supported, we should definitely
> > fall back on chmod for the backup files, shouldn't we?
>
> But chmod is not done on backup files other than copy the original bits
> to the backup.
Yes, I'm talking specifically about that scenario. We should fall
back on chmod in that scenario, shouldn't we? And if chmod fails, as
it did for you, shouldn't we tell the user about that?
next prev parent reply other threads:[~2015-10-19 10:14 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-10-18 4:34 bug#21699: 24.5; Bug in backup-buffer-copy and/or set-file-extended-attributes etc Eli Barzilay
2015-10-18 16:01 ` Eli Zaretskii
2015-10-18 21:05 ` Eli Barzilay
2015-10-19 5:10 ` Eli Zaretskii
2015-10-19 7:57 ` Eli Barzilay
2015-10-19 8:23 ` Eli Zaretskii
2015-10-19 9:03 ` Eli Barzilay
2015-10-19 9:09 ` Eli Zaretskii
2015-10-19 9:14 ` Eli Barzilay
2015-10-19 6:14 ` bug#21699: 24.5; Bug in backup-buffer-copy and/or set-file-extended-attributes etc [set-file-extended-attributes] Eli Barzilay
2015-10-19 6:38 ` Eli Zaretskii
2015-10-19 6:50 ` Eli Zaretskii
2015-10-19 7:09 ` Eli Zaretskii
2015-10-19 7:50 ` Eli Barzilay
2015-10-19 8:04 ` Eli Zaretskii
2015-10-19 9:10 ` Eli Barzilay
2015-10-19 9:22 ` Eli Zaretskii
2015-10-19 9:47 ` Eli Barzilay
2015-10-19 10:14 ` Eli Zaretskii [this message]
2015-10-22 5:43 ` Eli Barzilay
2015-10-23 8:25 ` Eli Zaretskii
2022-04-22 13:27 ` bug#21699: 24.5; Bug in backup-buffer-copy and/or set-file-extended-attributes etc Lars Ingebrigtsen
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=83fv17go6s.fsf@gnu.org \
--to=eliz@gnu.org \
--cc=21699@debbugs.gnu.org \
--cc=eli@barzilay.org \
/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 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).