24
24
import os, tempfile, types, osutils, gzip, errno
25
25
from stat import ST_SIZE
26
26
from StringIO import StringIO
27
from trace import mutter
27
from bzrlib.errors import BzrError
28
from bzrlib.trace import mutter
29
31
######################################################################
91
93
p = self._path(fileid)
92
94
if os.access(p, os.F_OK) or os.access(p + '.gz', os.F_OK):
93
from bzrlib.errors import bailout
94
95
raise BzrError("store %r already contains id %r" % (self._basedir, fileid))
113
def copy_multi(self, other, ids):
114
def copy_multi(self, other, ids, permit_failure=False):
114
115
"""Copy texts for ids from other into self.
116
If an id is present in self, it is skipped. A count of copied
117
ids is returned, which may be less than len(ids).
117
If an id is present in self, it is skipped.
119
Returns (count_copied, failed), where failed is a collection of ids
120
that could not be copied.
119
from bzrlib.progress import ProgressBar
122
pb = bzrlib.ui.ui_factory.progress_bar()
121
124
pb.update('preparing to copy')
122
125
to_copy = [id for id in ids if id not in self]
123
126
if isinstance(other, ImmutableStore):
124
127
return self.copy_multi_immutable(other, to_copy, pb)
126
130
for id in to_copy:
128
132
pb.update('copy', count, len(to_copy))
129
self.add(other[id], id)
130
assert count == len(to_copy)
133
if not permit_failure:
134
self.add(other[id], id)
143
if not permit_failure:
144
assert count == len(to_copy)
135
def copy_multi_immutable(self, other, to_copy, pb):
148
def copy_multi_immutable(self, other, to_copy, pb, permit_failure=False):
136
149
from shutil import copyfile
138
152
for id in to_copy:
139
153
p = self._path(id)
140
154
other_p = other._path(id)
142
156
copyfile(other_p, p)
143
157
except IOError, e:
144
158
if e.errno == errno.ENOENT:
145
copyfile(other_p+".gz", p+".gz")
159
if not permit_failure:
160
copyfile(other_p+".gz", p+".gz")
163
copyfile(other_p+".gz", p+".gz")
165
if e.errno == errno.ENOENT: