chiark / gitweb /
Allow StGIT commands to run correctly in subdirectories
[stgit] / stgit / commands / status.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
21
22from stgit.commands.common import *
23from stgit.utils import *
24from stgit import stack, git
25
26
27help = 'show the tree status'
d4356ac6 28usage = """%prog [options] [<files or dirs>]
26aab5b0
CM
29
30Show the status of the whole working copy or the given files. The
31command also shows the files in the current directory which are not
32under revision control. The files are prefixed as follows:
33
34 M - locally modified
35 N - newly added to the repository
36 D - deleted from the repository
37 C - conflict
38 ? - unknown
39
40A 'refresh' command clears the status of the modified, new and deleted
41files."""
fcee87cf 42
6dd8fafa 43directory = DirectoryHasRepository()
fcee87cf
CM
44options = [make_option('-m', '--modified',
45 help = 'show modified files only',
46 action = 'store_true'),
47 make_option('-n', '--new',
48 help = 'show new files only',
49 action = 'store_true'),
50 make_option('-d', '--deleted',
51 help = 'show deleted files only',
52 action = 'store_true'),
53 make_option('-c', '--conflict',
54 help = 'show conflict files only',
55 action = 'store_true'),
56 make_option('-u', '--unknown',
57 help = 'show unknown files only',
4d4c0e3a
PBG
58 action = 'store_true'),
59 make_option('-x', '--noexclude',
60 help = 'do not exclude any files from listing',
94227db3 61 action = 'store_true'),
2ace36ab
YD
62 make_option('-O', '--diff-opts',
63 help = 'options to pass to git-diff'),
94227db3
CM
64 make_option('--reset',
65 help = 'reset the current tree changes',
fcee87cf
CM
66 action = 'store_true')]
67
68
4361d795
DK
69def status(files = None, modified = False, new = False, deleted = False,
70 conflict = False, unknown = False, noexclude = False,
71 diff_flags = []):
72 """Show the tree status
73 """
74 cache_files = git.tree_status(files,
d4356ac6 75 unknown = (not files),
4361d795
DK
76 noexclude = noexclude,
77 diff_flags = diff_flags)
78 filtered = (modified or new or deleted or conflict or unknown)
79
80 if filtered:
81 filestat = []
82 if modified:
83 filestat.append('M')
84 if new:
85 filestat.append('A')
86 filestat.append('N')
87 if deleted:
88 filestat.append('D')
89 if conflict:
90 filestat.append('C')
91 if unknown:
92 filestat.append('?')
93 cache_files = [x for x in cache_files if x[0] in filestat]
94
cbd2f5f3
KH
95 output = []
96 for st, fn in cache_files:
cbd2f5f3
KH
97 if filtered:
98 output.append(fn)
4361d795 99 else:
cbd2f5f3
KH
100 output.append('%s %s' % (st, fn))
101 for o in sorted(output):
102 out.stdout(o)
4361d795 103
fcee87cf
CM
104def func(parser, options, args):
105 """Show the tree status
106 """
d4356ac6
CM
107 args = git.ls_files(args)
108 directory.cd_to_topdir()
109
94227db3 110 if options.reset:
49e316b9
CM
111 if args:
112 for f in args:
113 resolved(f)
114 git.reset(args)
115 else:
116 resolved_all()
117 git.reset()
94227db3 118 else:
2ace36ab
YD
119 if options.diff_opts:
120 diff_flags = options.diff_opts.split()
121 else:
122 diff_flags = []
123
4361d795
DK
124 status(args, options.modified, options.new, options.deleted,
125 options.conflict, options.unknown, options.noexclude,
126 diff_flags = diff_flags)