[Treepkg-commits] r332 - trunk/recipes/wince
scm-commit@wald.intevation.org
scm-commit at wald.intevation.org
Mon Jun 21 12:44:57 CEST 2010
Author: aheinecke
Date: 2010-06-21 12:44:57 +0200 (Mon, 21 Jun 2010)
New Revision: 332
Added:
trunk/recipes/wince/dbus.py
trunk/recipes/wince/libexpat.py
Log:
Added for Windows CE
Added: trunk/recipes/wince/dbus.py
===================================================================
--- trunk/recipes/wince/dbus.py 2010-06-21 10:43:16 UTC (rev 331)
+++ trunk/recipes/wince/dbus.py 2010-06-21 10:44:57 UTC (rev 332)
@@ -0,0 +1,153 @@
+# Copyright (C) 2010 by Intevation GmbH
+# Authors:
+# Andre Heinecke <aheinecke at intevation.de>
+#
+# This program is free software under the GPL (>=v2)
+# Read the file COPYING coming with the software for details.
+
+"""Recipe to build DBus from Git"""
+
+import os
+import re
+import inspect
+import new
+
+import treepkg.util
+import treepkg.packager
+import treepkg.run as run
+from treepkg.cmdexpand import cmdexpand
+
+class SourcePackager(treepkg.packager.SourcePackager):
+
+ """SourcePackager that uses pbuilder to create the source tarball"""
+
+ tarball_dependencies=set(["autoconf", "automake","git-core", "git",
+ "libexpat-ce-arm-dev"])
+ createtarball_script = """\
+#! /bin/bash
+#set -e
+
+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
+cp -a %(basedir)s $workdir
+cd $workdir
+
+export MINGWPATH=/opt/mingw32ce
+export INCLUDE=$MINGWPATH/arm-mingw32ce/include:$MINGWPATH/include:$INCLUDE
+export LIB=$MINGWPATH/arm-mingw32ce/lib:$MINGWPATH/lib:$LIB
+export PATH=:$PATH:$MINGWPATH/bin:$MINGWPATH/arm-mingw32ce/bin:\
+$MINGWPATH/libexec/gcc/arm-mingw32ce/4.4.0
+export LDFLAGS=-L$MINGWPATH/lib
+export CFLAGS=-I$MINGWPATH/include
+export CPPFLAGS=-I$MINGWPATH/include
+
+./autogen.sh --enable-maintainer-mode --host=arm-mingw32ce
+%(make_dist_command)s
+echo "origtargz " %(origtargz)s
+mv *.tar.gz %(origtargz)s
+"""
+
+ make_dist_command = "make dist"
+
+ def __init__(self, *args):
+ super(SourcePackager, self).__init__(*args)
+ self.pkgbasename = None
+ self.pkgbaseversion = None
+ self.origtargz = None
+
+ def orig_source_version(self, directory):
+ """Determines the version from configure.in"""
+ major = run.capture_output(cmdexpand("/bin/sh -c \"cat configure.in | \
+ grep dbus_major_version\] | \
+ awk -F \[ '{print $$3}'\""),
+ cwd=directory)[:1]
+ minor = run.capture_output(cmdexpand("/bin/sh -c \"cat configure.in | \
+ grep dbus_minor_version\] | \
+ awk -F \[ '{print $$3}'\""),
+ cwd=directory)[:1]
+ micro = run.capture_output(cmdexpand("/bin/sh -c \"cat configure.in | \
+ grep dbus_micro_version\] | \
+ awk -F \[ '{print $$3}'\""),
+ cwd=directory)[:1]
+ if not major or not minor or not micro:
+ raise RuntimeError("Could not determine version from \
+ %s/configure.in" % directory)
+ return "%s.%s.%s" % (major[:1],minor[:1],micro[:1])
+
+ def determine_package_version(self, directory):
+ """ Returns a Git package Name """
+ date = run.capture_output(cmdexpand("/bin/sh -c \" git log --date=iso \
+ -n 1 | grep Date \
+ | awk \'{print $$2}\'\""),
+ cwd=directory)
+ time = run.capture_output(cmdexpand("/bin/sh -c \" git log --date=iso \
+ -n 1 | grep Date \
+ | awk \'{print $$3}\'\""),
+ cwd=directory)
+ date = date.replace('-','')
+ time = time.replace(':','')
+ return "%s-%s%s.%s" % (self.orig_source_version(directory),
+ date[:8], time[:4], self.revision[:7])
+
+ def copy_workingcopy(self, dest):
+ treepkg.util.copytree(self.track.checkout_dir, dest)
+
+ def create_original_tarball(self):
+ copied_working_copy = os.path.join(self.work_dir, "copied_working_copy")
+ self.copy_workingcopy(copied_working_copy)
+
+ self.pkgbaseversion = \
+ self.determine_package_version(copied_working_copy)
+ self.pkgbasename = self.pkg_basename + "_" + self.pkgbaseversion
+ self.origtargz = os.path.join(self.work_dir,
+ self.pkgbasename + ".orig.tar.gz")
+
+ script = (self.createtarball_script
+ % dict(builddeps=" ".join(self.track.dependencies_required()
+ | self.tarball_dependencies),
+ basedir=copied_working_copy,
+ origtargz=self.origtargz,
+ make_dist_command=self.make_dist_command))
+ 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.src_dir])
+
+ def create_orig_dir(self):
+ """Unpacks the tarball created by create_original_tarball into work_dir
+ """
+ unpack_dir = os.path.join(self.work_dir, "unpack")
+ treepkg.util.ensure_directory(unpack_dir)
+ run.call(cmdexpand("tar xzf $origtargz -C $unpack_dir",
+ unpack_dir=unpack_dir, origtargz=self.origtargz))
+ unpacked_files = treepkg.util.listdir_abs(unpack_dir)
+ if len(unpacked_files) != 1:
+ raise RuntimeError("%s should have extracted to a single directory",
+ origtargz)
+ unpacked_dir = unpacked_files[0]
+
+ orig_dir = os.path.join(self.work_dir, os.path.basename(unpacked_dir))
+ os.rename(unpacked_dir, orig_dir)
+ return orig_dir
+
+ def do_package(self):
+ self.create_original_tarball()
+ orig_dir = self.create_orig_dir()
+
+ changemsg = ("Update to change: %s" % self.revision)
+
+ self.copy_debian_directory(orig_dir, self.pkgbaseversion, changemsg)
+
+ self.create_source_package(orig_dir, self.origtargz)
+ self.move_source_package(self.pkgbasename)
+
Added: trunk/recipes/wince/libexpat.py
===================================================================
--- trunk/recipes/wince/libexpat.py 2010-06-21 10:43:16 UTC (rev 331)
+++ trunk/recipes/wince/libexpat.py 2010-06-21 10:44:57 UTC (rev 332)
@@ -0,0 +1,138 @@
+# Copyright (C) 2010 by Intevation GmbH
+# Authors:
+# Andre Heinecke <aheinecke at intevation.de>
+#
+# This program is free software under the GPL (>=v2)
+# Read the file COPYING coming with the software for details.
+
+"""Recipe to build libexpat from Git"""
+
+import os
+import re
+import inspect
+import new
+
+import treepkg.util
+import treepkg.packager
+import treepkg.run as run
+from treepkg.cmdexpand import cmdexpand
+
+class SourcePackager(treepkg.packager.SourcePackager):
+
+ """SourcePackager that uses pbuilder to create the source tarball"""
+
+ tarball_dependencies=set(["autoconf", "automake","git-core", "git"])
+ createtarball_script = """\
+#! /bin/bash
+set -e
+
+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
+cp -a %(basedir)s $workdir
+cd $workdir
+
+export MINGWPATH=/opt/mingw32ce
+export INCLUDE=$MINGWPATH/arm-mingw32ce/include:$MINGWPATH/include:$INCLUDE
+export LIB=$MINGWPATH/arm-mingw32ce/lib:$MINGWPATH/lib:$LIB
+export PATH=:$PATH:$MINGWPATH/bin:$MINGWPATH/arm-mingw32ce/bin:\
+$MINGWPATH/libexec/gcc/arm-mingw32ce/4.4.0:
+
+autoreconf
+./configure --enable-maintainer-mode --host=arm-mingw32ce
+%(make_dist_command)s
+
+mv *.tar.gz %(origtargz)s
+"""
+
+ make_dist_command = "make dist"
+
+ def __init__(self, *args):
+ super(SourcePackager, self).__init__(*args)
+ self.pkgbasename = None
+ self.pkgbaseversion = None
+ self.origtargz = None
+
+ def orig_source_version(self, directory):
+ """Determines the version from expat.h directory"""
+ filename = os.path.join(directory, "conftools/get-version.sh")
+ expat_h = os.path.join(directory, "lib/expat.h")
+ output = run.capture_output(cmdexpand("$filename $expat_h",**locals()))
+ return output
+
+ def determine_package_version(self, directory):
+ """ Returns a Git package Name """
+ date = run.capture_output(cmdexpand("/bin/sh -c \" git log --date=iso \
+ -n 1 | grep Date \
+ | awk \'{print $$2}\'\""),
+ cwd=directory)
+ time = run.capture_output(cmdexpand("/bin/sh -c \" git log --date=iso \
+ -n 1 | grep Date \
+ | awk \'{print $$3}\'\""),
+ cwd=directory)
+ date = date.replace('-','')
+ time = time.replace(':','')
+ return "%s-%s%s.%s" % (self.orig_source_version(directory),
+ date[:8], time[:4], self.revision[:7])
+
+ def copy_workingcopy(self, dest):
+ treepkg.util.copytree(self.track.checkout_dir, dest)
+
+ def create_original_tarball(self):
+ copied_working_copy = os.path.join(self.work_dir, "copied_working_copy")
+ self.copy_workingcopy(copied_working_copy)
+
+ self.pkgbaseversion = \
+ self.determine_package_version(copied_working_copy)
+ self.pkgbasename = self.pkg_basename + "_" + self.pkgbaseversion
+ self.origtargz = os.path.join(self.work_dir,
+ self.pkgbasename + ".orig.tar.gz")
+
+ script = (self.createtarball_script
+ % dict(builddeps=" ".join(self.track.dependencies_required()
+ | self.tarball_dependencies),
+ basedir=copied_working_copy,
+ origtargz=self.origtargz,
+ make_dist_command=self.make_dist_command))
+ 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.src_dir])
+
+ def create_orig_dir(self):
+ """Unpacks the tarball created by create_original_tarball into work_dir
+ """
+ unpack_dir = os.path.join(self.work_dir, "unpack")
+ treepkg.util.ensure_directory(unpack_dir)
+ run.call(cmdexpand("tar xzf $origtargz -C $unpack_dir",
+ unpack_dir=unpack_dir, origtargz=self.origtargz))
+ unpacked_files = treepkg.util.listdir_abs(unpack_dir)
+ if len(unpacked_files) != 1:
+ raise RuntimeError("%s should have extracted to a single directory",
+ origtargz)
+ unpacked_dir = unpacked_files[0]
+
+ orig_dir = os.path.join(self.work_dir, os.path.basename(unpacked_dir))
+ os.rename(unpacked_dir, orig_dir)
+ return orig_dir
+
+ def do_package(self):
+ self.create_original_tarball()
+ orig_dir = self.create_orig_dir()
+
+ changemsg = ("Update to change: %s" % self.revision)
+
+ self.copy_debian_directory(orig_dir, self.pkgbaseversion, changemsg)
+
+ self.create_source_package(orig_dir, self.origtargz)
+ self.move_source_package(self.pkgbasename)
+
More information about the Treepkg-commits
mailing list