Strip leading or trailing '-' when generating patch names
[stgit] / stgit / commands / fold.py
CommitLineData
c14444b9
CM
1__copyright__ = """
2Copyright (C) 2005, Catalin Marinas <catalin.marinas@gmail.com>
3
4This program is free software; you can redistribute it and/or modify
5it under the terms of the GNU General Public License version 2 as
6published by the Free Software Foundation.
7
8This program is distributed in the hope that it will be useful,
9but WITHOUT ANY WARRANTY; without even the implied warranty of
10MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11GNU General Public License for more details.
12
13You should have received a copy of the GNU General Public License
14along with this program; if not, write to the Free Software
15Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16"""
17
18import sys, os
575bbdae 19from stgit.argparse import opt
c14444b9
CM
20from stgit.commands.common import *
21from stgit.utils import *
5e888f30 22from stgit.out import *
6c8a90e1 23from stgit import argparse, stack, git
c14444b9 24
575bbdae 25help = 'Integrate a GNU diff patch into the current patch'
33ff9cdd 26kind = 'patch'
54239abf 27usage = ['[options] [--] [<file>]']
575bbdae 28description = """
c14444b9
CM
29Apply the given GNU diff file (or the standard input) onto the top of
30the current patch. With the '--threeway' option, the patch is applied
d4b8d284 31onto the bottom of the current patch and a three-way merge is
84fcbc3b
CM
32performed with the current top. With the --base option, the patch is
33applied onto the specified base and a three-way merged is performed
34with the current top."""
c14444b9 35
6c8a90e1 36args = [argparse.files]
575bbdae
KH
37options = [
38 opt('-t', '--threeway', action = 'store_true',
39 short = 'Perform a three-way merge with the current patch'),
6c8a90e1 40 opt('-b', '--base', args = [argparse.commit],
b0bff932 41 short = 'Use BASE instead of HEAD when applying the patch'),
ca5c9651
CM
42 opt('-p', '--strip', type = 'int', metavar = 'N',
43 short = 'Remove N leading slashes from diff paths (default 1)'),
b0bff932
CM
44 opt('--reject', action = 'store_true',
45 short = 'Leave the rejected hunks in corresponding *.rej files')]
c14444b9 46
117ed129 47directory = DirectoryHasRepository(log = True)
c14444b9
CM
48
49def func(parser, options, args):
50 """Integrate a GNU diff patch into the current patch
51 """
52 if len(args) > 1:
53 parser.error('incorrect number of arguments')
54
55 check_local_changes()
56 check_conflicts()
6972fd6b 57 check_head_top_equal(crt_series)
c14444b9
CM
58
59 if len(args) == 1:
60 filename = args[0]
61 else:
62 filename = None
63
64 current = crt_series.get_current()
65 if not current:
66 raise CmdException, 'No patches applied'
67
68 if filename:
0a01a6d0 69 if os.path.exists(filename):
27ac2b7e 70 out.start('Folding patch "%s"' % filename)
0a01a6d0
CM
71 else:
72 raise CmdException, 'No such file: %s' % filename
c14444b9 73 else:
27ac2b7e 74 out.start('Folding patch from stdin')
c14444b9
CM
75
76 if options.threeway:
77 crt_patch = crt_series.get_patch(current)
78 bottom = crt_patch.get_bottom()
b0bff932 79 git.apply_patch(filename = filename, base = bottom,
ca5c9651 80 strip = options.strip, reject = options.reject)
84fcbc3b 81 elif options.base:
b0bff932 82 git.apply_patch(filename = filename, reject = options.reject,
ca5c9651 83 strip = options.strip,
6972fd6b 84 base = git_id(crt_series, options.base))
c14444b9 85 else:
ca5c9651
CM
86 git.apply_patch(filename = filename, strip = options.strip,
87 reject = options.reject)
c14444b9 88
27ac2b7e 89 out.done()