Mercurial > jhg
comparison src/org/tmatesoft/hg/repo/HgRemoteRepository.java @ 179:da426c2fe1ec
Support for changegroup wire command
author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
---|---|
date | Wed, 06 Apr 2011 02:50:26 +0200 |
parents | 62665d8f0686 |
children | cd3371670f0b |
comparison
equal
deleted
inserted
replaced
178:62665d8f0686 | 179:da426c2fe1ec |
---|---|
15 * contact TMate Software at support@hg4j.com | 15 * contact TMate Software at support@hg4j.com |
16 */ | 16 */ |
17 package org.tmatesoft.hg.repo; | 17 package org.tmatesoft.hg.repo; |
18 | 18 |
19 import java.io.File; | 19 import java.io.File; |
20 import java.io.FileOutputStream; | |
20 import java.io.IOException; | 21 import java.io.IOException; |
22 import java.io.InputStream; | |
21 import java.io.InputStreamReader; | 23 import java.io.InputStreamReader; |
22 import java.io.OutputStream; | 24 import java.io.OutputStream; |
23 import java.io.StreamTokenizer; | 25 import java.io.StreamTokenizer; |
24 import java.net.HttpURLConnection; | 26 import java.net.HttpURLConnection; |
25 import java.net.MalformedURLException; | 27 import java.net.MalformedURLException; |
35 import java.util.LinkedList; | 37 import java.util.LinkedList; |
36 import java.util.List; | 38 import java.util.List; |
37 import java.util.Map; | 39 import java.util.Map; |
38 import java.util.prefs.BackingStoreException; | 40 import java.util.prefs.BackingStoreException; |
39 import java.util.prefs.Preferences; | 41 import java.util.prefs.Preferences; |
42 import java.util.zip.InflaterInputStream; | |
40 | 43 |
41 import javax.net.ssl.HttpsURLConnection; | 44 import javax.net.ssl.HttpsURLConnection; |
42 import javax.net.ssl.SSLContext; | 45 import javax.net.ssl.SSLContext; |
43 import javax.net.ssl.TrustManager; | 46 import javax.net.ssl.TrustManager; |
44 import javax.net.ssl.X509TrustManager; | 47 import javax.net.ssl.X509TrustManager; |
275 } | 278 } |
276 } | 279 } |
277 | 280 |
278 // WireProtocol wiki: roots = a list of the latest nodes on every service side changeset branch that both the client and server know about. | 281 // WireProtocol wiki: roots = a list of the latest nodes on every service side changeset branch that both the client and server know about. |
279 public HgBundle getChanges(List<Nodeid> roots) throws HgException { | 282 public HgBundle getChanges(List<Nodeid> roots) throws HgException { |
280 return new HgLookup().loadBundle(new File("/temp/hg/hg-bundle-000000000000-gz.tmp")); | 283 StringBuilder sb = new StringBuilder(20 + roots.size() * 41); |
284 sb.append("roots="); | |
285 for (Nodeid n : roots) { | |
286 sb.append(n.toString()); | |
287 sb.append('+'); | |
288 } | |
289 if (sb.charAt(sb.length() - 1) == '+') { | |
290 // strip last space | |
291 sb.setLength(sb.length() - 1); | |
292 } | |
293 try { | |
294 URL u = new URL(url, url.getPath() + "?cmd=changegroup&" + sb.toString()); | |
295 HttpURLConnection c = setupConnection(u.openConnection()); | |
296 c.connect(); | |
297 if (debug) { | |
298 dumpResponseHeader(u, c); | |
299 } | |
300 File tf = writeBundle(c.getInputStream(), false, "HG10GZ" /*didn't see any other that zip*/); | |
301 return new HgLookup().loadBundle(tf); | |
302 } catch (MalformedURLException ex) { | |
303 throw new HgException(ex); | |
304 } catch (IOException ex) { | |
305 throw new HgException(ex); | |
306 } | |
281 } | 307 } |
282 | 308 |
283 private HttpURLConnection setupConnection(URLConnection urlConnection) { | 309 private HttpURLConnection setupConnection(URLConnection urlConnection) { |
284 urlConnection.setRequestProperty("User-Agent", "hg4j/0.5.0"); | 310 urlConnection.setRequestProperty("User-Agent", "hg4j/0.5.0"); |
285 urlConnection.addRequestProperty("Accept", "application/mercurial-0.1"); | 311 urlConnection.addRequestProperty("Accept", "application/mercurial-0.1"); |
298 final Map<String, List<String>> headerFields = c.getHeaderFields(); | 324 final Map<String, List<String>> headerFields = c.getHeaderFields(); |
299 for (String s : headerFields.keySet()) { | 325 for (String s : headerFields.keySet()) { |
300 System.out.printf("%s: %s\n", s, c.getHeaderField(s)); | 326 System.out.printf("%s: %s\n", s, c.getHeaderField(s)); |
301 } | 327 } |
302 } | 328 } |
329 | |
330 private static File writeBundle(InputStream is, boolean decompress, String header) throws IOException { | |
331 InputStream zipStream = decompress ? new InflaterInputStream(is) : is; | |
332 File tf = File.createTempFile("hg-bundle-", null); | |
333 FileOutputStream fos = new FileOutputStream(tf); | |
334 fos.write(header.getBytes()); | |
335 int r; | |
336 byte[] buf = new byte[8*1024]; | |
337 while ((r = zipStream.read(buf)) != -1) { | |
338 fos.write(buf, 0, r); | |
339 } | |
340 fos.close(); | |
341 zipStream.close(); | |
342 return tf; | |
343 } | |
344 | |
303 | 345 |
304 public static final class Range { | 346 public static final class Range { |
305 /** | 347 /** |
306 * Root of the range, earlier revision | 348 * Root of the range, earlier revision |
307 */ | 349 */ |