chiark / gitweb /
Infrastructure for current directory handling
[stgit] / stgit / commands / goto.py
CommitLineData
994fdba7
CM
1__copyright__ = """
2Copyright (C) 2006, 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
19from optparse import OptionParser, make_option
20
21from stgit.commands.common import *
22from stgit.utils import *
23from stgit import stack, git
24
25
26help = 'push or pop patches to the given one'
27usage = """%prog [options] <name>
28
29Push/pop patches to/from the stack until the one given on the command
30line becomes current. This is a shortcut for the 'push --to' or 'pop
31--to' commands. There is no '--undo' option for 'goto'. Use the 'push'
32command for this."""
33
6dd8fafa 34directory = DirectoryHasRepository()
a6758682
CM
35options = [make_option('-k', '--keep',
36 help = 'keep the local changes when popping patches',
37 action = 'store_true')]
994fdba7
CM
38
39
40def func(parser, options, args):
41 """Pushes the given patch or all onto the series
42 """
43 if len(args) != 1:
44 parser.error('incorrect number of arguments')
45
994fdba7
CM
46 check_conflicts()
47 check_head_top_equal()
48
a6758682
CM
49 if not options.keep:
50 check_local_changes()
51
994fdba7 52 applied = crt_series.get_applied()
994fdba7
CM
53 unapplied = crt_series.get_unapplied()
54 patch = args[0]
55
56 if patch in applied:
2cf7e94e 57 applied.reverse()
994fdba7 58 patches = applied[:applied.index(patch)]
a6758682 59 pop_patches(patches, options.keep)
994fdba7 60 elif patch in unapplied:
a6758682
CM
61 if options.keep:
62 raise CmdException, 'Cannot use --keep with patch pushing'
994fdba7
CM
63 patches = unapplied[:unapplied.index(patch)+1]
64 push_patches(patches)
65 else:
66 raise CmdException, 'Patch "%s" does not exist' % patch
67
68 print_crt_patch()