/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/xml7.py

  • Committer: Vincent Ladeuil
  • Date: 2008-11-21 16:43:53 UTC
  • mto: (3855.1.1 bzr.integration)
  • mto: This revision was merged to the branch mainline in revision 3856.
  • Revision ID: v.ladeuil+lp@free.fr-20081121164353-8d07go33ycibzbwl
Better fix for bug #300055.

* bzrlib/tests/test_log.py:
(TestGetViewRevisions.make_tree_with_many_merges): Hijack the
helper to test for revisions touching file on a more significant
tree.
(TestGetViewRevisions.test_file_id_for_range): Better test to
highlight bug #300055: starting revision is a dotted revno and the
log should start right there, not at the mainline revision where
merging occured. But that uncovers yet another bug...
(TestGetRevisionsTouchingFileID.assertAllRevisionsForFileID):
_filter_revisions_touching_file_id doesn't have a 'direction'
parameter anymore.

* bzrlib/tests/blackbox/test_log.py:
(TestCaseWithoutPropsHandler): Fix line too long.
(TestLog.test_log_with_tags,
TestLogMerges.test_merges_partial_range): Fix whitespaces.

* bzrlib/log.py:
(calculate_view_revisions): Delete gratuitous split line. Push
direction handling closer to the needed point. Delete 'direction'
parameter when calling _filter_revisions_touching_file_id.
(_filter_revisions_touching_file_id): Delete 'direction'
parameter. This was used for calling reverse_by_depth which can't
handle an already reversed list.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (C) 2006, 2007 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
from bzrlib import (
 
18
    inventory,
 
19
    xml6,
 
20
    )
 
21
 
 
22
 
 
23
class Serializer_v7(xml6.Serializer_v6):
 
24
    """A Serializer that supports tree references"""
 
25
 
 
26
    # this format is used by BzrBranch6
 
27
 
 
28
    supported_kinds = set(['file', 'directory', 'symlink', 'tree-reference'])
 
29
    format_num = '7'
 
30
 
 
31
    def _unpack_entry(self, elt):
 
32
        kind = elt.tag
 
33
        if not kind in self.supported_kinds:
 
34
            raise AssertionError('unsupported entry kind %s' % kind)
 
35
        if kind == 'tree-reference':
 
36
            file_id = elt.attrib['file_id']
 
37
            name = elt.attrib['name']
 
38
            parent_id = elt.attrib['parent_id']
 
39
            revision = elt.get('revision')
 
40
            reference_revision = elt.get('reference_revision')
 
41
            return inventory.TreeReference(file_id, name, parent_id, revision,
 
42
                                           reference_revision)
 
43
        else:
 
44
            return xml6.Serializer_v6._unpack_entry(self, elt)
 
45
 
 
46
serializer_v7 = Serializer_v7()