aboutsummaryrefslogtreecommitdiffstats
path: root/MgaRepo/commands/getsrpm.py
blob: caadfeb4117f4c487980855ab70606edc9652c04 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#
# This program will extract given version/revision of the named package
# from the Conectiva Linux repository system.
#
from MgaRepo import Error, config, disable_mirror
from MgaRepo.command import *
from MgaRepo.layout import package_url
from MgaRepo.rpmutil import get_srpm
import tempfile
import shutil
import getopt
import glob
import sys
import os

HELP = """\
Usage: mgarepo getsrpm [OPTIONS] REPPKGURL

Generates the source RPM (.srpm) file of a given package.

Options:
    -c         Use files in current/ directory (default)
    -p         Use files in pristine/ directory
    -v VER     Use files from the version specified by VER (e.g. 2.2.1-2cl)
    -r REV     Use files from current directory, in revision REV (e.g. 1001)
    -t DIR     Put SRPM file in directory DIR when done (default is ".")
    -P USER    Define the RPM packager information to USER
    -s FILE    Run script with "FILE TOPDIR SPECFILE" command
    -n         Rename the package to include the revision number
    -l         Use subversion log to build rpm %changelog
    -T FILE    Template to be used to generate the %changelog
    -F         Do not use full name & email for packagers in %changelog
    -M         Do not use the mirror (use the main repository)
    -h         Show this message
    --strict   Check if the given revision contains changes in REPPKGURL

Examples:
    mgarepo getsrpm python
    mgarepo getsrpm -l python
    mgarepo getsrpm http://foo.bar/svn/cnc/snapshot/python
    mgarepo getsrpm -p http://foo.bar/svn/cnc/releases/8cl/python
    mgarepo getsrpm -r 1001 file:///svn/cnc/snapshot/python
"""

def mode_callback(option, opt, val, parser, mode):
    opts = parser.values
    opts.mode = mode
    if mode == "version":
        try:
            opts.version, opts.release = val.split("-", 1)
        except ValueError:
            raise Error("wrong version, use something like 2.2-1mdk")
    elif mode == "revision":
        opts.revision = val

def parse_options():
    parser = OptionParser(help=HELP)
    parser.defaults["mode"] = "current"
    parser.defaults["version"] = None
    parser.defaults["release"] = None
    parser.defaults["revision"] = None
    parser.defaults["submit"] = False
    callback_options = dict(action="callback", callback=mode_callback,
                            type="string", dest="__ignore")
    parser.add_option("-c", callback_kwargs={"mode": "current"}, nargs=0,
                      **callback_options)
    parser.add_option("-p", callback_kwargs={"mode": "pristine"}, nargs=0,
                      **callback_options)
    parser.add_option("-r", callback_kwargs={"mode": "revision"}, nargs=1,
                      **callback_options)
    parser.add_option("-v", callback_kwargs={"mode": "version"}, nargs=1,
                      **callback_options)
    parser.add_option("-t", dest="targetdirs", action="append", default=[])
    parser.add_option("-s", dest="scripts", action="append", default=[])
    parser.add_option("-P", dest="packager", default="")
    parser.add_option("-n", dest="revname", action="store_true")
    parser.add_option("-l", dest="svnlog", action="store_true")
    parser.add_option("-T", dest="template", type="string", default=None)
    parser.add_option("-F", dest="fullnames", default=True,
            action="store_false")
    parser.add_option("-M", "--no-mirror", action="callback",
            callback=disable_mirror)
    parser.add_option("--strict", dest="strict", default=False,
            action="store_true")
    opts, args = parser.parse_args()
    del opts.__ignore
    if len(args) != 1:
        raise Error("invalid arguments")
    opts.pkgdirurl = package_url(args[0])
    opts.verbose = 1
    return opts

def main():
    do_command(parse_options, get_srpm)

# vim:et:ts=4:sw=4