diff options
author | Alex Gaynor <alex.gaynor@gmail.com> | 2023-01-10 07:51:23 -0500 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2023-01-10 07:52:27 -0500 |
commit | 1cd22f097aca2667cbfde6320178e2354d07199b (patch) | |
tree | d326a6d543068c608142b9a5da931bd9475bdad0 | |
parent | a9ead5ec359038efc96603ad28b0f2eb9255ec3b (diff) |
Improve performance by reducing expensive bytes conversion
In two core parts of the codebase, complex type-switch based code is used to convert a value to bytes. However, in all cases (except for one, fixed in this PR), the caller is specifying a Message instance. We can make this code much simpler by directly calling the correct method on Message.
In #2110 this is measured to massively speed up large SFTP transfers.
-rw-r--r-- | paramiko/packet.py | 2 | ||||
-rw-r--r-- | paramiko/sftp.py | 6 |
2 files changed, 5 insertions, 3 deletions
diff --git a/paramiko/packet.py b/paramiko/packet.py index a8db2582..b6498c5e 100644 --- a/paramiko/packet.py +++ b/paramiko/packet.py @@ -390,7 +390,7 @@ class Packetizer(object): Write a block of data using the current cipher, as an SSH block. """ # encrypt this sucka - data = asbytes(data) + data = data.asbytes() cmd = byte_ord(data[0]) if cmd in MSG_NAMES: cmd_name = MSG_NAMES[cmd] diff --git a/paramiko/sftp.py b/paramiko/sftp.py index 2e9dff66..144edd4a 100644 --- a/paramiko/sftp.py +++ b/paramiko/sftp.py @@ -129,7 +129,9 @@ class BaseSFTP(object): # ...internals... def _send_version(self): - self._send_packet(CMD_INIT, struct.pack(">I", _VERSION)) + m = Message() + m.add_int(_VERSION) + self._send_packet(CMD_INIT, m) t, data = self._read_packet() if t != CMD_VERSION: raise SFTPError("Incompatible sftp protocol") @@ -190,7 +192,7 @@ class BaseSFTP(object): return out def _send_packet(self, t, packet): - packet = util.asbytes(packet) + packet = packet.asbytes() out = struct.pack(">I", len(packet) + 1) + byte_chr(t) + packet if self.ultra_debug: self._log(DEBUG, util.format_binary(out, "OUT: ")) |