[oe-commits] org.oe.dev package_x.bbclass: Sync with poky preparing for individual package writing tasks

rpurdie commit openembedded-commits at lists.openembedded.org
Sun Sep 2 00:04:14 UTC 2007


package_x.bbclass: Sync with poky preparing for individual package writing tasks

Author: rpurdie at openembedded.org
Branch: org.openembedded.dev
Revision: de0f7d33bace1070e3a1202edc6e122f22d6873c
ViewMTN: http://monotone.openembedded.org/revision.psp?id=de0f7d33bace1070e3a1202edc6e122f22d6873c
Files:
1
classes/package_deb.bbclass
classes/package_rpm.bbclass
classes/package_tar.bbclass
Diffs:

#
# mt diff -r523a58e7085d331f0ced5c18729477190b028877 -rde0f7d33bace1070e3a1202edc6e122f22d6873c
#
# 
# 
# patch "classes/package_deb.bbclass"
#  from [e921fa8625c039aae270b843336c64fbd0a5dbf2]
#    to [73842f1df6176a56ec4f8018d2d98ca667df785f]
# 
# patch "classes/package_rpm.bbclass"
#  from [555193edec7219ac867536609f6970425ff4522b]
#    to [bb81b0ca13339c5590f4287cb163cfd408618bab]
# 
# patch "classes/package_tar.bbclass"
#  from [10aa1d1ddc7ffe939e5af5cd9118f366d4d4aba3]
#    to [3b2206e771dcb118314fab5af6570042df83f633]
# 
============================================================
--- classes/package_deb.bbclass	e921fa8625c039aae270b843336c64fbd0a5dbf2
+++ classes/package_deb.bbclass	73842f1df6176a56ec4f8018d2d98ca667df785f
@@ -64,9 +64,7 @@ python do_package_deb () {
 }
 
 python do_package_deb () {
-    import copy # to back up env data
-    import sys
-    import re
+    import sys, re, fcntl, copy
 
     workdir = bb.data.getVar('WORKDIR', d, 1)
     if not workdir:
@@ -99,10 +97,21 @@ python do_package_deb () {
         bb.debug(1, "No packages; nothing to do")
         return
 
+    def lockfile(name):
+        lf = open(name, "a+")
+        fcntl.flock(lf.fileno(), fcntl.LOCK_EX)
+        return lf
+
+    def unlockfile(lf):
+        fcntl.flock(lf.fileno(), fcntl.LOCK_UN)
+        lf.close
+
     for pkg in packages.split():
         localdata = bb.data.createCopy(d)
         root = "%s/install/%s" % (workdir, pkg)
 
+        lf = lockfile(root + ".lock")
+
         bb.data.setVar('ROOT', '', localdata)
         bb.data.setVar('ROOT_%s' % pkg, root, localdata)
         pkgname = bb.data.getVar('PKG_%s' % pkg, localdata, 1)
@@ -133,6 +142,7 @@ python do_package_deb () {
         if not g and bb.data.getVar('ALLOW_EMPTY', localdata) != "1":
             from bb import note
             note("Not creating empty archive for %s-%s-%s" % (pkg, bb.data.getVar('PV', localdata, 1), bb.data.getVar('PR', localdata, 1)))
+            unlockfile(lf)
             continue
         controldir = os.path.join(root, 'DEBIAN')
         bb.mkdirhier(controldir)
@@ -246,5 +256,20 @@ python do_package_deb () {
             os.rmdir(controldir)
         except OSError:
             pass
-        del localdata
+
+        unlockfile(lf)
 }
+
+python () {
+    import bb
+    if bb.data.getVar('PACKAGES', d, True) != '':
+        bb.data.setVarFlag('do_package_write_deb', 'depends', 'dpkg-native:do_populate_staging fakeroot-native:do_populate_staging', d)
+}
+
+python do_package_write_deb () {
+	bb.build.exec_func("read_subpackage_metadata", d)
+	bb.build.exec_func("do_package_deb", d)
+}
+do_package_write_deb[dirs] = "${D}"
+#addtask package_write_deb before do_package_write after do_package
+
============================================================
--- classes/package_rpm.bbclass	555193edec7219ac867536609f6970425ff4522b
+++ classes/package_rpm.bbclass	bb81b0ca13339c5590f4287cb163cfd408618bab
@@ -54,7 +54,6 @@ python write_specfile() {
 	except OSError:
 		raise bb.build.FuncFailed("unable to open spec file for writing.")
 
-#	fd = sys.__stdout__
 	fd = specfile
 	for var in out_vartranslate.keys():
 		if out_vartranslate[var][0] == "%":
@@ -123,7 +122,7 @@ python do_package_rpm () {
 		bb.data.setVar('OVERRIDES', '%s:%s' % (overrides, pkg), localdata)
 
 		bb.data.update_data(localdata)
-# stuff
+
 		root = bb.data.getVar('ROOT', localdata)
 		basedir = os.path.dirname(root)
 		pkgoutdir = outdir
@@ -132,3 +131,17 @@ python do_package_rpm () {
 		bb.build.exec_func('write_specfile', localdata)
 		del localdata
 }
+
+python () {
+    import bb
+    if bb.data.getVar('PACKAGES', d, True) != '':
+        bb.data.setVarFlag('do_package_write_rpm', 'depends', 'rpm-native:do_populate_staging', d)
+}
+
+
+python do_package_write_rpm () {
+	bb.build.exec_func("read_subpackage_metadata", d)
+	bb.build.exec_func("do_package_rpm", d)
+}
+do_package_write_rpm[dirs] = "${D}"
+#addtask package_write_rpm before do_build after do_package
============================================================
--- classes/package_tar.bbclass	10aa1d1ddc7ffe939e5af5cd9118f366d4d4aba3
+++ classes/package_tar.bbclass	3b2206e771dcb118314fab5af6570042df83f633
@@ -98,3 +98,17 @@ python do_package_tar () {
 		if ret != 0:
 			bb.error("Creation of tar %s failed." % tarfn)
 }
+
+python () {
+    import bb
+    if bb.data.getVar('PACKAGES', d, True) != '':
+        bb.data.setVarFlag('do_package_write_tar', 'depends', 'tar-native:do_populate_staging', d)
+}
+
+
+python do_package_write_tar () {
+	bb.build.exec_func("read_subpackage_metadata", d)
+	bb.build.exec_func("do_package_tar", d)
+}
+do_package_write_tar[dirs] = "${D}"
+#addtask package_write_tar before do_build after do_package






More information about the Openembedded-commits mailing list