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

  • Committer: Jelmer Vernooij
  • Date: 2009-03-28 22:27:07 UTC
  • mto: (0.200.305 trunk)
  • mto: This revision was merged to the branch mainline in revision 6960.
  • Revision ID: jelmer@samba.org-20090328222707-n0y980ntev40xqd2
Fix blob lookup.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2007-2008 Canonical Ltd
 
1
# Copyright (C) 2007 Canonical Ltd
 
2
# Copyright (C) 2008-2009 Jelmer Vernooij <jelmer@samba.org>
 
3
# Copyright (C) 2008 John Carr
2
4
#
3
5
# This program is free software; you can redistribute it and/or modify
4
6
# it under the terms of the GNU General Public License as published by
16
18
 
17
19
"""Converters, etc for going between Bazaar and Git ids."""
18
20
 
19
 
from bzrlib import errors, foreign, urlutils
20
 
from bzrlib.inventory import ROOT_ID
 
21
from bzrlib import (
 
22
    errors,
 
23
    foreign,
 
24
    urlutils,
 
25
    )
 
26
from bzrlib.inventory import (
 
27
    ROOT_ID,
 
28
    )
21
29
from bzrlib.foreign import (
22
 
        ForeignVcs, 
23
 
        VcsMappingRegistry, 
24
 
        ForeignRevision,
25
 
        )
 
30
    ForeignVcs, 
 
31
    VcsMappingRegistry, 
 
32
    ForeignRevision,
 
33
    )
26
34
 
27
35
def escape_file_id(file_id):
28
36
    return file_id.replace('_', '__').replace(' ', '_s')
55
63
        return bzr_rev_id[len(cls.revid_prefix)+1:], cls()
56
64
 
57
65
    def generate_file_id(self, path):
 
66
        # Git paths are just bytestrings
 
67
        # We must just hope they are valid UTF-8..
 
68
        assert isinstance(path, str)
58
69
        if path == "":
59
70
            return ROOT_ID
60
 
        return escape_file_id(path.encode('utf-8'))
 
71
        return escape_file_id(path)
 
72
 
 
73
    def parse_file_id(self, file_id):
 
74
        if file_id == ROOT_ID:
 
75
            return ""
 
76
        return unescape_file_id(file_id)
61
77
 
62
78
    def import_commit(self, commit):
63
79
        """Convert a git commit to a bzr revision.
133
149
 
134
150
    # stack contains the set of trees that we haven't 
135
151
    # finished constructing
136
 
 
137
152
    for path, entry in inv.iter_entries():
138
153
        while stack and not path.startswith(cur):
139
154
            tree.serialize()
187
202
    for p in rev.parent_ids:
188
203
        git_p = parent_lookup(p)
189
204
        if git_p is not None:
 
205
            assert len(git_p) == 40, "unexpected length for %r" % git_p
190
206
            commit._parents.append(git_p)
191
207
    commit._message = rev.message.encode("utf-8")
192
208
    commit._committer = rev.committer.encode("utf-8")
193
 
    commit._author = rev.get_apparent_author().encode("utf-8")
 
209
    commit._author = rev.get_apparent_authors()[0].encode("utf-8")
194
210
    commit._commit_time = long(rev.timestamp)
195
211
    commit.serialize()
196
212
    return commit