Show More
@@ -99,7 +99,7 class convert_git(converter_source): | |||||
99 | if similarity < 0 or similarity > 100: |
|
99 | if similarity < 0 or similarity > 100: | |
100 | raise util.Abort(_('similarity must be between 0 and 100')) |
|
100 | raise util.Abort(_('similarity must be between 0 and 100')) | |
101 | if similarity > 0: |
|
101 | if similarity > 0: | |
102 |
self.simopt = '- |
|
102 | self.simopt = '-C%d%%' % similarity | |
103 | findcopiesharder = ui.configbool('convert', 'git.findcopiesharder', |
|
103 | findcopiesharder = ui.configbool('convert', 'git.findcopiesharder', | |
104 | False) |
|
104 | False) | |
105 | if findcopiesharder: |
|
105 | if findcopiesharder: |
@@ -339,6 +339,11 class cg1packer(object): | |||||
339 | mfs.setdefault(c[0], x) |
|
339 | mfs.setdefault(c[0], x) | |
340 | return x |
|
340 | return x | |
341 |
|
341 | |||
|
342 | for chunk in self.group(clnodes, cl, lookupcl, units=_('changesets'), | |||
|
343 | reorder=reorder): | |||
|
344 | yield chunk | |||
|
345 | progress(msgbundling, None) | |||
|
346 | ||||
342 | # Callback for the manifest, used to collect linkrevs for filelog |
|
347 | # Callback for the manifest, used to collect linkrevs for filelog | |
343 | # revisions. |
|
348 | # revisions. | |
344 | # Returns the linkrev node (collected in lookupcl). |
|
349 | # Returns the linkrev node (collected in lookupcl). | |
@@ -350,16 +355,9 class cg1packer(object): | |||||
350 | if f in changedfiles: |
|
355 | if f in changedfiles: | |
351 | # record the first changeset introducing this filelog |
|
356 | # record the first changeset introducing this filelog | |
352 | # version |
|
357 | # version | |
353 |
fnodes |
|
358 | fnodes.setdefault(f, {}).setdefault(n, clnode) | |
354 | return clnode |
|
359 | return clnode | |
355 |
|
360 | |||
356 | for chunk in self.group(clnodes, cl, lookupcl, units=_('changesets'), |
|
|||
357 | reorder=reorder): |
|
|||
358 | yield chunk |
|
|||
359 | progress(msgbundling, None) |
|
|||
360 |
|
||||
361 | for f in changedfiles: |
|
|||
362 | fnodes[f] = {} |
|
|||
363 | mfnodes = self.prune(mf, mfs, commonrevs, source) |
|
361 | mfnodes = self.prune(mf, mfs, commonrevs, source) | |
364 | for chunk in self.group(mfnodes, mf, lookupmf, units=_('manifests'), |
|
362 | for chunk in self.group(mfnodes, mf, lookupmf, units=_('manifests'), | |
365 | reorder=reorder): |
|
363 | reorder=reorder): | |
@@ -377,7 +375,7 class cg1packer(object): | |||||
377 | linkrev = llr(r) |
|
375 | linkrev = llr(r) | |
378 | if linkrev in needed: |
|
376 | if linkrev in needed: | |
379 | yield filerevlog.node(r), cl.node(linkrev) |
|
377 | yield filerevlog.node(r), cl.node(linkrev) | |
380 |
|
|
378 | return dict(genfilenodes()) | |
381 | return fnodes.get(fname, {}) |
|
379 | return fnodes.get(fname, {}) | |
382 |
|
380 | |||
383 | for chunk in self.generatefiles(changedfiles, linknodes, commonrevs, |
|
381 | for chunk in self.generatefiles(changedfiles, linknodes, commonrevs, |
@@ -901,7 +901,7 def archive(web, req, tmpl): | |||||
901 |
|
901 | |||
902 | ctx = webutil.changectx(web.repo, req) |
|
902 | ctx = webutil.changectx(web.repo, req) | |
903 | pats = [] |
|
903 | pats = [] | |
904 | matchfn = None |
|
904 | matchfn = scmutil.match(ctx, []) | |
905 | file = req.form.get('file', None) |
|
905 | file = req.form.get('file', None) | |
906 | if file: |
|
906 | if file: | |
907 | pats = ['path:' + file[0]] |
|
907 | pats = ['path:' + file[0]] |
@@ -104,6 +104,7 def _smtp(ui): | |||||
104 | if util.parsebool(verifycert) is not False: |
|
104 | if util.parsebool(verifycert) is not False: | |
105 | raise util.Abort(_('invalid smtp.verifycert configuration: %s') |
|
105 | raise util.Abort(_('invalid smtp.verifycert configuration: %s') | |
106 | % (verifycert)) |
|
106 | % (verifycert)) | |
|
107 | verifycert = False | |||
107 | if (starttls or smtps) and verifycert: |
|
108 | if (starttls or smtps) and verifycert: | |
108 | sslkwargs = sslutil.sslkwargs(ui, mailhost) |
|
109 | sslkwargs = sslutil.sslkwargs(ui, mailhost) | |
109 | else: |
|
110 | else: |
@@ -12,8 +12,15 | |||||
12 | $ echo bletch>baz/bletch |
|
12 | $ echo bletch>baz/bletch | |
13 | $ hg commit -Am 3 -d '1000000000 0' |
|
13 | $ hg commit -Am 3 -d '1000000000 0' | |
14 | adding baz/bletch |
|
14 | adding baz/bletch | |
|
15 | $ hg init subrepo | |||
|
16 | $ touch subrepo/sub | |||
|
17 | $ hg -q -R subrepo ci -Am "init subrepo" | |||
|
18 | $ echo "subrepo = subrepo" > .hgsub | |||
|
19 | $ hg add .hgsub | |||
|
20 | $ hg ci -m "add subrepo" | |||
15 | $ echo "[web]" >> .hg/hgrc |
|
21 | $ echo "[web]" >> .hg/hgrc | |
16 | $ echo "name = test-archive" >> .hg/hgrc |
|
22 | $ echo "name = test-archive" >> .hg/hgrc | |
|
23 | $ echo "archivesubrepos = True" >> .hg/hgrc | |||
17 | $ cp .hg/hgrc .hg/hgrc-base |
|
24 | $ cp .hg/hgrc .hg/hgrc-base | |
18 | > test_archtype() { |
|
25 | > test_archtype() { | |
19 | > echo "allow_archive = $1" >> .hg/hgrc |
|
26 | > echo "allow_archive = $1" >> .hg/hgrc | |
@@ -83,30 +90,39 invalid arch type should give 404 | |||||
83 | > sys.stderr.write(str(e) + '\n') |
|
90 | > sys.stderr.write(str(e) + '\n') | |
84 | > EOF |
|
91 | > EOF | |
85 | $ python getarchive.py "$TIP" gz | gunzip | tar tf - 2>/dev/null |
|
92 | $ python getarchive.py "$TIP" gz | gunzip | tar tf - 2>/dev/null | |
86 |
test-archive- |
|
93 | test-archive-1701ef1f1510/.hg_archival.txt | |
87 |
test-archive- |
|
94 | test-archive-1701ef1f1510/.hgsub | |
88 | test-archive-2c0277f05ed4/baz/bletch |
|
95 | test-archive-1701ef1f1510/.hgsubstate | |
89 |
test-archive- |
|
96 | test-archive-1701ef1f1510/bar | |
|
97 | test-archive-1701ef1f1510/baz/bletch | |||
|
98 | test-archive-1701ef1f1510/foo | |||
|
99 | test-archive-1701ef1f1510/subrepo/sub | |||
90 | $ python getarchive.py "$TIP" bz2 | bunzip2 | tar tf - 2>/dev/null |
|
100 | $ python getarchive.py "$TIP" bz2 | bunzip2 | tar tf - 2>/dev/null | |
91 |
test-archive- |
|
101 | test-archive-1701ef1f1510/.hg_archival.txt | |
92 |
test-archive- |
|
102 | test-archive-1701ef1f1510/.hgsub | |
93 | test-archive-2c0277f05ed4/baz/bletch |
|
103 | test-archive-1701ef1f1510/.hgsubstate | |
94 |
test-archive- |
|
104 | test-archive-1701ef1f1510/bar | |
|
105 | test-archive-1701ef1f1510/baz/bletch | |||
|
106 | test-archive-1701ef1f1510/foo | |||
|
107 | test-archive-1701ef1f1510/subrepo/sub | |||
95 | $ python getarchive.py "$TIP" zip > archive.zip |
|
108 | $ python getarchive.py "$TIP" zip > archive.zip | |
96 | $ unzip -t archive.zip |
|
109 | $ unzip -t archive.zip | |
97 | Archive: archive.zip |
|
110 | Archive: archive.zip | |
98 |
testing: test-archive- |
|
111 | testing: test-archive-1701ef1f1510/.hg_archival.txt OK | |
99 |
testing: test-archive- |
|
112 | testing: test-archive-1701ef1f1510/.hgsub OK | |
100 |
testing: test-archive- |
|
113 | testing: test-archive-1701ef1f1510/.hgsubstate OK | |
101 |
testing: test-archive- |
|
114 | testing: test-archive-1701ef1f1510/bar OK | |
|
115 | testing: test-archive-1701ef1f1510/baz/bletch OK | |||
|
116 | testing: test-archive-1701ef1f1510/foo OK | |||
|
117 | testing: test-archive-1701ef1f1510/subrepo/sub OK | |||
102 | No errors detected in compressed data of archive.zip. |
|
118 | No errors detected in compressed data of archive.zip. | |
103 |
|
119 | |||
104 | test that we can download single directories and files |
|
120 | test that we can download single directories and files | |
105 |
|
121 | |||
106 | $ python getarchive.py "$TIP" gz baz | gunzip | tar tf - 2>/dev/null |
|
122 | $ python getarchive.py "$TIP" gz baz | gunzip | tar tf - 2>/dev/null | |
107 |
test-archive- |
|
123 | test-archive-1701ef1f1510/baz/bletch | |
108 | $ python getarchive.py "$TIP" gz foo | gunzip | tar tf - 2>/dev/null |
|
124 | $ python getarchive.py "$TIP" gz foo | gunzip | tar tf - 2>/dev/null | |
109 |
test-archive- |
|
125 | test-archive-1701ef1f1510/foo | |
110 |
|
126 | |||
111 | test that we detect file patterns that match no files |
|
127 | test that we detect file patterns that match no files | |
112 |
|
128 | |||
@@ -123,29 +139,39 test that we reject unsafe patterns | |||||
123 | $ hg archive -t tar test.tar |
|
139 | $ hg archive -t tar test.tar | |
124 | $ tar tf test.tar |
|
140 | $ tar tf test.tar | |
125 | test/.hg_archival.txt |
|
141 | test/.hg_archival.txt | |
|
142 | test/.hgsub | |||
|
143 | test/.hgsubstate | |||
126 | test/bar |
|
144 | test/bar | |
127 | test/baz/bletch |
|
145 | test/baz/bletch | |
128 | test/foo |
|
146 | test/foo | |
129 |
|
147 | |||
130 | $ hg archive --debug -t tbz2 -X baz test.tar.bz2 |
|
148 | $ hg archive --debug -t tbz2 -X baz test.tar.bz2 | |
131 |
archiving: 0/ |
|
149 | archiving: 0/4 files (0.00%) | |
132 |
archiving: b |
|
150 | archiving: .hgsub 1/4 files (25.00%) | |
133 |
archiving: |
|
151 | archiving: .hgsubstate 2/4 files (50.00%) | |
|
152 | archiving: bar 3/4 files (75.00%) | |||
|
153 | archiving: foo 4/4 files (100.00%) | |||
134 | $ bunzip2 -dc test.tar.bz2 | tar tf - 2>/dev/null |
|
154 | $ bunzip2 -dc test.tar.bz2 | tar tf - 2>/dev/null | |
135 | test/.hg_archival.txt |
|
155 | test/.hg_archival.txt | |
|
156 | test/.hgsub | |||
|
157 | test/.hgsubstate | |||
136 | test/bar |
|
158 | test/bar | |
137 | test/foo |
|
159 | test/foo | |
138 |
|
160 | |||
139 | $ hg archive -t tgz -p %b-%h test-%h.tar.gz |
|
161 | $ hg archive -t tgz -p %b-%h test-%h.tar.gz | |
140 | $ gzip -dc test-$QTIP.tar.gz | tar tf - 2>/dev/null |
|
162 | $ gzip -dc test-$QTIP.tar.gz | tar tf - 2>/dev/null | |
141 |
test- |
|
163 | test-1701ef1f1510/.hg_archival.txt | |
142 | test-2c0277f05ed4/bar |
|
164 | test-1701ef1f1510/.hgsub | |
143 | test-2c0277f05ed4/baz/bletch |
|
165 | test-1701ef1f1510/.hgsubstate | |
144 | test-2c0277f05ed4/foo |
|
166 | test-1701ef1f1510/bar | |
|
167 | test-1701ef1f1510/baz/bletch | |||
|
168 | test-1701ef1f1510/foo | |||
145 |
|
169 | |||
146 | $ hg archive autodetected_test.tar |
|
170 | $ hg archive autodetected_test.tar | |
147 | $ tar tf autodetected_test.tar |
|
171 | $ tar tf autodetected_test.tar | |
148 | autodetected_test/.hg_archival.txt |
|
172 | autodetected_test/.hg_archival.txt | |
|
173 | autodetected_test/.hgsub | |||
|
174 | autodetected_test/.hgsubstate | |||
149 | autodetected_test/bar |
|
175 | autodetected_test/bar | |
150 | autodetected_test/baz/bletch |
|
176 | autodetected_test/baz/bletch | |
151 | autodetected_test/foo |
|
177 | autodetected_test/foo | |
@@ -155,6 +181,8 The '-t' should override autodetection | |||||
155 | $ hg archive -t tar autodetect_override_test.zip |
|
181 | $ hg archive -t tar autodetect_override_test.zip | |
156 | $ tar tf autodetect_override_test.zip |
|
182 | $ tar tf autodetect_override_test.zip | |
157 | autodetect_override_test.zip/.hg_archival.txt |
|
183 | autodetect_override_test.zip/.hg_archival.txt | |
|
184 | autodetect_override_test.zip/.hgsub | |||
|
185 | autodetect_override_test.zip/.hgsubstate | |||
158 | autodetect_override_test.zip/bar |
|
186 | autodetect_override_test.zip/bar | |
159 | autodetect_override_test.zip/baz/bletch |
|
187 | autodetect_override_test.zip/baz/bletch | |
160 | autodetect_override_test.zip/foo |
|
188 | autodetect_override_test.zip/foo | |
@@ -203,10 +231,12 rename them afterwards. | |||||
203 | No errors detected in compressed data of test.zip. |
|
231 | No errors detected in compressed data of test.zip. | |
204 |
|
232 | |||
205 | $ hg archive -t tar - | tar tf - 2>/dev/null |
|
233 | $ hg archive -t tar - | tar tf - 2>/dev/null | |
206 |
test- |
|
234 | test-1701ef1f1510/.hg_archival.txt | |
207 | test-2c0277f05ed4/bar |
|
235 | test-1701ef1f1510/.hgsub | |
208 | test-2c0277f05ed4/baz/bletch |
|
236 | test-1701ef1f1510/.hgsubstate | |
209 | test-2c0277f05ed4/foo |
|
237 | test-1701ef1f1510/bar | |
|
238 | test-1701ef1f1510/baz/bletch | |||
|
239 | test-1701ef1f1510/foo | |||
210 |
|
240 | |||
211 | $ hg archive -r 0 -t tar rev-%r.tar |
|
241 | $ hg archive -r 0 -t tar rev-%r.tar | |
212 | $ [ -f rev-0.tar ] |
|
242 | $ [ -f rev-0.tar ] | |
@@ -216,10 +246,10 test .hg_archival.txt | |||||
216 | $ hg archive ../test-tags |
|
246 | $ hg archive ../test-tags | |
217 | $ cat ../test-tags/.hg_archival.txt |
|
247 | $ cat ../test-tags/.hg_archival.txt | |
218 | repo: daa7f7c60e0a224faa4ff77ca41b2760562af264 |
|
248 | repo: daa7f7c60e0a224faa4ff77ca41b2760562af264 | |
219 | node: 2c0277f05ed49d1c8328fb9ba92fba7a5ebcb33e |
|
249 | node: 1701ef1f151069b8747038e93b5186bb43a47504 | |
220 | branch: default |
|
250 | branch: default | |
221 | latesttag: null |
|
251 | latesttag: null | |
222 |
latesttagdistance: |
|
252 | latesttagdistance: 4 | |
223 | $ hg tag -r 2 mytag |
|
253 | $ hg tag -r 2 mytag | |
224 | $ hg tag -r 2 anothertag |
|
254 | $ hg tag -r 2 anothertag | |
225 | $ hg archive -r 2 ../test-lasttag |
|
255 | $ hg archive -r 2 ../test-lasttag | |
@@ -250,16 +280,20 enable progress extension: | |||||
250 |
|
280 | |||
251 | $ hg archive ../with-progress |
|
281 | $ hg archive ../with-progress | |
252 | \r (no-eol) (esc) |
|
282 | \r (no-eol) (esc) | |
253 |
archiving [ ] 0/ |
|
283 | archiving [ ] 0/6\r (no-eol) (esc) | |
254 |
archiving [ ] 0/ |
|
284 | archiving [ ] 0/6\r (no-eol) (esc) | |
255 |
archiving [====== |
|
285 | archiving [======> ] 1/6\r (no-eol) (esc) | |
256 |
archiving [====== |
|
286 | archiving [======> ] 1/6\r (no-eol) (esc) | |
257 |
archiving [============= |
|
287 | archiving [=============> ] 2/6\r (no-eol) (esc) | |
258 |
archiving [============= |
|
288 | archiving [=============> ] 2/6\r (no-eol) (esc) | |
259 |
archiving [==================== |
|
289 | archiving [====================> ] 3/6\r (no-eol) (esc) | |
260 |
archiving [==================== |
|
290 | archiving [====================> ] 3/6\r (no-eol) (esc) | |
261 |
archiving [=========================== |
|
291 | archiving [===========================> ] 4/6\r (no-eol) (esc) | |
262 |
archiving [=========================== |
|
292 | archiving [===========================> ] 4/6\r (no-eol) (esc) | |
|
293 | archiving [==================================> ] 5/6\r (no-eol) (esc) | |||
|
294 | archiving [==================================> ] 5/6\r (no-eol) (esc) | |||
|
295 | archiving [==========================================>] 6/6\r (no-eol) (esc) | |||
|
296 | archiving [==========================================>] 6/6\r (no-eol) (esc) | |||
263 | \r (no-eol) (esc) |
|
297 | \r (no-eol) (esc) | |
264 |
|
298 | |||
265 | cleanup after progress extension test: |
|
299 | cleanup after progress extension test: |
General Comments 0
You need to be logged in to leave comments.
Login now