From c64d075b3d367e6c76aafa17782585d026b1f31e Mon Sep 17 00:00:00 2001 From: Mark Hatle Date: Tue, 26 Jul 2011 14:28:33 -0500 Subject: package.bbclass: fixup_perms - change symlink processing We switch to using os.lchown in order to avoid following a symlink. We also now check if an item is a symlink, if so we avoid the os.chmod as a symlink inherits the mode of it's target. Signed-off-by: Mark Hatle --- meta/classes/package.bbclass | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/meta/classes/package.bbclass b/meta/classes/package.bbclass index f2950e25c2..076a532360 100644 --- a/meta/classes/package.bbclass +++ b/meta/classes/package.bbclass @@ -472,7 +472,7 @@ python fixup_perms () { else: return int(mode,8) - # Note uid/gid -1 has special significance in os.chown + # Note uid/gid -1 has special significance in os.lchown def _procuid(self, uid): if uid is None or uid == "-": return -1 @@ -514,14 +514,14 @@ python fixup_perms () { # Fix the permission, owner and group of path def fix_perms(path, mode, uid, gid, dir): - if mode: + if mode and not os.path.islink(path): #bb.note("Fixup Perms: chmod 0%o %s" % (mode, dir)) os.chmod(path, mode) # -1 is a special value that means don't change the uid/gid - # if they are BOTH -1, don't bother to chown + # if they are BOTH -1, don't bother to lchown if not (uid == -1 and gid == -1): - #bb.note("Fixup Perms: chown %d:%d %s" % (uid, gid, dir)) - os.chown(path, uid, gid) + #bb.note("Fixup Perms: lchown %d:%d %s" % (uid, gid, dir)) + os.lchown(path, uid, gid) # Return a list of configuration files based on either the default # files/fs-perms.txt or the contents of FILESYSTEM_PERMS_TABLES -- cgit 1.2.3-korg