~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):
1185.3.1 by Martin Pool
- docstring fix from Magnus Therning
24
    """Display status for non-ignored working files.
465 by Martin Pool
- Move show_status() out of Branch into a new function in
25
1185.3.1 by Martin Pool
- docstring fix from Magnus Therning
26
    show_unchanged
27
        If set, includes unchanged files.
465 by Martin Pool
- Move show_status() out of Branch into a new function in
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
1185.3.1 by Martin Pool
- docstring fix from Magnus Therning
32
    show_ids
33
        If set, includes each file's id.
34
915 by Martin Pool
- add simple test case for bzr status
35
    to_file
36
        If set, write to this file (default stdout.)
1185.3.1 by Martin Pool
- docstring fix from Magnus Therning
37
38
    show_pending
39
        If set, write pending merges.
465 by Martin Pool
- Move show_status() out of Branch into a new function in
40
    """
41
    import sys
974.1.26 by aaron.bentley at utoronto
merged mbp@sourcefrog.net-20050817233101-0939da1cf91f2472
42
    from bzrlib.delta import compare_trees
915 by Martin Pool
- add simple test case for bzr status
43
44
    if to_file == None:
45
        to_file = sys.stdout
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
46
    
610 by Martin Pool
- replace Branch.lock(mode) with separate lock_read and lock_write
47
    branch.lock_read()
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
48
    try:
49
50
        old = branch.basis_tree()
51
        new = branch.working_tree()
52
53
        delta = compare_trees(old, new, want_unchanged=show_unchanged,
54
                              specific_files=specific_files)
55
915 by Martin Pool
- add simple test case for bzr status
56
        delta.show(to_file,
57
                   show_ids=show_ids,
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
58
                   show_unchanged=show_unchanged)
59
60
        unknowns = new.unknowns()
61
        done_header = False
62
        for path in unknowns:
63
            # FIXME: Should also match if the unknown file is within a
64
            # specified directory.
65
            if specific_files:
66
                if path not in specific_files:
67
                    continue
68
            if not done_header:
915 by Martin Pool
- add simple test case for bzr status
69
                print >>to_file, 'unknown:'
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
70
                done_header = True
915 by Martin Pool
- add simple test case for bzr status
71
            print >>to_file, ' ', path
974.1.48 by Aaron Bentley
Status command shows pending merges
72
        if show_pending and len(branch.pending_merges()) > 0:
73
            print >>to_file, 'pending merges:'
74
            for merge in branch.pending_merges():
75
                print >> to_file, ' ', merge
580 by Martin Pool
- Use explicit lock methods on a branch, rather than doing it
76
    finally:
77
        branch.unlock()
78