##// END OF EJS Templates
Fix sshrepo imports
mpm@selenic.com -
r1103:808a9f0e default
parent child Browse files
Show More
@@ -1,127 +1,129
1 # sshrepo.py - ssh repository proxy class for mercurial
1 # sshrepo.py - ssh repository proxy class for mercurial
2 #
2 #
3 # Copyright 2005 Matt Mackall <mpm@selenic.com>
3 # Copyright 2005 Matt Mackall <mpm@selenic.com>
4 #
4 #
5 # This software may be used and distributed according to the terms
5 # This software may be used and distributed according to the terms
6 # of the GNU General Public License, incorporated herein by reference.
6 # of the GNU General Public License, incorporated herein by reference.
7
7
8 import os, re, select
8 import os, re, select
9 from node import *
10 from remoterepo import *
9
11
10 class sshrepository(remoterepository):
12 class sshrepository(remoterepository):
11 def __init__(self, ui, path):
13 def __init__(self, ui, path):
12 self.url = path
14 self.url = path
13 self.ui = ui
15 self.ui = ui
14
16
15 m = re.match(r'ssh://(([^@]+)@)?([^:/]+)(:(\d+))?(/(.*))?', path)
17 m = re.match(r'ssh://(([^@]+)@)?([^:/]+)(:(\d+))?(/(.*))?', path)
16 if not m:
18 if not m:
17 raise RepoError("couldn't parse destination %s" % path)
19 raise RepoError("couldn't parse destination %s" % path)
18
20
19 self.user = m.group(2)
21 self.user = m.group(2)
20 self.host = m.group(3)
22 self.host = m.group(3)
21 self.port = m.group(5)
23 self.port = m.group(5)
22 self.path = m.group(7) or "."
24 self.path = m.group(7) or "."
23
25
24 args = self.user and ("%s@%s" % (self.user, self.host)) or self.host
26 args = self.user and ("%s@%s" % (self.user, self.host)) or self.host
25 args = self.port and ("%s -p %s") % (args, self.port) or args
27 args = self.port and ("%s -p %s") % (args, self.port) or args
26
28
27 sshcmd = self.ui.config("ui", "ssh", "ssh")
29 sshcmd = self.ui.config("ui", "ssh", "ssh")
28 remotecmd = self.ui.config("ui", "remotecmd", "hg")
30 remotecmd = self.ui.config("ui", "remotecmd", "hg")
29 cmd = "%s %s '%s -R %s serve --stdio'"
31 cmd = "%s %s '%s -R %s serve --stdio'"
30 cmd = cmd % (sshcmd, args, remotecmd, self.path)
32 cmd = cmd % (sshcmd, args, remotecmd, self.path)
31
33
32 self.pipeo, self.pipei, self.pipee = os.popen3(cmd)
34 self.pipeo, self.pipei, self.pipee = os.popen3(cmd)
33
35
34 def readerr(self):
36 def readerr(self):
35 while 1:
37 while 1:
36 r,w,x = select.select([self.pipee], [], [], 0)
38 r,w,x = select.select([self.pipee], [], [], 0)
37 if not r: break
39 if not r: break
38 l = self.pipee.readline()
40 l = self.pipee.readline()
39 if not l: break
41 if not l: break
40 self.ui.status("remote: ", l)
42 self.ui.status("remote: ", l)
41
43
42 def __del__(self):
44 def __del__(self):
43 try:
45 try:
44 self.pipeo.close()
46 self.pipeo.close()
45 self.pipei.close()
47 self.pipei.close()
46 for l in self.pipee:
48 for l in self.pipee:
47 self.ui.status("remote: ", l)
49 self.ui.status("remote: ", l)
48 self.pipee.close()
50 self.pipee.close()
49 except:
51 except:
50 pass
52 pass
51
53
52 def dev(self):
54 def dev(self):
53 return -1
55 return -1
54
56
55 def do_cmd(self, cmd, **args):
57 def do_cmd(self, cmd, **args):
56 self.ui.debug("sending %s command\n" % cmd)
58 self.ui.debug("sending %s command\n" % cmd)
57 self.pipeo.write("%s\n" % cmd)
59 self.pipeo.write("%s\n" % cmd)
58 for k, v in args.items():
60 for k, v in args.items():
59 self.pipeo.write("%s %d\n" % (k, len(v)))
61 self.pipeo.write("%s %d\n" % (k, len(v)))
60 self.pipeo.write(v)
62 self.pipeo.write(v)
61 self.pipeo.flush()
63 self.pipeo.flush()
62
64
63 return self.pipei
65 return self.pipei
64
66
65 def call(self, cmd, **args):
67 def call(self, cmd, **args):
66 r = self.do_cmd(cmd, **args)
68 r = self.do_cmd(cmd, **args)
67 l = r.readline()
69 l = r.readline()
68 self.readerr()
70 self.readerr()
69 try:
71 try:
70 l = int(l)
72 l = int(l)
71 except:
73 except:
72 raise RepoError("unexpected response '%s'" % l)
74 raise RepoError("unexpected response '%s'" % l)
73 return r.read(l)
75 return r.read(l)
74
76
75 def lock(self):
77 def lock(self):
76 self.call("lock")
78 self.call("lock")
77 return remotelock(self)
79 return remotelock(self)
78
80
79 def unlock(self):
81 def unlock(self):
80 self.call("unlock")
82 self.call("unlock")
81
83
82 def heads(self):
84 def heads(self):
83 d = self.call("heads")
85 d = self.call("heads")
84 try:
86 try:
85 return map(bin, d[:-1].split(" "))
87 return map(bin, d[:-1].split(" "))
86 except:
88 except:
87 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
89 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
88
90
89 def branches(self, nodes):
91 def branches(self, nodes):
90 n = " ".join(map(hex, nodes))
92 n = " ".join(map(hex, nodes))
91 d = self.call("branches", nodes=n)
93 d = self.call("branches", nodes=n)
92 try:
94 try:
93 br = [ tuple(map(bin, b.split(" "))) for b in d.splitlines() ]
95 br = [ tuple(map(bin, b.split(" "))) for b in d.splitlines() ]
94 return br
96 return br
95 except:
97 except:
96 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
98 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
97
99
98 def between(self, pairs):
100 def between(self, pairs):
99 n = "\n".join(["-".join(map(hex, p)) for p in pairs])
101 n = "\n".join(["-".join(map(hex, p)) for p in pairs])
100 d = self.call("between", pairs=n)
102 d = self.call("between", pairs=n)
101 try:
103 try:
102 p = [ l and map(bin, l.split(" ")) or [] for l in d.splitlines() ]
104 p = [ l and map(bin, l.split(" ")) or [] for l in d.splitlines() ]
103 return p
105 return p
104 except:
106 except:
105 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
107 raise RepoError("unexpected response '%s'" % (d[:400] + "..."))
106
108
107 def changegroup(self, nodes):
109 def changegroup(self, nodes):
108 n = " ".join(map(hex, nodes))
110 n = " ".join(map(hex, nodes))
109 f = self.do_cmd("changegroup", roots=n)
111 f = self.do_cmd("changegroup", roots=n)
110 return self.pipei
112 return self.pipei
111
113
112 def addchangegroup(self, cg):
114 def addchangegroup(self, cg):
113 d = self.call("addchangegroup")
115 d = self.call("addchangegroup")
114 if d:
116 if d:
115 raise RepoError("push refused: %s", d)
117 raise RepoError("push refused: %s", d)
116
118
117 while 1:
119 while 1:
118 d = cg.read(4096)
120 d = cg.read(4096)
119 if not d: break
121 if not d: break
120 self.pipeo.write(d)
122 self.pipeo.write(d)
121 self.readerr()
123 self.readerr()
122
124
123 self.pipeo.flush()
125 self.pipeo.flush()
124
126
125 self.readerr()
127 self.readerr()
126 l = int(self.pipei.readline())
128 l = int(self.pipei.readline())
127 return self.pipei.read(l) != ""
129 return self.pipei.read(l) != ""
General Comments 0
You need to be logged in to leave comments. Login now