/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/status.py

  • Committer: Alexander Belchenko
  • Date: 2007-10-26 21:49:15 UTC
  • mto: (2947.4.2 0.92)
  • mto: This revision was merged to the branch mainline in revision 2971.
  • Revision ID: bialix@ukr.net-20071026214915-5eacqh9k2ps6jagj
windows python-based installer: shortcut for uninstall action

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2006 Canonical Ltd
 
1
# Copyright (C) 2005, 2006, 2007 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
16
16
 
17
17
import sys
18
18
 
 
19
from bzrlib import (
 
20
    delta as _mod_delta,
 
21
    tree,
 
22
    )
19
23
from bzrlib.diff import _raise_if_nonexistent
20
24
import bzrlib.errors as errors
21
25
from bzrlib.log import line_log
22
26
from bzrlib.osutils import is_inside_any
23
27
from bzrlib.symbol_versioning import (deprecated_function,
24
 
        zero_eight,
25
28
        )
 
29
from bzrlib.trace import warning
26
30
 
27
31
# TODO: when showing single-line logs, truncate to the width of the terminal
28
32
# if known, but only if really going to the terminal (not into a file)
29
33
 
30
34
 
31
 
@deprecated_function(zero_eight)
32
 
def show_status(branch, show_unchanged=None,
33
 
                specific_files=None,
34
 
                show_ids=False,
35
 
                to_file=None,
36
 
                show_pending=True,
37
 
                revision=None):
38
 
    """Display summary of changes.
39
 
 
40
 
    Please use show_tree_status instead.
41
 
 
42
 
    By default this compares the working tree to a previous revision. 
43
 
    If the revision argument is given, summarizes changes between the 
44
 
    working tree and another, or between two revisions.
45
 
 
46
 
    The result is written out as Unicode and to_file should be able 
47
 
    to encode that.
48
 
 
49
 
    show_unchanged
50
 
        If set, includes unchanged files.
51
 
 
52
 
    specific_files
53
 
        If set, only show the status of files in this list.
54
 
 
55
 
    show_ids
56
 
        If set, includes each file's id.
57
 
 
58
 
    to_file
59
 
        If set, write to this file (default stdout.)
60
 
 
61
 
    show_pending
62
 
        If set, write pending merges.
63
 
 
64
 
    revision
65
 
        If None the compare latest revision with working tree
66
 
        If one revision show compared it with working tree.
67
 
        If two revisions show status between first and second.
68
 
    """
69
 
    show_tree_status(branch.bzrdir.open_workingtree(), show_unchanged, 
70
 
                     specific_files, show_ids, to_file, show_pending, revision)
71
 
 
72
 
 
73
35
def show_tree_status(wt, show_unchanged=None,
74
36
                     specific_files=None,
75
37
                     show_ids=False,
76
38
                     to_file=None,
77
39
                     show_pending=True,
78
 
                     revision=None):
 
40
                     revision=None,
 
41
                     short=False,
 
42
                     versioned=False):
79
43
    """Display summary of changes.
80
44
 
81
45
    By default this compares the working tree to a previous revision. 
100
64
        If not None it must be a RevisionSpec list.
101
65
        If one revision show compared it with working tree.
102
66
        If two revisions show status between first and second.
 
67
    :param short: If True, gives short SVN-style status lines.
 
68
    :param versioned: If True, only shows versioned files.
103
69
    """
104
70
    if show_unchanged is not None:
105
71
        warn("show_status_trees with show_unchanged has been deprecated "
112
78
    try:
113
79
        new_is_working_tree = True
114
80
        if revision is None:
 
81
            if wt.last_revision() != wt.branch.last_revision():
 
82
                warning("working tree is out of date, run 'bzr update'")
115
83
            new = wt
116
84
            old = new.basis_tree()
117
85
        elif len(revision) > 0:
129
97
                    raise errors.BzrCommandError(str(e))
130
98
            else:
131
99
                new = wt
132
 
        _raise_if_nonexistent(specific_files, old, new)
133
 
        delta = new.changes_from(old, want_unchanged=show_unchanged,
134
 
                              specific_files=specific_files)
135
 
        delta.show(to_file,
136
 
                   show_ids=show_ids,
137
 
                   show_unchanged=show_unchanged)
138
 
 
139
 
        list_paths('unknown', new.unknowns(), specific_files, to_file)
140
 
        conflict_title = False
141
 
        # show the new conflicts only for now. XXX: get them from the delta.
142
 
        for conflict in new.conflicts():
143
 
            if conflict_title is False:
144
 
                print >> to_file, "conflicts:"
145
 
                conflict_title = True
146
 
            print >> to_file, "  %s" % conflict
147
 
        if new_is_working_tree and show_pending:
148
 
            show_pending_merges(new, to_file)
 
100
        old.lock_read()
 
101
        new.lock_read()
 
102
        try:
 
103
            _raise_if_nonexistent(specific_files, old, new)
 
104
            want_unversioned = not versioned
 
105
            if short:
 
106
                changes = new._iter_changes(old, show_unchanged, specific_files,
 
107
                    require_versioned=False, want_unversioned=want_unversioned)
 
108
                reporter = _mod_delta._ChangeReporter(output_file=to_file,
 
109
                    unversioned_filter=new.is_ignored)
 
110
                _mod_delta.report_changes(changes, reporter)
 
111
            else:
 
112
                delta = new.changes_from(old, want_unchanged=show_unchanged,
 
113
                                      specific_files=specific_files,
 
114
                                      want_unversioned=want_unversioned)
 
115
                # filter out unknown files. We may want a tree method for
 
116
                # this
 
117
                delta.unversioned = [unversioned for unversioned in
 
118
                    delta.unversioned if not new.is_ignored(unversioned[0])]
 
119
                delta.show(to_file,
 
120
                           show_ids=show_ids,
 
121
                           show_unchanged=show_unchanged,
 
122
                           short_status=False)
 
123
            # show the new conflicts only for now. XXX: get them from the
 
124
            # delta.
 
125
            conflicts = new.conflicts()
 
126
            if specific_files is not None:
 
127
                conflicts = conflicts.select_conflicts(new, specific_files,
 
128
                    ignore_misses=True, recurse=True)[1]
 
129
            if len(conflicts) > 0 and not short:
 
130
                to_file.write("conflicts:\n")
 
131
            for conflict in conflicts:
 
132
                if short:
 
133
                    prefix = 'C  '
 
134
                else:
 
135
                    prefix = ' '
 
136
                to_file.write("%s %s\n" % (prefix, conflict))
 
137
            if new_is_working_tree and show_pending:
 
138
                show_pending_merges(new, to_file, short)
 
139
        finally:
 
140
            old.unlock()
 
141
            new.unlock()
149
142
    finally:
150
143
        wt.unlock()
151
144
 
152
 
def show_pending_merges(new, to_file):
 
145
def show_pending_merges(new, to_file, short=False):
153
146
    """Write out a display of pending merges in a working tree."""
154
147
    parents = new.get_parent_ids()
155
148
    if len(parents) < 2:
157
150
    pending = parents[1:]
158
151
    branch = new.branch
159
152
    last_revision = parents[0]
160
 
    print >>to_file, 'pending merges:'
 
153
    if not short:
 
154
        to_file.write('pending merges:\n')
161
155
    if last_revision is not None:
162
156
        try:
163
 
            ignore = set(branch.repository.get_ancestry(last_revision))
 
157
            ignore = set(branch.repository.get_ancestry(last_revision,
 
158
                                                        topo_sorted=False))
164
159
        except errors.NoSuchRevision:
165
160
            # the last revision is a ghost : assume everything is new 
166
161
            # except for it
175
170
            from bzrlib.osutils import terminal_width
176
171
            width = terminal_width()
177
172
            m_revision = branch.repository.get_revision(merge)
178
 
            print >> to_file, ' ', line_log(m_revision, width - 3)
 
173
            if short:
 
174
                prefix = 'P  '
 
175
            else:
 
176
                prefix = ' '
 
177
            to_file.write(prefix + ' ' + line_log(m_revision, width - 4))
 
178
            to_file.write('\n')
179
179
            inner_merges = branch.repository.get_ancestry(merge)
180
180
            assert inner_merges[0] is None
181
181
            inner_merges.pop(0)
184
184
                if mmerge in ignore:
185
185
                    continue
186
186
                mm_revision = branch.repository.get_revision(mmerge)
187
 
                print >> to_file, '   ', line_log(mm_revision, width - 5)
 
187
                if short:
 
188
                    prefix = 'P.  '
 
189
                else:
 
190
                    prefix = '   '
 
191
                to_file.write(prefix + ' ' + line_log(mm_revision, width - 5))
 
192
                to_file.write('\n')
188
193
                ignore.add(mmerge)
189
194
        except errors.NoSuchRevision:
190
 
            print >> to_file, ' ', merge
191
 
        
192
 
def list_paths(header, paths, specific_files, to_file):
193
 
    done_header = False
194
 
    for path in paths:
195
 
        if specific_files and not is_inside_any(specific_files, path):
196
 
            continue
197
 
        if not done_header:
198
 
            print >>to_file, '%s:' % header
199
 
            done_header = True
200
 
        print >>to_file, ' ', path
 
195
            if short:
 
196
                prefix = 'P  '
 
197
            else:
 
198
                prefix = ' '
 
199
            to_file.write(prefix + ' ' + merge)
 
200
            to_file.write('\n')