1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-26 01:32:25 +00:00

testcrypt: allow ssh2_cipher_new to return NULL.

No cipher construction function _currently_ returns NULL, but one's
about to start, so the testcrypt system will have to be able to cope.

This is the first time a function in the testcrypt API has had an
'opt' type as its return value rather than an argument. But it works
just the same in reverse: the wire protocol emits the special
identifer "NULL" when the optional return value is absent, and the
Python module catches that and rewrites it as Python 'None'.
This commit is contained in:
Simon Tatham 2019-01-11 06:47:39 +00:00
parent 9128454750
commit ee8025dd1c
3 changed files with 13 additions and 1 deletions

View File

@ -139,6 +139,10 @@ def make_argword(arg, argtype, fnname, argindex, to_preserve):
fnname, argindex, typename, arg)) fnname, argindex, typename, arg))
def make_retval(rettype, word, unpack_strings): def make_retval(rettype, word, unpack_strings):
if rettype.startswith("opt_"):
if word == "NULL":
return None
rettype = rettype[4:]
if rettype == "val_string" and unpack_strings: if rettype == "val_string" and unpack_strings:
retwords = childprocess.funcall("getstring", [word]) retwords = childprocess.funcall("getstring", [word])
childprocess.funcall("free", [word]) childprocess.funcall("free", [word])

View File

@ -505,6 +505,14 @@ static void return_val_string_asciz(strbuf *out, char *s)
return_val_string(out, sb); return_val_string(out, sb);
} }
static void return_opt_val_ssh2cipher(strbuf *out, ssh2_cipher *c)
{
if (!c)
strbuf_catf(out, "NULL\n");
else
return_val_ssh2cipher(out, c);
}
static void handle_hello(BinarySource *in, strbuf *out) static void handle_hello(BinarySource *in, strbuf *out)
{ {
strbuf_catf(out, "hello, world"); strbuf_catf(out, "hello, world");

View File

@ -162,7 +162,7 @@ FUNC2(val_string, ssh1_cipher_decrypt, val_ssh1cipher, val_string_ptrlen)
/* /*
* The ssh2_cipher abstraction, with similar modifications. * The ssh2_cipher abstraction, with similar modifications.
*/ */
FUNC1(val_ssh2cipher, ssh2_cipher_new, ssh2_cipheralg) FUNC1(opt_val_ssh2cipher, ssh2_cipher_new, ssh2_cipheralg)
FUNC2(void, ssh2_cipher_setiv, val_ssh2cipher, val_string_ptrlen) FUNC2(void, ssh2_cipher_setiv, val_ssh2cipher, val_string_ptrlen)
FUNC2(void, ssh2_cipher_setkey, val_ssh2cipher, val_string_ptrlen) FUNC2(void, ssh2_cipher_setkey, val_ssh2cipher, val_string_ptrlen)
FUNC2(val_string, ssh2_cipher_encrypt, val_ssh2cipher, val_string_ptrlen) FUNC2(val_string, ssh2_cipher_encrypt, val_ssh2cipher, val_string_ptrlen)