Add support for initializing a branch for stgit from Emacs.
[stgit] / stgit / commands / diff.py
CommitLineData
fcee87cf
CM
1
2__copyright__ = """
3Copyright (C) 2005, Catalin Marinas <catalin.marinas@gmail.com>
4
5This program is free software; you can redistribute it and/or modify
6it under the terms of the GNU General Public License version 2 as
7published by the Free Software Foundation.
8
9This program is distributed in the hope that it will be useful,
10but WITHOUT ANY WARRANTY; without even the implied warranty of
11MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12GNU General Public License for more details.
13
14You should have received a copy of the GNU General Public License
15along with this program; if not, write to the Free Software
16Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17"""
18
19import sys, os
20from optparse import OptionParser, make_option
52f3900c 21from pydoc import pager
fcee87cf
CM
22
23from stgit.commands.common import *
24from stgit.utils import *
5e888f30 25from stgit.out import *
20a52e06 26from stgit import argparse, stack, git
fcee87cf
CM
27
28help = 'show the tree diff'
d4356ac6 29usage = """%prog [options] [<files or dirs>]
fcee87cf 30
26aab5b0 31Show the diff (default) or diffstat between the current working copy
e4560d7e
CM
32or a tree-ish object and another tree-ish object (defaulting to HEAD).
33File names can also be given to restrict the diff output. The
34tree-ish object can be an StGIT patch, a standard git commit, tag or
35tree. In addition to these, the command also supports '{base}',
36representing the bottom of the current stack.
26aab5b0 37
e4560d7e
CM
38rev = '[branch:](<patch>|{base}) | <tree-ish>'
39"""
fcee87cf 40
6dd8fafa 41directory = DirectoryHasRepository()
ebbd6f00
CM
42options = [make_option('-r', '--range',
43 metavar = 'rev1[..[rev2]]', dest = 'revs',
fcee87cf
CM
44 help = 'show the diff between revisions'),
45 make_option('-s', '--stat',
46 help = 'show the stat instead of the diff',
0b635fe6 47 action = 'store_true')
20a52e06 48 ] + argparse.diff_opts_option()
fcee87cf
CM
49
50def func(parser, options, args):
51 """Show the tree diff
52 """
d4356ac6
CM
53 args = git.ls_files(args)
54 directory.cd_to_topdir()
55
fcee87cf 56 if options.revs:
6b1e0111 57 rev_list = options.revs.split('..')
fcee87cf
CM
58 rev_list_len = len(rev_list)
59 if rev_list_len == 1:
e4560d7e
CM
60 rev1 = rev_list[0]
61 rev2 = None
fcee87cf
CM
62 elif rev_list_len == 2:
63 rev1 = rev_list[0]
64 rev2 = rev_list[1]
fcee87cf
CM
65 else:
66 parser.error('incorrect parameters to -r')
67 else:
68 rev1 = 'HEAD'
69 rev2 = None
70
a45cea15 71 diff_str = git.diff(args, git_id(crt_series, rev1),
e4560d7e 72 rev2 and git_id(crt_series, rev2),
a45cea15 73 diff_flags = options.diff_flags)
fcee87cf 74 if options.stat:
a45cea15 75 out.stdout_raw(git.diffstat(diff_str) + '\n')
fcee87cf 76 else:
fdf4cb43
CM
77 if diff_str:
78 pager(diff_str)