/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 apport/source_bzr.py

  • Committer: Vincent Ladeuil
  • Date: 2009-10-06 14:40:37 UTC
  • mto: (4728.1.2 integration)
  • mto: This revision was merged to the branch mainline in revision 4731.
  • Revision ID: v.ladeuil+lp@free.fr-20091006144037-o76rgosv9hj3td0y
Simplify mutable_tree.has_changes() and update call sites.

* bzrlib/workingtree.py:
(WorkingTree.merge_from_branch): Add a force parameter. Replace
the check_basis() call by the corresponding code, taken the new
'force' parameter into account.

* bzrlib/tests/test_status.py:
(TestStatus.make_multiple_pending_tree): Add force=True on
supplementary merges.

* bzrlib/tests/test_reconfigure.py:
(TestReconfigure): Add a test for pending merges.

* bzrlib/tests/test_msgeditor.py:
(MsgEditorTest.make_multiple_pending_tree): Add force=True on
supplementary merges.

* bzrlib/tests/blackbox/test_uncommit.py:
(TestUncommit.test_uncommit_octopus_merge): Add force=True on
supplementary merges.

* bzrlib/send.py:
(send): Use the simplified has_changes(). Fix typo in comment too.

* bzrlib/reconfigure.py:
(Reconfigure._check): Use the simplified has_changes().

* bzrlib/mutabletree.py:
(MutableTree.has_changes): Make the tree parameter optional but
retain it for tests. Add a pending merges check.

* bzrlib/merge.py:
(Merger.ensure_revision_trees, Merger.file_revisions,
Merger.check_basis, Merger.compare_basis): Deprecate.

* bzrlib/bundle/apply_bundle.py:
(merge_bundle): Replace the check_basis() call by the
corresponding code.

* bzrlib/builtins.py:
(cmd_remove_tree.run, cmd_push.run, cmd_merge.run): Use the
simplified has_changes().
(cmd_merge.run): Replace the check_basis call() by the corresponding
code (minus the alredy done has_changes() check).

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
'''apport package hook for Bazaar'''
2
 
 
3
 
# Copyright (c) 2009, 2010 Canonical Ltd.
4
 
# Author: Matt Zimmerman <mdz@canonical.com>
5
 
#         and others
6
 
 
7
 
from apport.hookutils import *
8
 
import os
9
 
 
10
 
bzr_log = os.path.expanduser('~/.bzr.log')
11
 
dot_bzr = os.path.expanduser('~/.bazaar')
12
 
 
13
 
def _add_log_tail(report):
14
 
    # may have already been added in-process
15
 
    if 'BzrLogTail' in report:
16
 
        return
17
 
 
18
 
    bzr_log_lines = open(bzr_log).readlines()
19
 
    bzr_log_lines.reverse()
20
 
 
21
 
    bzr_log_tail = []
22
 
    blanks = 0
23
 
    for line in bzr_log_lines:
24
 
        if line == '\n':
25
 
            blanks += 1
26
 
        bzr_log_tail.append(line)
27
 
        if blanks >= 2: 
28
 
            break
29
 
 
30
 
    bzr_log_tail.reverse()
31
 
    report['BzrLogTail'] = ''.join(bzr_log_tail)
32
 
 
33
 
 
34
 
def add_info(report):
35
 
    _add_log_tail(report)
36
 
    if 'BzrPlugins' not in report:
37
 
        # may already be present in-process
38
 
        report['BzrPlugins'] = command_output(['bzr', 'plugins', '-v'])
39
 
        
40
 
    # by default assume bzr crashes are upstream bugs; this relies on
41
 
    # having a bzr entry under /etc/apport/crashdb.conf.d/
42
 
    report['CrashDB'] = 'bzr'
43
 
 
44
 
    # these may contain some sensitive info (smtp_passwords)
45
 
    # TODO: strip that out and attach the rest
46
 
 
47
 
    #attach_file_if_exists(report,
48
 
    #   os.path.join(dot_bzr, 'bazaar.conf', 'BzrConfig')
49
 
    #attach_file_if_exists(report,
50
 
    #   os.path.join(dot_bzr, 'locations.conf', 'BzrLocations')
51
 
 
52
 
        
53
 
# vim: expandtab shiftwidth=4