bricks@358: # Copyright (C) 2007 - 2010 by Intevation GmbH bricks@358: # Authors: bricks@358: # Bernhard Herzog bricks@358: # Bjoern Ricks bricks@358: # bricks@358: # This program is free software under the GPL (>=v2) bricks@358: # Read the file COPYING coming with the software for details. bricks@358: bricks@499: """PackageTrack for kde entperprise tag only builds""" bricks@358: bricks@358: import logging bricks@358: bricks@524: from treepkg.readconfig import convert_bool bricks@499: import recipes.kde.enterprise.generic as enterprise bricks@358: bricks@499: class PackageTrack(enterprise.PackageTrack): bricks@358: bricks@499: """In contrast to recipes.kde.enterprise.generic.PackageTrack bricks@499: this PackageTrack either builds trunk or newest tag""" bricks@499: bricks@499: revision_packager_cls = enterprise.RevisionPackager bricks@358: bricks@524: extra_config_desc = [("tags_url", str, ""), bricks@524: ("tags_pattern", str, ""), bricks@524: ("tags_subdir", str, ""), bricks@524: ("tags_scm_type", str, None), bricks@524: ("tags_rules_url", str, None), bricks@524: ("tags_rules_pattern", str, ""), bricks@524: ("tags_rules_subdir", str, ""), bricks@524: ("tags_rules_scm_type", str, None), bricks@524: ("fail_if_tag_not_found", convert_bool, "true")] bricks@524: bricks@358: def __init__(self, *args, **kw): bricks@524: self.fail_if_tag_not_found = kw.pop("fail_if_tag_not_found") bricks@358: super(PackageTrack, self).__init__(*args, **kw) bricks@358: bricks@358: def packager_for_new_revision(self): bricks@358: logging.info("Checking tags") bricks@358: self.tag_url = None bricks@358: self.use_tag_rules = self.found_tag_rules bricks@358: tag_url, tag_revision = self.tag_detector.newest_tag_revision() bricks@358: tag_rules_url, tag_rules_revision = self.tag_rules_detector.newest_tag_revision() bricks@358: logging.info("Found: %s: %s", tag_url, tag_revision) bricks@358: logging.info("Found rules: %s: %s", tag_rules_url, tag_rules_revision) bricks@358: if self.use_tag_rules and tag_rules_url is None: bricks@524: self.use_tag_rules = False bricks@524: logging.error("No rules found in tag but tag should be used to" \ bricks@524: " build package.") bricks@524: return bricks@358: if tag_url is not None: bricks@358: if not self.use_tag_rules: bricks@358: tag_rules_revision = self.rules_working_copy.last_changed_revision() bricks@358: revision = (tag_revision, tag_rules_revision) bricks@358: logging.info("New revision is %s", revision) bricks@358: if revision not in self.get_revision_numbers(): bricks@358: logging.info("Revision %s has not been packaged yet", bricks@358: revision) bricks@358: self.tag_url = tag_url bricks@358: self.tag_revision = tag_revision bricks@358: self.tag_rules_url = tag_rules_url bricks@358: self.tag_rules_revision = tag_rules_revision bricks@526: tag_date, tag_change_count = self.tag_detector.tag_pkg_parameters(tag_url) bricks@528: logging.info("Tag date was %s", tag_date) bricks@358: pkg_revision = (self.pkg_revision_template bricks@358: % dict(pkg_revision=tag_change_count, bricks@358: rules_revision=revision[1])) bricks@358: return self.revision_packager_cls(self, tag=tag_url, bricks@358: pkg_revision=pkg_revision, bricks@358: pkg_date=tag_date, bricks@358: *revision) bricks@358: else: bricks@358: logging.info("Revision %s has already been packaged.", bricks@358: revision) bricks@358: bricks@524: else: bricks@524: if self.fail_if_tag_not_found: bricks@524: logging.error("Could not find tag for track %s", self.name) bricks@524: return bricks@524: # tag_url is not set -> build trunk bricks@358: # don't use rules from tags for trunk builds bricks@358: self.use_tag_rules = False bricks@499: return super(PackageTrack, self).new_revsision_packager()