[Treepkg-commits] r200 - in trunk: recipes/kde_enterprise_3_5 recipes/kde_enterprise_4 treepkg

scm-commit@wald.intevation.org scm-commit at wald.intevation.org
Thu May 7 17:19:16 CEST 2009


Author: bh
Date: 2009-05-07 17:19:15 +0200 (Thu, 07 May 2009)
New Revision: 200

Modified:
   trunk/recipes/kde_enterprise_3_5/base.py
   trunk/recipes/kde_enterprise_4/base.py
   trunk/treepkg/packager.py
Log:
Refactoring: Implement do_package in treepkg.packager.SourcePackager.
The actual implementation in the derived classes is almost identical in
all cases so it's better to have as much of the implementation in the
base class.  The update_version_numbers method is not called directly by
the base class code so is removed from the base class.  OTOH,
prepare_sources_for_tarball has been added as a more general variant of
update_version_numbers that is actually called by the default
implementation of do_package.


Modified: trunk/recipes/kde_enterprise_3_5/base.py
===================================================================
--- trunk/recipes/kde_enterprise_3_5/base.py	2009-05-07 14:25:10 UTC (rev 199)
+++ trunk/recipes/kde_enterprise_3_5/base.py	2009-05-07 15:19:15 UTC (rev 200)
@@ -17,8 +17,6 @@
 
 class BaseSourcePackager(treepkg.packager.SourcePackager):
 
-    changemsg_template = None
-
     def __init__(self, *args, **kw):
         super(BaseSourcePackager, self).__init__(*args, **kw)
         self.enterprise_version = (time.strftime("%Y%m%d", time.localtime()) \
@@ -28,24 +26,16 @@
         enterprise_version = self.enterprise_version
         return self.track.version_template % locals()
 
-    def do_package(self):
-        pkgbaseversion, pkgbasedir = self.export_sources()
+    def prepare_sources_for_tarball(self, pkgbasedir):
         self.update_version_numbers(pkgbasedir)
 
-        pkgbasename = self.pkg_basename + "_" + pkgbaseversion
-        origtargz = os.path.join(self.work_dir,
-                                 pkgbasename + ".orig.tar.gz")
-        self.create_tarball(origtargz, self.work_dir,
-                            os.path.basename(pkgbasedir))
+    def update_version_numbers(self, pkgbasedir):
+        """Updates the version numbers in the code in pkgbasedir.
+        The default implementation does nothing.  Derived classes should
+        override this method if necessary.
+        """
 
-        changemsg = self.changemsg_template % dict(revision=self.revision)
-        self.copy_debian_directory(pkgbasedir, pkgbaseversion,
-                                   changemsg)
 
-        self.create_source_package(pkgbasedir, origtargz)
-        self.move_source_package(pkgbasename)
-
-
 class BasePackageTrack(treepkg.packager.PackageTrack):
 
     extra_config_desc = [("version_template", str, "%(enterprise_version)s"),

Modified: trunk/recipes/kde_enterprise_4/base.py
===================================================================
--- trunk/recipes/kde_enterprise_4/base.py	2009-05-07 14:25:10 UTC (rev 199)
+++ trunk/recipes/kde_enterprise_4/base.py	2009-05-07 15:19:15 UTC (rev 200)
@@ -18,6 +18,8 @@
 
 class BaseSourcePackager(treepkg.packager.SourcePackager):
 
+    changemsg_template = "Update to SVN enterprise4 branch rev. %(revision)d"
+
     def __init__(self, *args, **kw):
         super(BaseSourcePackager, self).__init__(*args, **kw)
         self.enterprise_version = (time.strftime("%Y%m%d", time.localtime()) \
@@ -27,25 +29,16 @@
         enterprise_version = self.enterprise_version
         return self.track.version_template % locals()
 
-    def do_package(self):
-        pkgbaseversion, pkgbasedir = self.export_sources()
+    def prepare_sources_for_tarball(self, pkgbasedir):
         self.update_version_numbers(pkgbasedir)
 
-        pkgbasename = self.pkg_basename + "_" + pkgbaseversion
-        origtargz = os.path.join(self.work_dir,
-                                 pkgbasename + ".orig.tar.gz")
-        self.create_tarball(origtargz, self.work_dir,
-                            os.path.basename(pkgbasedir))
+    def update_version_numbers(self, pkgbasedir):
+        """Updates the version numbers in the code in pkgbasedir.
+        The default implementation does nothing.  Derived classes should
+        override this method if necessary.
+        """
 
-        changemsg = ("Update to SVN enterprise4 branch rev. %d"
-                     % (self.revision,))
-        self.copy_debian_directory(pkgbasedir, pkgbaseversion,
-                                   changemsg)
 
-        self.create_source_package(pkgbasedir, origtargz)
-        self.move_source_package(pkgbasename)
-
-
 class BasePackageTrack(treepkg.packager.PackageTrack):
 
     extra_config_desc = ["version_template",

Modified: trunk/treepkg/packager.py
===================================================================
--- trunk/treepkg/packager.py	2009-05-07 14:25:10 UTC (rev 199)
+++ trunk/treepkg/packager.py	2009-05-07 15:19:15 UTC (rev 200)
@@ -35,6 +35,10 @@
     # Derived classes must supply the package basename
     pkg_basename = None
 
+    # Derived classes may want to override this message
+    changemsg_template = "Update to revision %(revision)d"
+
+
     track = _fromparent("track")
     revision = _fromparent("revision")
     status = _fromparent("status")
@@ -80,11 +84,12 @@
         return pkgbaseversion, pkgbasedir
 
 
-    def update_version_numbers(self, pkgbasedir):
-        """Updates the version numbers in the code in pkgbasedir.
+    def prepare_sources_for_tarball(self, pkgbasedir):
+        """Prepare the exported sources prior to creating the tarball.
 
         The default implementation does nothing.  Derived classes should
-        override this method if necessary.
+        override this method if necessary to e.g. update the version
+        numbers in the code.
         """
 
     def create_tarball(self, tarballname, workdir, basedir, compression="gz"):
@@ -189,16 +194,26 @@
             shutil.rmtree(self.work_dir)
 
     def do_package(self):
-        """Does the work of creating a source package
-        This method must be overriden by derived classes.
+        """Does the work of creating a source package."""
+        pkgbaseversion, pkgbasedir = self.export_sources()
 
-        The method should do the work in self.work_dir.  When the
-        package is done, the source package files should be in
-        self.src_dir.
-        """
-        raise NotImplementedError
+        pkgbasename = self.pkg_basename + "_" + pkgbaseversion
+        origtargz = os.path.join(self.work_dir,
+                                 pkgbasename + ".orig.tar.gz")
 
+        self.prepare_sources_for_tarball(pkgbasedir)
 
+        self.create_tarball(origtargz, self.work_dir,
+                            os.path.basename(pkgbasedir))
+
+        changemsg = self.changemsg_template % dict(revision=self.revision)
+        self.copy_debian_directory(pkgbasedir, pkgbaseversion,
+                                   changemsg)
+
+        self.create_source_package(pkgbasedir, origtargz)
+        self.move_source_package(pkgbasename)
+
+
 class BinaryPackager(object):
 
     track = _fromparent("track")



More information about the Treepkg-commits mailing list