Do not use the pager when the output is empty
[stgit] / stgit / commands / show.py
CommitLineData
8847a11b
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
52f3900c 20from pydoc import pager
8847a11b
CM
21
22from stgit.commands.common import *
23from stgit import git
24
25
26help = 'show the commit corresponding to a patch (or the current patch)'
27usage = """%prog [options] [<patch>]
28
29Show the commit log and the diff corresponding to a given patch. The
30output is similar to that generated by the 'git show' command."""
31
32options = []
33
34
35def func(parser, options, args):
36 """Show commit log and diff
37 """
38 if len(args) == 0:
39 patch = 'HEAD'
40 elif len(args) == 1:
41 patch = args[0]
42 else:
43 parser.error('incorrect number of arguments')
44
45 commit_id = git_id(patch)
fdf4cb43
CM
46 commit_str = git.pretty_commit(commit_id)
47 if commit_str:
48 pager(commit_str)