summaryrefslogtreecommitdiff
path: root/gbp/deb
diff options
context:
space:
mode:
authorGuido Günther <agx@sigxcpu.org>2012-01-13 09:07:19 +0100
committerGuido Günther <agx@sigxcpu.org>2012-01-22 19:45:26 +0100
commit5b5dbf61244708d9d234a3ef90ce85cd4f35f259 (patch)
tree4ac0abfab8629011418c4bc6852b423295b1a2f3 /gbp/deb
parent63b24cef4db5277eff7b38bbe359fc30f9d28b90 (diff)
downloadgit-buildpackage-5b5dbf61244708d9d234a3ef90ce85cd4f35f259.tar.gz
git-buildpackage-5b5dbf61244708d9d234a3ef90ce85cd4f35f259.tar.bz2
git-buildpackage-5b5dbf61244708d9d234a3ef90ce85cd4f35f259.zip
PristineTar: move to separate module
and make it accessible from GitRepository to group checkout/checkin/lookup.
Diffstat (limited to 'gbp/deb')
-rw-r--r--gbp/deb/git.py23
-rw-r--r--gbp/deb/pristinetar.py113
2 files changed, 136 insertions, 0 deletions
diff --git a/gbp/deb/git.py b/gbp/deb/git.py
index aa19f82a..3f998051 100644
--- a/gbp/deb/git.py
+++ b/gbp/deb/git.py
@@ -18,10 +18,15 @@
import re
from gbp.git import GitRepository, GitRepositoryError
+from gbp.deb.pristinetar import PristineTar
class DebianGitRepository(GitRepository):
"""A git repository that holds the source of a Debian package"""
+ def __init__(self, path):
+ super(DebianGitRepository, self).__init__(path)
+ self.pristine_tar = PristineTar(self)
+
def find_version(self, format, version):
"""
Check if a certain version is stored in this repo and return the SHA1
@@ -112,4 +117,22 @@ class DebianGitRepository(GitRepository):
return version
return None
+ @property
+ def pristine_tar_branch(self):
+ """
+ The name of the pristine-tar branch, whether it already exists or
+ not.
+ """
+ return PristineTar.branch
+
+ def has_pristine_tar_branch(self):
+ """
+ Wheter the repo has a I{pristine-tar} branch.
+
+ @return: C{True} if the repo has pristine-tar commits already, C{False}
+ otherwise
+ @rtype: C{Bool}
+ """
+ return True if self.has_branch(self.pristine_tar_branch) else False
+
# vim:et:ts=4:sw=4:et:sts=4:ai:set list listchars=tab\:»·,trail\:·:
diff --git a/gbp/deb/pristinetar.py b/gbp/deb/pristinetar.py
new file mode 100644
index 00000000..4478ad42
--- /dev/null
+++ b/gbp/deb/pristinetar.py
@@ -0,0 +1,113 @@
+# vim: set fileencoding=utf-8 :
+#
+# (C) 2012 Guido Günther <agx@sigxcpu.org>
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+"""Handle checkin and checkout of archives from the pristine-tar branch"""
+
+import os, re
+from gbp.command_wrappers import Command
+from gbp.deb import UpstreamSource, compressor_opts
+
+class PristineTar(Command):
+ """The pristine-tar branch in a git repository"""
+ cmd='/usr/bin/pristine-tar'
+ branch = 'pristine-tar'
+
+ def __init__(self, repo):
+ self.repo = repo
+ super(PristineTar, self).__init__(self.cmd)
+
+ def has_commit(self, package, version, comp_type=None):
+ """
+ Do we have a pristine-tar commit for package I{package} at version
+ {version} with compression type I{comp_type}?
+
+ @param package: the package to look for
+ @type package: C{str}
+ @param version: the upstream version to look for
+ @type version: C{str}
+ @param comp_type: the compression type
+ @type comp_type: C{str}
+ """
+ return True if self.get_commit(package, version, comp_type) else False
+
+ def get_commit(self, package, version, comp_type=None):
+ """
+ Get the pristine-tar commit of package I{package} in version I{version}
+ and compression type I{comp_type}
+
+ @param package: the package to look for
+ @type package: C{str}
+ @param version: the version to look for
+ @param comp_type: the compression type
+ @type comp_type: C{str}
+ """
+ if not self.repo.has_pristine_tar_branch():
+ return None
+
+ if not comp_type:
+ ext = '\w+'
+ else:
+ ext = compressor_opts[comp_type][1]
+
+ regex = ('pristine-tar .* %s_%s\.orig\.tar\.%s' %
+ (package, version, ext))
+ commits = self.repo.grep_log(regex, self.branch)
+ if commits:
+ commit = commits[-1]
+ gbp.log.debug("Found pristine-tar commit at '%s'" % commit)
+ return commit
+ return None
+
+ def _checkout(self, archive):
+ self.run_error = 'Couldn\'t checkout "%s"' % os.path.basename(archive)
+ self.__call__(['checkout', archive])
+
+ def checkout(self, package, version, comp_type, output_dir):
+ """
+ Checkout the orig tarball for package I{package} of I{version} and
+ compression type I{comp_type} to I{output_dir}
+
+ @param package: the package to generate the orig tarball for
+ @type package: C{str}
+ @param version: the version to check generate the orig tarball for
+ @type version: C{str}
+ @param comp_type: the compression type of the tarball
+ @type comp_type: C{str}
+ @param output_dir: the directory to put the tarball into
+ @type output_dir: C{str}
+ """
+ name = UpstreamSource.build_tarball_name(package,
+ version,
+ comp_type,
+ output_dir)
+ self._checkout(name)
+
+ def commit(self, archive, upstream):
+ """
+ Commit an archive I{archive} to the pristine tar branch using upstream
+ branch ${upstream}.
+
+ @param archive: the archive to commit
+ @type archive: C{str}
+ @param upstream: the upstream branch to diff against
+ @type upstream: C{str}
+ """
+ ref = 'refs/heads/%s' % upstream
+
+ self.run_error = ("Couldn't commit to '%s' with upstream '%s'" %
+ (self.branch, upstream))
+ self.__call__(['commit', archive, upstream])
+