]> code.ossystems Code Review - openembedded-core.git/commitdiff
package.bbclass: Fix various problems
authorRichard Purdie <richard.purdie@linuxfoundation.org>
Tue, 1 Nov 2011 14:21:11 +0000 (14:21 +0000)
committerRichard Purdie <richard.purdie@linuxfoundation.org>
Tue, 1 Nov 2011 16:51:17 +0000 (16:51 +0000)
Before this change:

a) Ownership and permissions of files copied from packages to
   package-split could get lost during the copy process. This change
   ensures they are preserved.
b) Ownership and permissions of directories could also get lost.
   Most of the complexity in this patch is addressing this problem
   ensuring newly created directories match the source ones being
   copied.
c) There was no warning about directories being created but not
   shipped by any package.

This patch fixes all of the above issues.

Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
meta/classes/package.bbclass

index a9c510d27c212fa5d02d83896e68a2fbdf8d4b5f..0e1d8dbfc4692a36db21c4425e5c049ad7e0dcba 100644 (file)
@@ -916,16 +916,37 @@ python populate_packages () {
                        if file in seen:
                                continue
                        seen.append(file)
+
+                       def mkdir(src, dest, p):
+                               src = os.path.join(src, p)
+                               dest = os.path.join(dest, p)
+                               bb.mkdirhier(dest)
+                               fstat = os.stat(src)
+                               os.chmod(dest, fstat.st_mode)
+                               os.chown(dest, fstat.st_uid, fstat.st_gid)
+                               if p not in seen:
+                                       seen.append(p)
+
+                       def mkdir_recurse(src, dest, paths):
+                               while paths.startswith("./"):
+                                       paths = paths[2:]
+                               p = "."
+                               for c in paths.split("/"):
+                                       p = os.path.join(p, c)
+                                       if not os.path.exists(os.path.join(dest, p)):
+                                               mkdir(src, dest, p)
+
                        if os.path.isdir(file) and not os.path.islink(file):
-                               bb.mkdirhier(os.path.join(root,file))
-                               os.chmod(os.path.join(root,file), os.stat(file).st_mode)
+                               mkdir_recurse(dvar, root, file)
                                continue
 
+                       mkdir_recurse(dvar, root, os.path.dirname(file))
                        fpath = os.path.join(root,file)
-                       dpath = os.path.dirname(fpath)
-                       bb.mkdirhier(dpath)
                        if not os.path.islink(file):
                                os.link(file, fpath)
+                               fstat = os.stat(file)
+                               os.chmod(fpath, fstat.st_mode)
+                               os.chown(fpath, fstat.st_uid, fstat.st_gid)
                                continue
                        ret = bb.copyfile(file, fpath)
                        if ret is False or ret == 0:
@@ -939,13 +960,13 @@ python populate_packages () {
                dir = root[len(dvar):]
                if not dir:
                        dir = os.sep
-               for f in files:
+               for f in (files + dirs):
                        path = os.path.join(dir, f)
                        if ('.' + path) not in seen:
                                unshipped.append(path)
 
        if unshipped != []:
-               bb.warn("For recipe %s, the following files were installed but not shipped in any package:" % pn)
+               bb.warn("For recipe %s, the following files/directories were installed but not shipped in any package:" % pn)
                for f in unshipped:
                        bb.warn("  " + f)