Mercurial > hg
annotate hgext/largefiles/uisetup.py @ 15503:eb5ed02d8743
forget: use forward slashes for internal paths
forget into a subrepo failed on windows because pathes were joined with \.
author | Mads Kiilerich <mads@kiilerich.com> |
---|---|
date | Tue, 15 Nov 2011 02:44:55 +0100 |
parents | 155d0f8fb7e5 |
children | 9d7a83a42f8c 9036c7d106bf |
rev | line source |
---|---|
15168 | 1 # Copyright 2009-2010 Gregory P. Ward |
2 # Copyright 2009-2010 Intelerad Medical Systems Incorporated | |
3 # Copyright 2010-2011 Fog Creek Software | |
4 # Copyright 2010-2011 Unity Technologies | |
5 # | |
6 # This software may be used and distributed according to the terms of the | |
7 # GNU General Public License version 2 or any later version. | |
8 | |
9 '''setup for largefiles extension: uisetup''' | |
10 | |
11 from mercurial import archival, cmdutil, commands, extensions, filemerge, hg, \ | |
15356
6d6b1b9aeea6
largfiles: drop unused import
Thomas Arendsen Hein <thomas@intevation.de>
parents:
15349
diff
changeset
|
12 httprepo, localrepo, sshrepo, sshserver, wireproto |
15168 | 13 from mercurial.i18n import _ |
14 from mercurial.hgweb import hgweb_mod, protocol | |
15 | |
16 import overrides | |
17 import proto | |
18 | |
19 def uisetup(ui): | |
20 # Disable auto-status for some commands which assume that all | |
21 # files in the result are under Mercurial's control | |
22 | |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
23 entry = extensions.wrapcommand(commands.table, 'add', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
24 overrides.override_add) |
15168 | 25 addopt = [('', 'large', None, _('add as largefile')), |
15295
bd9405551ad4
largefiles: fix typo
Wagner Bruna <wbruna@softwareexpress.com.br>
parents:
15254
diff
changeset
|
26 ('', 'lfsize', '', _('add all files above this size (in megabytes) ' |
15168 | 27 'as largefiles (default: 10)'))] |
28 entry[1].extend(addopt) | |
29 | |
30 entry = extensions.wrapcommand(commands.table, 'addremove', | |
31 overrides.override_addremove) | |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
32 entry = extensions.wrapcommand(commands.table, 'remove', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
33 overrides.override_remove) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
34 entry = extensions.wrapcommand(commands.table, 'forget', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
35 overrides.override_forget) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
36 entry = extensions.wrapcommand(commands.table, 'status', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
37 overrides.override_status) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
38 entry = extensions.wrapcommand(commands.table, 'log', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
39 overrides.override_log) |
15168 | 40 entry = extensions.wrapcommand(commands.table, 'rollback', |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
41 overrides.override_rollback) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
42 entry = extensions.wrapcommand(commands.table, 'verify', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
43 overrides.override_verify) |
15168 | 44 |
45 verifyopt = [('', 'large', None, _('verify largefiles')), | |
46 ('', 'lfa', None, | |
47 _('verify all revisions of largefiles not just current')), | |
48 ('', 'lfc', None, | |
49 _('verify largefile contents not just existence'))] | |
50 entry[1].extend(verifyopt) | |
51 | |
52 entry = extensions.wrapcommand(commands.table, 'outgoing', | |
53 overrides.override_outgoing) | |
54 outgoingopt = [('', 'large', None, _('display outgoing largefiles'))] | |
55 entry[1].extend(outgoingopt) | |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
56 entry = extensions.wrapcommand(commands.table, 'summary', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
57 overrides.override_summary) |
15168 | 58 summaryopt = [('', 'large', None, _('display outgoing largefiles'))] |
59 entry[1].extend(summaryopt) | |
60 | |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
61 entry = extensions.wrapcommand(commands.table, 'update', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
62 overrides.override_update) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
63 entry = extensions.wrapcommand(commands.table, 'pull', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
64 overrides.override_pull) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
65 entry = extensions.wrapfunction(filemerge, 'filemerge', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
66 overrides.override_filemerge) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
67 entry = extensions.wrapfunction(cmdutil, 'copy', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
68 overrides.override_copy) |
15168 | 69 |
70 # Backout calls revert so we need to override both the command and the | |
71 # function | |
15170
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
72 entry = extensions.wrapcommand(commands.table, 'revert', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
73 overrides.override_revert) |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
74 entry = extensions.wrapfunction(commands, 'revert', |
c1a4a3220711
largefiles: fix over-long lines
Matt Mackall <mpm@selenic.com>
parents:
15169
diff
changeset
|
75 overrides.override_revert) |
15168 | 76 |
77 # clone uses hg._update instead of hg.update even though they are the | |
78 # same function... so wrap both of them) | |
79 extensions.wrapfunction(hg, 'update', overrides.hg_update) | |
80 extensions.wrapfunction(hg, '_update', overrides.hg_update) | |
81 extensions.wrapfunction(hg, 'clean', overrides.hg_clean) | |
82 extensions.wrapfunction(hg, 'merge', overrides.hg_merge) | |
83 | |
84 extensions.wrapfunction(archival, 'archive', overrides.override_archive) | |
15349
63455eb771af
largefiles: drop more unnecessary compatibility checks
Greg Ward <greg@gerg.ca>
parents:
15295
diff
changeset
|
85 extensions.wrapfunction(cmdutil, 'bailifchanged', |
63455eb771af
largefiles: drop more unnecessary compatibility checks
Greg Ward <greg@gerg.ca>
parents:
15295
diff
changeset
|
86 overrides.override_bailifchanged) |
15168 | 87 |
88 # create the new wireproto commands ... | |
89 wireproto.commands['putlfile'] = (proto.putlfile, 'sha') | |
90 wireproto.commands['getlfile'] = (proto.getlfile, 'sha') | |
91 wireproto.commands['statlfile'] = (proto.statlfile, 'sha') | |
92 | |
93 # ... and wrap some existing ones | |
94 wireproto.commands['capabilities'] = (proto.capabilities, '') | |
95 wireproto.commands['heads'] = (proto.heads, '') | |
96 wireproto.commands['lheads'] = (wireproto.heads, '') | |
97 | |
15254
dd03d3a9f888
largefiles: more work on cleaning up comments
Greg Ward <greg@gerg.ca>
parents:
15252
diff
changeset
|
98 # make putlfile behave the same as push and {get,stat}lfile behave |
dd03d3a9f888
largefiles: more work on cleaning up comments
Greg Ward <greg@gerg.ca>
parents:
15252
diff
changeset
|
99 # the same as pull w.r.t. permissions checks |
15168 | 100 hgweb_mod.perms['putlfile'] = 'push' |
101 hgweb_mod.perms['getlfile'] = 'pull' | |
102 hgweb_mod.perms['statlfile'] = 'pull' | |
103 | |
104 # the hello wireproto command uses wireproto.capabilities, so it won't see | |
105 # our largefiles capability unless we replace the actual function as well. | |
106 proto.capabilities_orig = wireproto.capabilities | |
107 wireproto.capabilities = proto.capabilities | |
108 | |
15252
6e809bb4f969
largefiles: improve comments, internal docstrings
Greg Ward <greg@gerg.ca>
parents:
15188
diff
changeset
|
109 # these let us reject non-largefiles clients and make them display |
6e809bb4f969
largefiles: improve comments, internal docstrings
Greg Ward <greg@gerg.ca>
parents:
15188
diff
changeset
|
110 # our error messages |
15168 | 111 protocol.webproto.refuseclient = proto.webproto_refuseclient |
112 sshserver.sshserver.refuseclient = proto.sshproto_refuseclient | |
113 | |
114 # can't do this in reposetup because it needs to have happened before | |
115 # wirerepo.__init__ is called | |
116 proto.ssh_oldcallstream = sshrepo.sshrepository._callstream | |
117 proto.http_oldcallstream = httprepo.httprepository._callstream | |
118 sshrepo.sshrepository._callstream = proto.sshrepo_callstream | |
119 httprepo.httprepository._callstream = proto.httprepo_callstream | |
120 | |
121 # don't die on seeing a repo with the largefiles requirement | |
122 localrepo.localrepository.supported |= set(['largefiles']) | |
123 | |
124 # override some extensions' stuff as well | |
125 for name, module in extensions.extensions(): | |
126 if name == 'fetch': | |
127 extensions.wrapcommand(getattr(module, 'cmdtable'), 'fetch', | |
128 overrides.override_fetch) | |
129 if name == 'purge': | |
130 extensions.wrapcommand(getattr(module, 'cmdtable'), 'purge', | |
131 overrides.override_purge) | |
132 if name == 'rebase': | |
133 extensions.wrapcommand(getattr(module, 'cmdtable'), 'rebase', | |
134 overrides.override_rebase) | |
15383
155d0f8fb7e5
largefiles: fix bad bug where transplanting a changeset with a largefile will result in an old largefile being comitted later on
Na'Tosha Bard <natosha@unity3d.com>
parents:
15356
diff
changeset
|
135 if name == 'transplant': |
155d0f8fb7e5
largefiles: fix bad bug where transplanting a changeset with a largefile will result in an old largefile being comitted later on
Na'Tosha Bard <natosha@unity3d.com>
parents:
15356
diff
changeset
|
136 extensions.wrapcommand(getattr(module, 'cmdtable'), 'transplant', |
155d0f8fb7e5
largefiles: fix bad bug where transplanting a changeset with a largefile will result in an old largefile being comitted later on
Na'Tosha Bard <natosha@unity3d.com>
parents:
15356
diff
changeset
|
137 overrides.override_transplant) |