bricks@351: # Copyright (C) 2007 - 2010 by Intevation GmbH bricks@351: # Authors: bricks@351: # Bernhard Herzog bricks@351: # Bjoern Ricks bricks@351: # bricks@351: # This program is free software under the GPL (>=v2) bricks@351: # Read the file COPYING coming with the software for details. bricks@351: bricks@351: """Base classes for kde maemo tag packagers""" bricks@351: bricks@351: import re bricks@351: import time bricks@351: import logging bricks@351: bricks@351: import treepkg.packager bricks@351: import treepkg.subversion as subversion bricks@351: import treepkg.sbuilder bricks@351: bricks@351: bricks@351: class SourcePackager(treepkg.packager.SourcePackager): bricks@351: bricks@351: def __init__(self, *args, **kw): bricks@351: super(SourcePackager, self).__init__(*args, **kw) bricks@351: self.enterprise_version = (self.parent.pkg_date + "." bricks@351: + str(self.revision)) bricks@351: self.maemo_version = "%s.%s" % (self.revision, bricks@351: self.parent.pkg_date) bricks@351: bricks@351: def determine_package_version(self, directory): bricks@351: enterprise_version = self.enterprise_version bricks@351: maemo_version = self.maemo_version bricks@351: revision = self.revision bricks@351: rules_revision = self.parent.rules_revision bricks@351: pkg_revision = self.parent.pkg_revision bricks@351: pkg_date = self.parent.pkg_date bricks@351: bricks@351: return self.track.version_template % locals() bricks@351: bricks@351: def prepare_sources_for_tarball(self, pkgbasedir, pkgbaseversion): bricks@351: self.update_version_numbers(pkgbasedir) bricks@351: bricks@351: def update_version_numbers(self, pkgbasedir): bricks@351: """Updates the version numbers in the code in pkgbasedir. bricks@351: The default implementation does nothing. Derived classes should bricks@351: override this method if necessary. bricks@351: """ bricks@351: bricks@351: def get_change_msg(self): bricks@351: return self.changemsg_template % dict(revision=self.revision, bricks@351: pkg_date=self.parent.pkg_date, bricks@351: rules_revision=self.parent.rules_revision) bricks@351: bricks@351: bricks@351: class RevisionPackager(treepkg.packager.RevisionPackager): bricks@351: bricks@351: source_packager_cls = SourcePackager bricks@351: bricks@351: def __init__(self, *args, **kw): bricks@351: self.pkg_date = kw.pop("pkg_date", bricks@351: time.strftime("%Y%m%d", time.localtime())) bricks@351: super(RevisionPackager, self).__init__(*args, **kw) bricks@351: bricks@351: bricks@351: class PackageTrack(treepkg.packager.PackageTrack): bricks@351: bricks@351: revision_packager_cls = RevisionPackager bricks@351: builder_cls = treepkg.sbuilder.SbdmockBuilder bricks@351: bricks@351: extra_config_desc = [("tags_url", str, ""), bricks@351: ("tags_pattern", str, ""), bricks@351: ("tags_subdir", str, ""), bricks@351: ("tags_rules_subdir", str, "")] bricks@351: bricks@351: def __init__(self, *args, **kw): bricks@351: tags_url = kw.pop("tags_url") bricks@351: tags_pattern = kw.pop("tags_pattern") bricks@351: tags_subdir = kw.pop("tags_subdir") bricks@351: tags_rules_subdir = kw.pop("tags_rules_subdir") bricks@351: super(PackageTrack, self).__init__(*args, **kw) bricks@351: self.tag_detector = subversion.TagDetector(tags_url, tags_pattern, bricks@351: tags_subdir) bricks@351: self.tag_rules_detector = subversion.TagDetector(tags_url, tags_pattern, bricks@351: tags_rules_subdir) bricks@355: self.found_tag_rules = False bricks@351: if tags_rules_subdir: bricks@355: self.found_tag_rules = True bricks@351: bricks@351: def packager_for_new_revision(self): bricks@351: logging.info("Checking tags") bricks@351: self.tag_url = None bricks@356: self.use_tag_rules = self.found_tag_rules bricks@351: tag_url, tag_revision = self.tag_detector.newest_tag_revision() bricks@351: tag_rules_url, tag_rules_revision = self.tag_rules_detector.newest_tag_revision() bricks@351: logging.info("Found: %s: %s", tag_url, tag_revision) bricks@356: logging.info("Found rules: %s: %s", tag_rules_url, tag_rules_revision) bricks@351: if self.use_tag_rules and tag_rules_url is None: bricks@351: self.use_tag_rules = False bricks@351: if tag_url is not None: bricks@351: if not self.use_tag_rules: bricks@351: tag_rules_revision = self.rules_working_copy.last_changed_revision() bricks@351: revision = (tag_revision, tag_rules_revision) bricks@351: logging.info("New revision is %s", revision) bricks@351: if revision not in self.get_revision_numbers(): bricks@351: logging.info("Revision %s has not been packaged yet", bricks@351: revision) bricks@351: self.tag_url = tag_url bricks@351: self.tag_revision = tag_revision bricks@351: self.tag_rules_url = tag_rules_url bricks@351: self.tag_rules_revision = tag_rules_revision bricks@351: tag_date, tag_change_count = self.tag_pkg_parameters(tag_url) bricks@351: pkg_revision = (self.pkg_revision_template bricks@353: % dict(pkg_revision=tag_change_count, bricks@353: rules_revision=revision[1])) bricks@351: return self.revision_packager_cls(self, tag=tag_url, bricks@351: pkg_revision=pkg_revision, bricks@351: pkg_date=tag_date, bricks@351: *revision) bricks@351: else: bricks@351: logging.info("Revision %s has already been packaged.", bricks@351: revision) bricks@353: else: bricks@353: return super(PackageTrack, self).packager_for_new_revision() bricks@351: bricks@351: def export_sources(self, to_dir): bricks@351: if self.tag_url is not None: bricks@351: logging.info("Exporting sources for tarball from %r to %r", bricks@351: self.tag_url, to_dir) bricks@351: self.working_copy.export_tag(self.tag_url, to_dir, bricks@351: revision=self.tag_revision) bricks@351: else: bricks@351: super(PackageTrack, self).export_sources(to_dir) bricks@351: bricks@351: def copy_debian_directory(self, to_dir): bricks@351: if self.use_tag_rules: bricks@351: logging.info("Exporting debian package description from %s to %s", bricks@351: self.tag_rules_url, to_dir) bricks@351: self.rules_working_copy.export_tag(self.tag_rules_url, to_dir) bricks@351: else: bricks@351: super(PackageTrack, self).copy_debian_directory(to_dir) bricks@351: bricks@351: def tag_pkg_parameters(self, tag_url): bricks@351: match = re.search(r"/enterprise[^.]*\.[^.]*\." bricks@351: r"(?P[0-9]{8})\.(?P[0-9]+)/", bricks@351: tag_url) bricks@351: if match: bricks@351: date = match.group("date") bricks@351: baserev = match.group("baserev") bricks@351: xml_log = subversion.log_xml(tag_url, baserev) bricks@351: revisions = subversion.extract_tag_revisions(xml_log) bricks@351: tag_change_count = len(revisions) bricks@351: return (date, tag_change_count) bricks@351: else: bricks@351: raise RuntimeError("Cannot determine tag parameters from %r" bricks@351: % tag_url) bricks@351: