/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.217.1 by John Carr
Start stubbing out rewritten git-serve
1
# Copyright (C) 2008 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
0.200.292 by Jelmer Vernooij
Fix formatting.
17
import os
18
import tempfile
19
20
from bzrlib.repository import (
21
    Repository,
22
    )
23
24
from bzrlib.plugins.git.fetch import (
25
    import_git_objects,
26
    )
27
from bzrlib.plugins.git.mapping import (
28
    default_mapping,
29
    )
0.200.456 by Jelmer Vernooij
Fix git -> git fetching.
30
from bzrlib.plugins.git.object_store import (
0.200.485 by Jelmer Vernooij
Use ObjectStore to find revision SHA1s rather than 'simple' looups.
31
    get_object_store
0.200.456 by Jelmer Vernooij
Fix git -> git fetching.
32
    )
0.200.292 by Jelmer Vernooij
Fix formatting.
33
34
from dulwich.server import (
35
    Backend,
36
    )
37
from dulwich.pack import (
38
    Pack,
39
    PackData,
40
    write_pack_index_v2,
41
    )
42
0.217.32 by John Carr
Dirtyness to help pass tests
43
0.217.1 by John Carr
Start stubbing out rewritten git-serve
44
class BzrBackend(Backend):
45
0.217.2 by John Carr
Fix missing imports. Update TCPGitServer instantiation to latest. BzrBackend needs to know which directory its repo is in.
46
    def __init__(self, directory):
47
        self.directory = directory
0.217.7 by John Carr
Create tips
48
        self.mapping = default_mapping
0.217.2 by John Carr
Fix missing imports. Update TCPGitServer instantiation to latest. BzrBackend needs to know which directory its repo is in.
49
0.217.1 by John Carr
Start stubbing out rewritten git-serve
50
    def get_refs(self):
51
        """ return a dict of all tags and branches in repository (and shas) """
0.217.12 by John Carr
Support ls-remote against bazaar
52
        ret = {}
53
        repo_dir = BzrDir.open(self.directory)
54
        repo = repo_dir.open_repository()
0.200.485 by Jelmer Vernooij
Use ObjectStore to find revision SHA1s rather than 'simple' looups.
55
        store = get_object_store(repo)
0.217.52 by John Carr
Have a head, any head
56
        branch = None
0.217.12 by John Carr
Support ls-remote against bazaar
57
        for branch in repo.find_branches(using=True):
0.217.52 by John Carr
Have a head, any head
58
            #FIXME: Look for 'master' or 'trunk' in here, and set HEAD accordingly...
0.217.12 by John Carr
Support ls-remote against bazaar
59
            #FIXME: Need to get branch path relative to its repository and use this instead of nick
0.200.485 by Jelmer Vernooij
Use ObjectStore to find revision SHA1s rather than 'simple' looups.
60
            ret["refs/heads/"+branch.nick] = store._lookup_revision_sha1(branch.last_revision())
0.217.52 by John Carr
Have a head, any head
61
        if 'HEAD' not in ret and branch:
0.200.485 by Jelmer Vernooij
Use ObjectStore to find revision SHA1s rather than 'simple' looups.
62
            ret['HEAD'] = store._lookup_revision_sha1(branch.last_revision())
0.217.12 by John Carr
Support ls-remote against bazaar
63
        return ret
0.217.1 by John Carr
Start stubbing out rewritten git-serve
64
65
    def apply_pack(self, refs, read):
66
        """ apply pack from client to current repository """
0.217.4 by John Carr
Easy bits of git pushing to bazaar
67
0.217.8 by John Carr
Don't bother using InterRepo, use import_git_objects directly. Don't need a full repository (just operating on a pack and index)
68
        fd, path = tempfile.mkstemp(suffix=".pack")
69
        f = os.fdopen(fd, 'w')
0.217.6 by John Carr
Fix typos
70
        f.write(read())
0.217.5 by John Carr
Add a temporary hack to test pushing form git to bazaar
71
        f.close()
0.217.8 by John Carr
Don't bother using InterRepo, use import_git_objects directly. Don't need a full repository (just operating on a pack and index)
72
73
        p = PackData(path)
74
        entries = p.sorted_entries()
75
        write_pack_index_v2(path[:-5]+".idx", entries, p.calculate_checksum())
76
77
        def get_objects():
78
            pack = Pack(path[:-5])
79
            for obj in pack.iterobjects():
80
                yield obj
81
82
        target = Repository.open(self.directory)
83
84
        target.lock_write()
0.217.4 by John Carr
Easy bits of git pushing to bazaar
85
        try:
0.217.8 by John Carr
Don't bother using InterRepo, use import_git_objects directly. Don't need a full repository (just operating on a pack and index)
86
            target.start_write_group()
87
            try:
88
                import_git_objects(target, self.mapping, iter(get_objects()))
89
            finally:
90
                target.commit_write_group()
0.217.4 by John Carr
Easy bits of git pushing to bazaar
91
        finally:
0.217.8 by John Carr
Don't bother using InterRepo, use import_git_objects directly. Don't need a full repository (just operating on a pack and index)
92
            target.unlock()
0.217.4 by John Carr
Easy bits of git pushing to bazaar
93
0.217.7 by John Carr
Create tips
94
        for oldsha, sha, ref in refs:
95
            if ref[:11] == 'refs/heads/':
96
                branch_nick = ref[11:]
97
98
                try:
99
                    target_dir = BzrDir.open(self.directory + "/" + branch_nick)
100
                except:
101
                    target_dir = BzrDir.create(self.directory + "/" + branch_nick)
102
103
                try:
104
                    target_branch = target_dir.open_branch()
105
                except:
106
                    target_branch = target_dir.create_branch()
0.217.22 by John Carr
Fix whitespace
107
0.217.7 by John Carr
Create tips
108
                rev_id = self.mapping.revision_id_foreign_to_bzr(sha)
0.217.22 by John Carr
Fix whitespace
109
                target_branch.generate_revision_history(rev_id)
0.217.7 by John Carr
Create tips
110
0.217.1 by John Carr
Start stubbing out rewritten git-serve
111
    def fetch_objects(self, determine_wants, graph_walker, progress):
112
        """ yield git objects to send to client """
0.200.212 by Jelmer Vernooij
Move conversion functions to mapping, use fetch_objects() from repository if present.
113
        repo = Repository.open(self.directory)
114
115
        # If this is a Git repository, just use the existing fetch_objects implementation.
0.200.442 by Jelmer Vernooij
Fix trivial bug checking for git repositories.
116
        if getattr(repo, "fetch_objects", None) is not None:
0.200.226 by Jelmer Vernooij
Merge thin-pack work.
117
            return repo.fetch_objects(determine_wants, graph_walker, None, progress)
0.200.212 by Jelmer Vernooij
Move conversion functions to mapping, use fetch_objects() from repository if present.
118
0.217.12 by John Carr
Support ls-remote against bazaar
119
        wants = determine_wants(self.get_refs())
0.200.188 by Jelmer Vernooij
Merge dulwich.
120
0.217.14 by John Carr
Negotiate which revisions need to be sent to client, and iterate over them all
121
        repo.lock_read()
122
        try:
0.200.454 by Jelmer Vernooij
Use ObjectStore.find_missing_objects in server.
123
            store = BazaarObjectStore(repo)
0.200.486 by Jelmer Vernooij
Fix NameError.
124
            have = store.find_missing_revisions(graph_walker)
125
            missing_sha1s = store.find_missing_objects(have, wants, progress)
126
            return self.object_store.iter_shas(missing_sha1s)
0.217.14 by John Carr
Negotiate which revisions need to be sent to client, and iterate over them all
127
        finally:
128
            repo.unlock()