~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/status.py

  • Committer: Robert Collins
  • Date: 2005-08-23 06:52:09 UTC
  • mto: (974.1.50) (1185.1.10) (1092.3.1)
  • mto: This revision was merged to the branch mainline in revision 1139.
  • Revision ID: robertc@robertcollins.net-20050823065209-81cd5962c401751b
move io redirection into each test case from the global runner

Show diffs side-by-side

added added

removed removed

Lines of Context:
18
18
 
19
19
def show_status(branch, show_unchanged=False,
20
20
                specific_files=None,
21
 
                show_ids=False):
 
21
                show_ids=False,
 
22
                to_file=None):
22
23
    """Display single-line status for non-ignored working files.
23
24
 
24
25
    show_all
26
27
 
27
28
    specific_files
28
29
        If set, only show the status of files in this list.
 
30
 
 
31
    to_file
 
32
        If set, write to this file (default stdout.)
29
33
    """
30
34
    import sys
31
 
    import diff
32
 
    
33
 
    branch._need_readlock()
34
 
    
35
 
    old = branch.basis_tree()
36
 
    new = branch.working_tree()
37
 
 
38
 
    delta = diff.compare_trees(old, new, want_unchanged=show_unchanged,
39
 
                               specific_files=specific_files)
40
 
 
41
 
    delta.show(sys.stdout, show_ids=show_ids,
42
 
               show_unchanged=show_unchanged)
43
 
 
44
 
    unknowns = new.unknowns()
45
 
    done_header = False
46
 
    for path in unknowns:
47
 
        # FIXME: Should also match if the unknown file is within a
48
 
        # specified directory.
49
 
        if specific_files:
50
 
            if path not in specific_files:
51
 
                continue
52
 
        if not done_header:
53
 
            print 'unknown:'
54
 
            done_header = True
55
 
        print ' ', path
 
35
    from bzrlib.delta import compare_trees
 
36
 
 
37
    if to_file == None:
 
38
        to_file = sys.stdout
 
39
    
 
40
    branch.lock_read()
 
41
    try:
 
42
 
 
43
        old = branch.basis_tree()
 
44
        new = branch.working_tree()
 
45
 
 
46
        delta = compare_trees(old, new, want_unchanged=show_unchanged,
 
47
                              specific_files=specific_files)
 
48
 
 
49
        delta.show(to_file,
 
50
                   show_ids=show_ids,
 
51
                   show_unchanged=show_unchanged)
 
52
 
 
53
        unknowns = new.unknowns()
 
54
        done_header = False
 
55
        for path in unknowns:
 
56
            # FIXME: Should also match if the unknown file is within a
 
57
            # specified directory.
 
58
            if specific_files:
 
59
                if path not in specific_files:
 
60
                    continue
 
61
            if not done_header:
 
62
                print >>to_file, 'unknown:'
 
63
                done_header = True
 
64
            print >>to_file, ' ', path
 
65
    finally:
 
66
        branch.unlock()
 
67