Show More
@@ -67,6 +67,17 def convert(ui, src, dest=None, revmapfi | |||||
67 | subdirectory into the root of the repository, use '.' as the path to |
|
67 | subdirectory into the root of the repository, use '.' as the path to | |
68 | rename to. |
|
68 | rename to. | |
69 |
|
69 | |||
|
70 | The splicemap is a file that allows insertion of synthetic | |||
|
71 | history, letting you specify the parents of a revision. This is | |||
|
72 | useful if you want to e.g. give a Subversion merge two parents, or | |||
|
73 | graft two disconnected series of history together. Each entry | |||
|
74 | contains a key, followed by a space, followed by one or two | |||
|
75 | values, separated by spaces. The key is the revision ID in the | |||
|
76 | source revision control system whose parents should be modified | |||
|
77 | (same format as a key in .hg/shamap). The values are the revision | |||
|
78 | IDs (in either the source or destination revision control system) | |||
|
79 | that should be used as the new parents for that node. | |||
|
80 | ||||
70 | Back end options: |
|
81 | Back end options: | |
71 |
|
82 | |||
72 | --config convert.hg.clonebranches=False (boolean) |
|
83 | --config convert.hg.clonebranches=False (boolean) | |
@@ -100,6 +111,7 cmdtable = { | |||||
100 | ('', 'filemap', '', 'remap file names using contents of file'), |
|
111 | ('', 'filemap', '', 'remap file names using contents of file'), | |
101 | ('r', 'rev', '', 'import up to target revision REV'), |
|
112 | ('r', 'rev', '', 'import up to target revision REV'), | |
102 | ('s', 'source-type', '', 'source repository type'), |
|
113 | ('s', 'source-type', '', 'source repository type'), | |
|
114 | ('', 'splicemap', '', 'splice synthesized history into place'), | |||
103 | ('', 'datesort', None, 'try to sort changesets by date')], |
|
115 | ('', 'datesort', None, 'try to sort changesets by date')], | |
104 | 'hg convert [OPTION]... SOURCE [DEST [MAPFILE]]'), |
|
116 | 'hg convert [OPTION]... SOURCE [DEST [MAPFILE]]'), | |
105 | "debugsvnlog": |
|
117 | "debugsvnlog": |
@@ -84,7 +84,7 class converter(object): | |||||
84 | self.readauthormap(opts.get('authors')) |
|
84 | self.readauthormap(opts.get('authors')) | |
85 | self.authorfile = self.dest.authorfile() |
|
85 | self.authorfile = self.dest.authorfile() | |
86 |
|
86 | |||
87 |
self.splicemap = mapfile(ui, |
|
87 | self.splicemap = mapfile(ui, opts.get('splicemap')) | |
88 |
|
88 | |||
89 | def walktree(self, heads): |
|
89 | def walktree(self, heads): | |
90 | '''Return a mapping that identifies the uncommitted parents of every |
|
90 | '''Return a mapping that identifies the uncommitted parents of every | |
@@ -252,9 +252,10 class converter(object): | |||||
252 | self.dest.copyfile(copyf, f) |
|
252 | self.dest.copyfile(copyf, f) | |
253 |
|
253 | |||
254 | try: |
|
254 | try: | |
255 |
parents = |
|
255 | parents = self.splicemap[rev].replace(',', ' ').split() | |
256 |
self.ui. |
|
256 | self.ui.status('spliced in %s as parents of %s\n' % | |
257 | (parents, rev)) |
|
257 | (parents, rev)) | |
|
258 | parents = [self.map.get(p, p) for p in parents] | |||
258 | except KeyError: |
|
259 | except KeyError: | |
259 | parents = [b[0] for b in pbranches] |
|
260 | parents = [b[0] for b in pbranches] | |
260 | newnode = self.dest.putcommit(filenames, parents, commit) |
|
261 | newnode = self.dest.putcommit(filenames, parents, commit) |
General Comments 0
You need to be logged in to leave comments.
Login now