[elbe-devel] [PATCH v2] pbuilder: call origtargz before pbuilder build

Christian Teklenborg chris at linutronix.de
Fri May 7 12:22:10 CEST 2021


Add the devscripts package to the default-init.xml that origtargz will
be installed on the initvm. Check if an origfile was passed to
pbuilder. If no origfile is given and the format is 3.0 (quilt)
download it with origtargz.

Signed-off-by: Christian Teklenborg <chris at linutronix.de>
---
 debian/control          |  3 ++-
 elbepack/elbeproject.py | 33 +++++++++++++++++++++++----------
 2 files changed, 25 insertions(+), 11 deletions(-)

diff --git a/debian/control b/debian/control
index 949f161f..54d3a514 100644
--- a/debian/control
+++ b/debian/control
@@ -140,7 +140,8 @@ Depends: ${misc:Depends},
   git,
   ca-certificates,
   subversion,
-  haveged
+  haveged,
+  devscripts
 Description: Embedded Linux Build Environment Server Component
  This package is typically installed in a virtual machine (that can be created
  with the 'elbe initvm create' command from the 'elbe' package). Several
diff --git a/elbepack/elbeproject.py b/elbepack/elbeproject.py
index 78a46454..f4021ef3 100644
--- a/elbepack/elbeproject.py
+++ b/elbepack/elbeproject.py
@@ -15,6 +15,7 @@ import datetime
 import io
 import logging
 import sys
+import glob
 
 from elbepack.shellhelper import CommandError, system, do, chroot
 
@@ -740,16 +741,6 @@ class ElbeProject:
         pbdir = os.path.join(self.builddir, "pdebuilder", "current")
         do('mkdir -p "%s"' % os.path.join(pbdir))
 
-        try:
-            for orig_fname in self.orig_files:
-                ofname = os.path.join(self.builddir, orig_fname)
-                do('mv "%s" "%s"' % (ofname,
-                                     os.path.join(self.builddir,
-                                                  "pdebuilder")))
-        finally:
-            self.orig_fname = None
-            self.orig_files = []
-
         # Untar current_pdebuild.tar.gz into pdebuilder/current
         do('tar xfz "%s" -C "%s"' %
            (os.path.join(self.builddir, "current_pdebuild.tar.gz"), pbdir))
@@ -771,6 +762,28 @@ class ElbeProject:
         profile_list = profile.split(",")
         deb_build_opts = [i for i in profile_list if i=="nodoc" or i=="nocheck"]
 
+        pdebuilder_current = os.path.join(self.builddir, "pdebuilder", "current")
+
+        formatfile = ""
+
+        if os.path.exists(os.path.join(pdebuilder_current, "debian", "source", "format")):
+            formatfile = open(os.path.join(pdebuilder_current, "debian", "source", "format"), "r").read()
+
+        src_pkg_name = open(os.path.join(pdebuilder_current, "debian", "changelog"), "r").readline().split()[0]
+
+        if "3.0 (quilt)" in formatfile and not self.orig_files:
+            do("cd %s; origtargz --download-only --tar-only" % pdebuilder_current)
+            self.orig_files = glob.glob("%s/../%s*.orig.*" % (pdebuilder_current, src_pkg_name))
+        try:
+            for orig_fname in self.orig_files:
+                    ofname = os.path.join(self.builddir, orig_fname)
+                    do('mv "%s" "%s"' % (ofname,
+                                         os.path.join(self.builddir,
+                                                      "pdebuilder")))
+        finally:
+            self.orig_fname = None
+            self.orig_files = []
+
         try:
             if cross:
                 do('cd "%s"; dpkg-source -b .; %s '
-- 
2.20.1



More information about the elbe-devel mailing list