Signed-off-by: Catalin Marinas <catalin.marinas@gmail.com>
-Copyright (C) 2007, Catalin Marinas <catalin.marinas@gmail.com>
+Copyright (C) 2009, Catalin Marinas <catalin.marinas@gmail.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License version 2 as
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
"""
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
"""
+from stgit.commands import common
+from stgit.lib import transaction
+from stgit import argparse
from stgit.argparse import opt
from stgit.argparse import opt
-from stgit.commands.common import *
-from stgit.utils import *
-from stgit.out import *
-from stgit import argparse, stack, git
help = 'Unhide a hidden patch'
kind = 'stack'
help = 'Unhide a hidden patch'
kind = 'stack'
opt('-b', '--branch', args = [argparse.stg_branches],
short = 'Use BRANCH instead of the default branch')]
opt('-b', '--branch', args = [argparse.stg_branches],
short = 'Use BRANCH instead of the default branch')]
-directory = DirectoryHasRepository(log = True)
+directory = common.DirectoryHasRepositoryLib()
def func(parser, options, args):
def func(parser, options, args):
- """Unhide a range of patches in the series
- """
- if args:
- # parsing all the patches for a more meaningful error reporting
- all_patches = crt_series.get_applied() + crt_series.get_unapplied() \
- + crt_series.get_hidden()
- patches = parse_patches(args, all_patches)
- else:
+ """Unhide a range of patch in the series."""
+ stack = directory.repository.current_stack
+ trans = transaction.StackTransaction(stack, 'hide')
+
+ if not args:
parser.error('No patches specified')
parser.error('No patches specified')
- for patch in patches:
- crt_series.unhide_patch(patch)
- out.info('Patch "%s" unhidden' % patch)
+ patches = common.parse_patches(args, trans.all_patches)
+ for p in patches:
+ if not p in trans.hidden:
+ raise common.CmdException('Patch "%s" not hidden' % p)
+
+ applied = list(trans.applied)
+ unapplied = trans.unapplied + patches
+ hidden = [p for p in trans.hidden if not p in set(patches)]
+
+ trans.reorder_patches(applied, unapplied, hidden)
+ return trans.run()