Mercurial > hg4j
comparison src/org/tmatesoft/hg/internal/SubrepoManager.java @ 442:6865eb742883
Tests for subrepo API, refactor status tests for reuse, better subrepos API
| author | Artem Tikhomirov <tikhomirov.artem@gmail.com> |
|---|---|
| date | Fri, 27 Apr 2012 20:57:20 +0200 |
| parents | 9c9c442b5f2e |
| children | e4ee4bf4c7d0 |
comparison
equal
deleted
inserted
replaced
| 441:2a08466838d3 | 442:6865eb742883 |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2011 TMate Software Ltd | 2 * Copyright (c) 2011-2012 TMate Software Ltd |
| 3 * | 3 * |
| 4 * This program is free software; you can redistribute it and/or modify | 4 * This program is free software; you can redistribute it and/or modify |
| 5 * it under the terms of the GNU General Public License as published by | 5 * it under the terms of the GNU General Public License as published by |
| 6 * the Free Software Foundation; version 2 of the License. | 6 * the Free Software Foundation; version 2 of the License. |
| 7 * | 7 * |
| 25 import java.util.HashMap; | 25 import java.util.HashMap; |
| 26 import java.util.LinkedList; | 26 import java.util.LinkedList; |
| 27 import java.util.List; | 27 import java.util.List; |
| 28 import java.util.Map; | 28 import java.util.Map; |
| 29 | 29 |
| 30 import org.tmatesoft.hg.core.Nodeid; | |
| 31 import org.tmatesoft.hg.repo.HgInternals; | |
| 30 import org.tmatesoft.hg.repo.HgInvalidControlFileException; | 32 import org.tmatesoft.hg.repo.HgInvalidControlFileException; |
| 31 import org.tmatesoft.hg.repo.HgRepository; | 33 import org.tmatesoft.hg.repo.HgRepository; |
| 32 import org.tmatesoft.hg.repo.HgSubrepoLocation; | 34 import org.tmatesoft.hg.repo.HgSubrepoLocation; |
| 35 import org.tmatesoft.hg.util.Path; | |
| 33 | 36 |
| 34 /** | 37 /** |
| 35 * | 38 * |
| 39 * @see http://mercurial.selenic.com/wiki/SubrepoWork | |
| 40 * @see http://mercurial.selenic.com/wiki/Subrepository | |
| 36 * @author Artem Tikhomirov | 41 * @author Artem Tikhomirov |
| 37 * @author TMate Software Ltd. | 42 * @author TMate Software Ltd. |
| 38 */ | 43 */ |
| 39 public class SubrepoManager /* XXX RepoChangeNotifier, RepoChangeListener */{ | 44 public class SubrepoManager /* XXX RepoChangeNotifier, RepoChangeListener */{ |
| 40 | 45 |
| 73 | 78 |
| 74 private List<HgSubrepoLocation> readConfig(BufferedReader br, Map<String, String> substate) throws IOException { | 79 private List<HgSubrepoLocation> readConfig(BufferedReader br, Map<String, String> substate) throws IOException { |
| 75 try { | 80 try { |
| 76 String line; | 81 String line; |
| 77 LinkedList<HgSubrepoLocation> res = new LinkedList<HgSubrepoLocation>(); | 82 LinkedList<HgSubrepoLocation> res = new LinkedList<HgSubrepoLocation>(); |
| 83 HgInternals hgRepoInternal = new HgInternals(repo); | |
| 78 while ((line = br.readLine()) != null) { | 84 while ((line = br.readLine()) != null) { |
| 79 int sep = line.indexOf('='); | 85 int sep = line.indexOf('='); |
| 80 if (sep == -1) { | 86 if (sep == -1) { |
| 81 continue; | 87 continue; |
| 82 } | 88 } |
| 83 // since both key and value are referenced from HgSubrepoLocation, doesn't make sense | 89 // since both key and value are referenced from HgSubrepoLocation, doesn't make sense |
| 84 // to have separate String instances (new String(line.substring())) | 90 // to have separate String instances (new String(line.substring())) |
| 85 String key = line.substring(0, sep).trim(); | 91 String key = line.substring(0, sep).trim(); |
| 86 String value = line.substring(sep + 1).trim(); | 92 String value = line.substring(sep + 1).trim(); |
| 87 if (value.length() == 0) { | 93 if (key.length() == 0 || value.length() == 0) { |
| 88 // XXX log bad line? | 94 // XXX log bad line? |
| 89 continue; | 95 continue; |
| 90 } | 96 } |
| 91 HgSubrepoLocation.Kind kind = HgSubrepoLocation.Kind.Hg; | 97 HgSubrepoLocation.Kind kind = HgSubrepoLocation.Kind.Hg; |
| 92 int kindEnd = value.indexOf(']', 1); | 98 int kindEnd = value.indexOf(']', 1); |
| 98 } else if ("git".equals(kindStr)) { | 104 } else if ("git".equals(kindStr)) { |
| 99 kind = HgSubrepoLocation.Kind.Git; | 105 kind = HgSubrepoLocation.Kind.Git; |
| 100 } | 106 } |
| 101 } | 107 } |
| 102 // TODO respect paths mappings in config file | 108 // TODO respect paths mappings in config file |
| 103 HgSubrepoLocation loc = new HgSubrepoLocation(repo, key, value, kind, substate.get(key)); | 109 // |
| 110 // apparently, key value can't end with '/', `hg commit` fails if it does: | |
| 111 // abort: path ends in directory separator: fourth/ | |
| 112 Path p = Path.create(key.charAt(key.length()-1) == '/' ? key : key + '/'); | |
| 113 String revValue = substate.get(key); | |
| 114 HgSubrepoLocation loc = hgRepoInternal.newSubrepo(p, value, kind, revValue == null ? null : Nodeid.fromAscii(revValue)); | |
| 104 res.add(loc); | 115 res.add(loc); |
| 105 } | 116 } |
| 106 return Arrays.asList(res.toArray(new HgSubrepoLocation[res.size()])); | 117 return Arrays.asList(res.toArray(new HgSubrepoLocation[res.size()])); |
| 107 } finally { | 118 } finally { |
| 108 br.close(); | 119 br.close(); |
| 109 } | 120 } |
| 110 } | 121 } |
| 111 | 122 |
| 112 private Map<String, String> readState(BufferedReader br) throws IOException { | 123 private Map<String, String> readState(BufferedReader br) throws IOException { |
| 124 // TODO reuse for other files with <revision><space><value> format, like .hgtags | |
| 113 HashMap<String, String> rv = new HashMap<String, String>(); | 125 HashMap<String, String> rv = new HashMap<String, String>(); |
| 114 try { | 126 try { |
| 115 String line; | 127 String line; |
| 116 while ((line = br.readLine()) != null) { | 128 while ((line = br.readLine()) != null) { |
| 117 int sep = line.trim().indexOf(' '); | 129 int sep = line.trim().indexOf(' '); |
