Show More
@@ -136,7 +136,11 def extsetup(ui): | |||||
136 | ) |
|
136 | ) | |
137 | % (scheme, scheme.upper()) |
|
137 | % (scheme, scheme.upper()) | |
138 | ) |
|
138 | ) | |
139 | hg.schemes[scheme] = ShortRepository(url, scheme, t) |
|
139 | url_scheme = urlutil.url(url).scheme | |
|
140 | if url_scheme in hg.peer_schemes: | |||
|
141 | hg.peer_schemes[scheme] = ShortRepository(url, scheme, t) | |||
|
142 | else: | |||
|
143 | hg.repo_schemes[scheme] = ShortRepository(url, scheme, t) | |||
140 |
|
144 | |||
141 | extensions.wrapfunction(urlutil, b'hasdriveletter', hasdriveletter) |
|
145 | extensions.wrapfunction(urlutil, b'hasdriveletter', hasdriveletter) | |
142 |
|
146 | |||
@@ -144,7 +148,11 def extsetup(ui): | |||||
144 | @command(b'debugexpandscheme', norepo=True) |
|
148 | @command(b'debugexpandscheme', norepo=True) | |
145 | def expandscheme(ui, url, **opts): |
|
149 | def expandscheme(ui, url, **opts): | |
146 | """given a repo path, provide the scheme-expanded path""" |
|
150 | """given a repo path, provide the scheme-expanded path""" | |
147 | repo = hg._peerlookup(url) |
|
151 | scheme = urlutil.url(url).scheme | |
148 | if isinstance(repo, ShortRepository): |
|
152 | if scheme in hg.peer_schemes: | |
149 | url = repo.resolve(url) |
|
153 | cls = hg.peer_schemes[scheme] | |
|
154 | else: | |||
|
155 | cls = hg.repo_schemes.get(scheme) | |||
|
156 | if cls is not None and isinstance(cls, ShortRepository): | |||
|
157 | url = cls.resolve(url) | |||
150 | ui.write(url + b'\n') |
|
158 | ui.write(url + b'\n') |
@@ -143,22 +143,28 class LocalFactory: | |||||
143 | return cls.instance(ui, path, *args, **kwargs) |
|
143 | return cls.instance(ui, path, *args, **kwargs) | |
144 |
|
144 | |||
145 |
|
145 | |||
146 | schemes = { |
|
146 | repo_schemes = { | |
147 | b'bundle': bundlerepo, |
|
147 | b'bundle': bundlerepo, | |
148 | b'union': unionrepo, |
|
148 | b'union': unionrepo, | |
149 | b'file': LocalFactory, |
|
149 | b'file': LocalFactory, | |
|
150 | b'static-http': statichttprepo, | |||
|
151 | } | |||
|
152 | ||||
|
153 | peer_schemes = { | |||
150 | b'http': httppeer, |
|
154 | b'http': httppeer, | |
151 | b'https': httppeer, |
|
155 | b'https': httppeer, | |
152 | b'ssh': sshpeer, |
|
156 | b'ssh': sshpeer, | |
153 | b'static-http': statichttprepo, |
|
|||
154 | } |
|
157 | } | |
155 |
|
158 | |||
156 |
|
159 | |||
157 | def _peerlookup(path): |
|
160 | def _peerlookup(path): | |
158 | u = urlutil.url(path) |
|
161 | u = urlutil.url(path) | |
159 | scheme = u.scheme or b'file' |
|
162 | scheme = u.scheme or b'file' | |
160 | thing = schemes.get(scheme) or schemes[b'file'] |
|
163 | if scheme in peer_schemes: | |
161 | return thing |
|
164 | return peer_schemes[scheme] | |
|
165 | if scheme in repo_schemes: | |||
|
166 | return repo_schemes[scheme] | |||
|
167 | return LocalFactory | |||
162 |
|
168 | |||
163 |
|
169 | |||
164 | def islocal(repo): |
|
170 | def islocal(repo): |
General Comments 0
You need to be logged in to leave comments.
Login now