/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 contrib/newinventory.py

  • Committer: John Arbash Meinel
  • Date: 2011-04-20 14:27:19 UTC
  • mto: This revision was merged to the branch mainline in revision 5837.
  • Revision ID: john@arbash-meinel.com-20110420142719-advs1k5vztqzbrgv
Fix bug #767177. Be more agressive with file.close() calls.

Our test suite gets a number of thread leaks and failures because it happens to get async
SFTPFile.close() calls. (if an SFTPFile closes due to __del__ it is done as an async request,
while if you call SFTPFile.close() it is done as a synchronous request.)
We have a couple other cases, probably. Namely SFTPTransport.get() also does an async
prefetch of the content, so if you don't .read() you'll also leak threads that think they
are doing work that you want.

The biggest change here, though, is using a try/finally in a generator, which is not 
python2.4 compatible.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# (C) 2005 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16
 
 
17
 
from bzrlib.xml import ElementTree, Element
18
 
 
19
 
 
20
 
def write_inventory(inv, f):
21
 
    el = Element('inventory', {'version': '2'})
22
 
    el.text = '\n'
23
 
 
24
 
    root = Element('root_directory', {'id': inv.root.file_id})
25
 
    root.tail = root.text = '\n'
26
 
    el.append(root)
27
 
 
28
 
    def descend(parent_el, ie):
29
 
        kind = ie.kind
30
 
        el = Element(kind, {'name': ie.name,
31
 
                            'id': ie.file_id,})
32
 
        
33
 
        if kind == 'file':
34
 
            if ie.text_id:
35
 
                el.set('text_id', ie.text_id)
36
 
            if ie.text_sha1:
37
 
                el.set('text_sha1', ie.text_sha1)
38
 
            if ie.text_size is not None:
39
 
                el.set('text_size', ('%d' % ie.text_size))
40
 
        elif kind != 'directory':
41
 
            raise BzrError('unknown InventoryEntry kind %r' % kind)
42
 
 
43
 
        el.tail = '\n'
44
 
        parent_el.append(el)
45
 
 
46
 
        if kind == 'directory':
47
 
            el.text = '\n' # break before having children
48
 
            l = ie.children.items()
49
 
            l.sort()
50
 
            for child_name, child_ie in l:
51
 
                descend(el, child_ie)
52
 
                
53
 
        
54
 
    # walk down through inventory, adding all directories
55
 
 
56
 
    l = inv.root.children.items()
57
 
    l.sort()
58
 
    for entry_name, ie in l:
59
 
        descend(root, ie)
60
 
    
61
 
    ElementTree(el).write(f, 'utf-8')
62
 
    f.write('\n')
63
 
 
64
 
 
65
 
 
66
 
def escape_attr(text):
67
 
    return text.replace("&", "&") \
68
 
           .replace("'", "'") \
69
 
           .replace('"', """) \
70
 
           .replace("<", "&lt;") \
71
 
           .replace(">", "&gt;")
72
 
 
73
 
 
74
 
# This writes out an inventory without building an XML tree first,
75
 
# just to see if it's faster.  Not currently used.
76
 
def write_slacker_inventory(inv, f):
77
 
    def descend(ie):
78
 
        kind = ie.kind
79
 
        f.write('<%s name="%s" id="%s" ' % (kind, escape_attr(ie.name),
80
 
                                            escape_attr(ie.file_id)))
81
 
 
82
 
        if kind == 'file':
83
 
            if ie.text_id:
84
 
                f.write('text_id="%s" ' % ie.text_id)
85
 
            if ie.text_sha1:
86
 
                f.write('text_sha1="%s" ' % ie.text_sha1)
87
 
            if ie.text_size is not None:
88
 
                f.write('text_size="%d" ' % ie.text_size)
89
 
            f.write('/>\n')
90
 
        elif kind == 'directory':
91
 
            f.write('>\n')
92
 
            
93
 
            l = ie.children.items()
94
 
            l.sort()
95
 
            for child_name, child_ie in l:
96
 
                descend(child_ie)
97
 
 
98
 
            f.write('</directory>\n')
99
 
        else:
100
 
            raise BzrError('unknown InventoryEntry kind %r' % kind)
101
 
 
102
 
    f.write('<inventory>\n')
103
 
    f.write('<root_directory id="%s">\n' % escape_attr(inv.root.file_id))
104
 
 
105
 
    l = inv.root.children.items()
106
 
    l.sort()
107
 
    for entry_name, ie in l:
108
 
        descend(ie)
109
 
 
110
 
    f.write('</root_directory>\n')
111
 
    f.write('</inventory>\n')
112
 
    
113
 
 
114
 
 
115
 
def read_new_inventory(f):
116
 
    from inventory import Inventory, InventoryEntry
117
 
    
118
 
    def descend(parent_ie, el):
119
 
        kind = el.tag
120
 
        name = el.get('name')
121
 
        file_id = el.get('id')
122
 
        ie = InventoryEntry(file_id, name, el.tag)
123
 
        parent_ie.children[name] = ie
124
 
        inv._byid[file_id] = ie
125
 
        if kind == 'directory':
126
 
            for child_el in el:
127
 
                descend(ie, child_el)
128
 
        elif kind == 'file':
129
 
            assert len(el) == 0
130
 
            ie.text_id = el.get('text_id')
131
 
            v = el.get('text_size')
132
 
            ie.text_size = v and int(v)
133
 
            ie.text_sha1 = el.get('text_sha1')
134
 
        else:
135
 
            raise BzrError("unknown inventory entry %r" % kind)
136
 
 
137
 
    inv_el = ElementTree().parse(f)
138
 
    assert inv_el.tag == 'inventory'
139
 
    root_el = inv_el[0]
140
 
    assert root_el.tag == 'root_directory'
141
 
 
142
 
    inv = Inventory(inv_el.get('file_id'))
143
 
    for el in root_el:
144
 
        descend(inv.root, el)