Show More
@@ -107,37 +107,26 b' def report(ui, olddatafn, newdatafn):' | |||||
107 | shrink_factor = oldsize / newsize |
|
107 | shrink_factor = oldsize / newsize | |
108 | ui.write('shrinkage: %.1f%% (%.1fx)\n' % (shrink_percent, shrink_factor)) |
|
108 | ui.write('shrinkage: %.1f%% (%.1fx)\n' % (shrink_percent, shrink_factor)) | |
109 |
|
109 | |||
110 | def main(): |
|
110 | def shrink(ui, repo, **opts): | |
|
111 | """ | |||
|
112 | Shrink revlog by re-ordering revisions. Will operate on manifest for | |||
|
113 | the given repository if no other revlog is specified.""" | |||
111 |
|
114 | |||
112 | # Unbuffer stdout for nice progress output. |
|
115 | # Unbuffer stdout for nice progress output. | |
113 | sys.stdout = os.fdopen(sys.stdout.fileno(), 'w', 0) |
|
116 | sys.stdout = os.fdopen(sys.stdout.fileno(), 'w', 0) | |
114 |
|
117 | |||
115 | parser = optparse.OptionParser(description=__doc__) |
|
118 | if not repo.local(): | |
116 | parser.add_option('-R', '--repository', |
|
119 | raise util.Abort('not a local repository: %s' % repo.root) | |
117 | default=os.path.curdir, |
|
|||
118 | metavar='REPO', |
|
|||
119 | help='repository root directory [default: current dir]') |
|
|||
120 | parser.add_option('--revlog', |
|
|||
121 | metavar='FILE', |
|
|||
122 | help='shrink FILE [default: REPO/hg/store/00manifest.i]') |
|
|||
123 | (options, args) = parser.parse_args() |
|
|||
124 | if args: |
|
|||
125 | raise util.Abort('too many arguments') |
|
|||
126 |
|
120 | |||
127 | # Open the specified repository. |
|
121 | fn = opts.get('revlog') | |
128 | ui = ui_.ui() |
|
122 | if not fn: | |
129 | repo = hg.repository(ui, options.repository) |
|
|||
130 | if not repo.local(): |
|
|||
131 | raise util.Abort('not a local repository: %s' % options.repository) |
|
|||
132 |
|
||||
133 | if options.revlog is None: |
|
|||
134 | indexfn = repo.sjoin('00manifest.i') |
|
123 | indexfn = repo.sjoin('00manifest.i') | |
135 | else: |
|
124 | else: | |
136 |
if not |
|
125 | if not fn.endswith('.i'): | |
137 | raise util.Abort('--revlog option must specify the revlog index ' |
|
126 | raise util.Abort('--revlog option must specify the revlog index ' | |
138 |
'file (*.i), not %s' % opt |
|
127 | 'file (*.i), not %s' % opts.get('revlog')) | |
139 |
|
128 | |||
140 |
indexfn = os.path.realpath( |
|
129 | indexfn = os.path.realpath(fn) | |
141 | store = repo.sjoin('') |
|
130 | store = repo.sjoin('') | |
142 | if not indexfn.startswith(store): |
|
131 | if not indexfn.startswith(store): | |
143 | raise util.Abort('--revlog option must specify a revlog in %s, ' |
|
132 | raise util.Abort('--revlog option must specify a revlog in %s, ' | |
@@ -213,9 +202,8 b' def main():' | |||||
213 | 'Running \'hg verify\' is strongly recommended.)\n' |
|
202 | 'Running \'hg verify\' is strongly recommended.)\n' | |
214 | % (oldindexfn, olddatafn)) |
|
203 | % (oldindexfn, olddatafn)) | |
215 |
|
204 | |||
216 | try: |
|
205 | cmdtable = { | |
217 | main() |
|
206 | 'shrink': (shrink, | |
218 | except util.Abort, inst: |
|
207 | [('', 'revlog', '', 'shrink file')], | |
219 | print inst.args[0] |
|
208 | 'hg shrink [--revlog PATH]') | |
220 | except KeyboardInterrupt: |
|
209 | } | |
221 | sys.exit("interrupted") |
|
General Comments 0
You need to be logged in to leave comments.
Login now