view bin/treepkgbuilder.py @ 557:9824e409388b

Refactor git branching If a checkout is already available and the branch is changed in the config git command would always fail because it doesn't know the branch to track. Therefore always check if the branch is locally available and if not checkout the remote branch
author Bjoern Ricks <bricks@intevation.de>
date Fri, 02 Sep 2011 08:45:28 +0000
parents f06f707d9fda
children
line wrap: on
line source
#! /usr/bin/python
# Copyright (C) 2007, 2008, 2009 by Intevation GmbH
# Authors:
# Bernhard Herzog <bh@intevation.de>
#
# This program is free software under the GPL (>=v2)
# Read the file COPYING coming with the software for details.

"""Usage: treepkgbuilder COMMAND [options]

Manage the pbuilder environment for a tree packager installation.  The
pbuilder settings are taken from the configuration file, either the
default treepkg.cfg or the one given with the --config-file option.
Also, this script assumes that there is only one pbuilder setting for
all packagers.  Use treepkgbuilder COMMAND --help for more details about
the commands.
"""

import sys

import treepkgcmd
from treepkg.options import create_parser
from treepkg.packager import create_package_track, PackagerGroup
from treepkg.readconfig import read_config


class Command(object):

    names = ()

    def __init__(self, arguments):
        parser = self.create_parser()
        self.opts, self.rest = parser.parse_args(arguments)

    def create_parser(self):
        return create_parser()

    def read_config(self):
        self.treepkg_opts, self.packager_opts \
                           = read_config(self.opts.config_file)

    def get_builder(self):
        self.read_config()
        group = PackagerGroup([create_package_track(**opts)
                               for opts in self.packager_opts],
                              **self.treepkg_opts)
        track = group.get_package_tracks()[0]
        return track.builder



class InitCommand(Command):

    names = ("init",)

    def __init__(self, arguments):
        super(InitCommand, self).__init__(arguments)
        if self.opts.mirrorsite is None:
            print >>sys.stderr, "Missing required option --mirrorsite"
            sys.exit(1)

    def create_parser(self):
        parser = super(InitCommand, self).create_parser()
        parser.set_defaults(distribution="etch")
        parser.add_option("--mirrorsite",
                          help=("The debian mirror site"
                                " (pbuilder MIRRORSITE setting).  Required."))
        parser.add_option("--othermirror",
                          help=("Extra contents of the OTHERMIRROR setting."
                                " See the pbuilder documentation for the"
                                " format."))
        parser.add_option("--distribution",
                          help=("The debian distribution for the pbuilder"
                                " chroot. Default is etch."))
        return parser

    def run(self):
        builder = self.get_builder()
        builder.init_builder(distribution=self.opts.distribution,
                              mirrorsite=self.opts.mirrorsite,
                              extramirrors=self.opts.othermirror)


class AddBinariesCommand(Command):

    names = ("add-binaries",)

    def create_parser(self):
        parser = super(AddBinariesCommand, self).create_parser()
        parser.set_defaults(subdir="manual")
        parser.add_option("--subdir",
                          help=("The subdirectory of extra-pkg into which"
                                " the packages are to be copied"
                                " (default 'manual')."))
        return parser


    def run(self):
        builder = self.get_builder()
        builder.add_binaries_to_extra_pkg(self.rest,
                                          subdirectory=self.opts.subdir)


class UpdateCommand(Command):

    names = ("update",)

    def run(self):
        builder = self.get_builder()
        builder.update(suppress_output=False, log_info=False)


class AddKeyCommand(Command):

    names = ("addkey", "add-key")

    def __init__(self, arguments):
        super(AddKeyCommand, self).__init__(arguments)
        if not self.opts.key_id:
            print >>sys.stderr, "No key id given"
            sys.exit(1)

    def create_parser(self):
        parser = super(AddKeyCommand, self).create_parser()
        parser.add_option("--key-id",
                          help=("The id of the key to add.  Required."))
        return parser

    def run(self):
        builder = self.get_builder()
        builder.add_apt_key(self.opts.key_id)


class LoginCommand(Command):

    names = ("login",)

    def create_parser(self):
        parser = super(LoginCommand, self).create_parser()
        parser.set_defaults(bind_mount=[])
        parser.add_option("--bind-mount", action="append",
                          help=("Directories to bind-mount in the chroot"
                                " environment."))
        parser.add_option("--save-after-login", action="store_true",
                          help="Copy changes back to the tarball.")
        return parser


    def run(self):
        self.get_builder().login(bindmounts=self.opts.bind_mount,
                                 save_after_login=self.opts.save_after_login)


class BuildCommand(Command):

    names = ("build",)

    def create_parser(self):
        parser = super(BuildCommand, self).create_parser()
        parser.add_option("--logfile", help=("The file for the build log."))
        parser.add_option("--binary-dir",
                          help=("Directory for the binary packages."))
        return parser

    def run(self):
        if len(self.rest) != 1:
            print >>sys.stderr, "Exactly one .dsc file must be specified"
            sys.exit(1)
        dsc_file = self.rest[0]
        self.get_builder().build(dsc_file, binary_dir=self.opts.binary_dir,
                                 logfile=self.opts.logfile)


class ExecuteCommand(Command):

    names = ("execute",)

    def create_parser(self):
        parser = super(ExecuteCommand, self).create_parser()
        parser.add_option("--logfile", help=("Log file."))
        parser.add_option("--bind-mount", action="append",
                          help=("Directories to bind-mount in the chroot"
                                " environment."))
        return parser

    def run(self):
        if not self.rest:
            print >>sys.stderr, "At least the script file must be specified"
            sys.exit(1)
        script = self.rest
        self.get_builder().run_script(script, bindmounts=self.opts.bind_mount,
                                      logfile=self.opts.logfile)


class HelpCommand(Command):

    names = ("help", "--help", "-h")

    def run(self):
        print __doc__.rstrip()
        print "Supported commands:"
        commands = sorted((cmd for cmd in iter_commands() if cmd.names),
                          key=lambda cmd: cmd.names[0])
        for cmd in commands:
            print "   ", " ".join(cmd.names)


def iter_commands():
    for key, obj in globals().items():
        if key.endswith("Command"):
            yield obj

def get_command_class(name):
    for obj in iter_commands():
        if name in obj.names:
            return obj
    return None


def main():
    arguments = sys.argv[1:]

    if len(arguments) < 1:
        print >>sys.stderr, "Missing command"
        sys.exit(1)

    command_name = arguments[0]
    arguments = arguments[1:]

    command_class = get_command_class(command_name)
    if command_class is None:
        print >>sys.stderr, "Unknown command %r" % command_name
        sys.exit(1)

    command = command_class(arguments)
    command.run()


main()
This site is hosted by Intevation GmbH (Datenschutzerklärung und Impressum | Privacy Policy and Imprint)