FT works on win32
This commit is contained in:
parent
bc8a20f907
commit
9f91b28e12
|
@ -108,8 +108,6 @@ running instance of Gajim. \nFile Transfer will be canceled.\n==================
|
||||||
else:
|
else:
|
||||||
host['state'] = -1
|
host['state'] = -1
|
||||||
self.remove_receiver(host['idx'])
|
self.remove_receiver(host['idx'])
|
||||||
streamhost
|
|
||||||
|
|
||||||
|
|
||||||
def _connection_refused(self, streamhost, file_props, idx):
|
def _connection_refused(self, streamhost, file_props, idx):
|
||||||
if file_props is None:
|
if file_props is None:
|
||||||
|
@ -165,7 +163,6 @@ running instance of Gajim. \nFile Transfer will be canceled.\n==================
|
||||||
return
|
return
|
||||||
reader.state = 6
|
reader.state = 6
|
||||||
if reader.connected:
|
if reader.connected:
|
||||||
reader.fd = open(reader.file_props['file-name'])
|
|
||||||
reader.file_props['error'] = 0
|
reader.file_props['error'] = 0
|
||||||
reader.file_props['disconnect_cb'] = reader.disconnect
|
reader.file_props['disconnect_cb'] = reader.disconnect
|
||||||
reader.file_props['started'] = True
|
reader.file_props['started'] = True
|
||||||
|
@ -355,8 +352,8 @@ class Socks5:
|
||||||
self.remaining_buff = ''
|
self.remaining_buff = ''
|
||||||
|
|
||||||
def open_file_for_reading(self):
|
def open_file_for_reading(self):
|
||||||
self.fd = open(self.file_props['file-name'])
|
self.fd = open(self.file_props['file-name'],'rb')
|
||||||
|
self.fd.seek(self.size)
|
||||||
def close_file(self):
|
def close_file(self):
|
||||||
try:
|
try:
|
||||||
self.fd.close()
|
self.fd.close()
|
||||||
|
@ -370,7 +367,7 @@ class Socks5:
|
||||||
if self.file_props.has_key('fd'):
|
if self.file_props.has_key('fd'):
|
||||||
fd = self.file_props['fd']
|
fd = self.file_props['fd']
|
||||||
else:
|
else:
|
||||||
fd = open(self.file_props['file-name'],'w')
|
fd = open(self.file_props['file-name'],'wb')
|
||||||
self.file_props['fd'] = fd
|
self.file_props['fd'] = fd
|
||||||
self.file_props['received-len'] = 0
|
self.file_props['received-len'] = 0
|
||||||
return fd
|
return fd
|
||||||
|
@ -429,7 +426,9 @@ class Socks5:
|
||||||
buff = self.remaining_buff
|
buff = self.remaining_buff
|
||||||
self.remaining_buff = ''
|
self.remaining_buff = ''
|
||||||
else:
|
else:
|
||||||
|
self.open_file_for_reading()
|
||||||
buff = self.fd.read(MAX_BUFF_LEN)
|
buff = self.fd.read(MAX_BUFF_LEN)
|
||||||
|
self.close_file()
|
||||||
if len(buff) > 0:
|
if len(buff) > 0:
|
||||||
lenn = 0
|
lenn = 0
|
||||||
try:
|
try:
|
||||||
|
@ -466,7 +465,9 @@ class Socks5:
|
||||||
return None
|
return None
|
||||||
return lenn
|
return lenn
|
||||||
else:
|
else:
|
||||||
|
return 0
|
||||||
self.state = 8 # end connection
|
self.state = 8 # end connection
|
||||||
|
|
||||||
self.disconnect()
|
self.disconnect()
|
||||||
return -1
|
return -1
|
||||||
|
|
||||||
|
@ -803,7 +804,15 @@ class Socks5Receiver(Socks5):
|
||||||
if errnum == 111 or self.connect_timeout > 1000:
|
if errnum == 111 or self.connect_timeout > 1000:
|
||||||
self.queue._connection_refused(self.streamhost,
|
self.queue._connection_refused(self.streamhost,
|
||||||
self.file_props, self.queue_idx)
|
self.file_props, self.queue_idx)
|
||||||
return None
|
return None
|
||||||
|
# win32 needs this
|
||||||
|
elif errnum != 10056 or self.state != 0:
|
||||||
|
return None
|
||||||
|
else: # socket is already connected
|
||||||
|
self._sock.setblocking(False)
|
||||||
|
self._send=self._sock.send
|
||||||
|
self._recv=self._sock.recv
|
||||||
|
pass
|
||||||
self.buff = ''
|
self.buff = ''
|
||||||
self.connected = True
|
self.connected = True
|
||||||
self.file_props['connected'] = True
|
self.file_props['connected'] = True
|
||||||
|
@ -857,7 +866,6 @@ class Socks5Receiver(Socks5):
|
||||||
# for senders: init file_props and send '\n'
|
# for senders: init file_props and send '\n'
|
||||||
if result == 1 and self.state == 5:
|
if result == 1 and self.state == 5:
|
||||||
if self.file_props['type'] == 's':
|
if self.file_props['type'] == 's':
|
||||||
self.fd = open(self.file_props['file-name'])
|
|
||||||
self.file_props['error'] = 0
|
self.file_props['error'] = 0
|
||||||
self.file_props['disconnect_cb'] = self.disconnect
|
self.file_props['disconnect_cb'] = self.disconnect
|
||||||
self.file_props['started'] = True
|
self.file_props['started'] = True
|
||||||
|
|
Loading…
Reference in New Issue