[Treepkg-commits] r319 - trunk/recipes/kde/maemo

scm-commit@wald.intevation.org scm-commit at wald.intevation.org
Fri May 21 15:52:48 CEST 2010


Author: bricks
Date: 2010-05-21 15:52:47 +0200 (Fri, 21 May 2010)
New Revision: 319

Added:
   trunk/recipes/kde/maemo/kde_l10n_tags.py
Log:
kde-l10n packager for maemo tags


Copied: trunk/recipes/kde/maemo/kde_l10n_tags.py (from rev 318, trunk/recipes/kde/maemo/kde_l10n.py)
===================================================================
--- trunk/recipes/kde/maemo/kde_l10n.py	2010-05-21 12:45:58 UTC (rev 318)
+++ trunk/recipes/kde/maemo/kde_l10n_tags.py	2010-05-21 13:52:47 UTC (rev 319)
@@ -0,0 +1,122 @@
+# Copyright (C) 2007, 2008, 2009 by Intevation GmbH
+# Authors:
+# Bernhard Herzog <bh at intevation.de>
+# Bjoern Ricks <bjoern.ricks at intevation.de>
+#
+# This program is free software under the GPL (>=v2)
+# Read the file COPYING coming with the software for details.
+
+import os
+import logging
+import shutil
+import time
+
+import treepkg.util
+from treepkg.cmdexpand import cmdexpand
+from treepkg import run
+
+import recipes.kde.maemo.generic as generic
+
+
+class SourcePackager(tags.SourcePackager):
+
+    """Creates the debian source package for the l10n files
+
+    This is a bit more complicated than for other packages.  The
+    orig.tar.gz file of the debian source package contains one .tar.bz2
+    file for every language.  Those .tar.bz files are the kde-18n-<lang>
+    files released by the KDE project.  For now, we only have the German
+    localization in the enterprise source package, so the orig.tar.gz
+    file will have the following contents:
+
+      kde-l10n-<version>/
+      kde-l10n-<version>/kde-l10n-de-<version>.tar.bz2
+
+    <version> is the same everywhere.
+    """
+
+    createtarball_script = """\
+#! /bin/bash
+set -e
+
+#fakeroot apt-get --assume-yes --force-yes install %(builddeps)s
+
+# copy the source tree to a directory that's under pbuilder control so
+# that it gets removed along with the build environment.  Otherwise we
+# end up with a directory containing files that cannot be removed by
+# treepkg
+workdir=/tmp/work-tags
+cp -a %(basedir)s $workdir
+cd $workdir
+
+# only handle the de subdirectory
+echo de > subdirs
+
+# create the CMakeFiles
+./scripts/autogen.sh
+mv de kde-l10n-de-%(version)s
+tar cjf %(tarball)s kde-l10n-de-%(version)s
+cd ..
+rm -rf $workdir
+"""
+
+
+    def __init__(self, *args, **kw):
+        super(SourcePackager, self).__init__(*args, **kw)
+        self.enterprise_version = (time.strftime("%Y%m%d", time.localtime())
+                                   + "." + str(self.revision))
+        self.maemo_version =  "%s.%s" % (self.revision,
+                              self.parent.pkg_date)
+
+    def determine_package_version(self, directory):
+        enterprise_version = self.enterprise_version
+        maemo_version = self.maemo_version
+        revision = self.revision
+        rules_revision = self.parent.rules_revision
+        pkg_revision = self.parent.pkg_revision
+        pkg_date = self.parent.pkg_date
+
+        return self.track.version_template % locals()
+
+    def create_l10n_de_tarball(self, pkgbasedir, pkgbaseversion):
+        logging.info("Creating kde-l10n-de tarball")
+        de_tarball = os.path.join(self.work_dir,
+                                  "kde-l10n-de-" + pkgbaseversion + ".tar.bz2")
+        # xutils-dev is needed for the revpath script used by
+        # scripts/autogen.sh
+        script = (self.createtarball_script
+                  % dict(builddeps="xutils-dev",  tarball=de_tarball,
+                         basedir=pkgbasedir, version=pkgbaseversion))
+        script_name = os.path.join(self.work_dir, "createtarball")
+        treepkg.util.writefile(script_name, script, 0755)
+        treepkg.util.ensure_directory(self.src_dir)
+        treepkg.util.ensure_directory(self.log_dir)
+        #self.track.builder.run_script([script_name],
+        #                              logfile=os.path.join(self.log_dir,
+        #                                                   "tarball_log.txt"),
+        #                              bindmounts=[self.work_dir])
+        self.run_script([script_name], logfile=os.path.join(self.log_dir,
+                                       "tarball_log.txt"))
+ 
+        return de_tarball
+
+    def run_script(self, script_name, logfile):
+        run.call(cmdexpand("@script", script=script_name),
+                 suppress_output=False, logfile=logfile)
+
+    def prepare_sources_for_tarball(self, pkgbasedir, pkgbaseversion):
+        de_tarball = self.create_l10n_de_tarball(pkgbasedir, pkgbaseversion)
+        shutil.rmtree(pkgbasedir)
+        os.mkdir(pkgbasedir)
+        os.rename(de_tarball,
+                  os.path.join(pkgbasedir, os.path.basename(de_tarball)))
+
+
+class RevisionPackager(tags.RevisionPackager):
+
+    source_packager_cls = SourcePackager
+
+
+class PackageTrack(tags.PackageTrack):
+
+    revision_packager_cls = RevisionPackager



More information about the Treepkg-commits mailing list