~bzr-pqm/bzr/bzr.dev

362 by Martin Pool
- Import stat-cache code
1
# (C) 2005 Canonical Ltd
2
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
465 by Martin Pool
- Move show_status() out of Branch into a new function in
18
19
def show_status(branch, show_unchanged=False,
483 by Martin Pool
- change 'file_list' to more explanatory 'specific_files'
20
                specific_files=None,
915 by Martin Pool
- add simple test case for bzr status
21
                show_ids=False,
974.1.48 by Aaron Bentley
Status command shows pending merges
22
                to_file=None,
23
                show_pending=True):
465 by Martin Pool
- Move show_status() out of Branch into a new function in
24
    """Display single-line status for non-ignored working files.
25
26
    show_all
27
        If true, show unmodified files too.
28
483 by Martin Pool
- change 'file_list' to more explanatory 'specific_files'
29
    specific_files
465 by Martin Pool
- Move show_status() out of Branch into a new function in
30
        If set, only show the status of files in this list.
915 by Martin Pool
- add simple test case for bzr status
31
32
    to_file
33
        If set, write to this file (default stdout.)
465 by Martin Pool
- Move show_status() out of Branch into a new function in
34
    """
35
    import sys
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
36
    from bzrlib.delta import compare_trees
915 by Martin Pool
- add simple test case for bzr status
37
38
    if to_file == None:
39
        to_file = sys.stdout
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
40
    
610 by Martin Pool
- replace Branch.lock(mode) with separate lock_read and lock_write
41
    branch.lock_read()
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
42
    try:
43
44
        old = branch.basis_tree()
45
        new = branch.working_tree()
46
47
        delta = compare_trees(old, new, want_unchanged=show_unchanged,
48
                              specific_files=specific_files)
49
915 by Martin Pool
- add simple test case for bzr status
50
        delta.show(to_file,
51
                   show_ids=show_ids,
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
52
                   show_unchanged=show_unchanged)
53
54
        unknowns = new.unknowns()
55
        done_header = False
56
        for path in unknowns:
57
            # FIXME: Should also match if the unknown file is within a
58
            # specified directory.
59
            if specific_files:
60
                if path not in specific_files:
61
                    continue
62
            if not done_header:
915 by Martin Pool
- add simple test case for bzr status
63
                print >>to_file, 'unknown:'
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
64
                done_header = True
915 by Martin Pool
- add simple test case for bzr status
65
            print >>to_file, ' ', path
974.1.48 by Aaron Bentley
Status command shows pending merges
66
        if show_pending and len(branch.pending_merges()) > 0:
67
            print >>to_file, 'pending merges:'
68
            for merge in branch.pending_merges():
69
                print >> to_file, ' ', merge
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
70
    finally:
71
        branch.unlock()
72