From f836065f853296f40d49a393e07fc04a8eeaf1c7 Mon Sep 17 00:00:00 2001 From: Christien Rioux Date: Sat, 22 Jul 2023 13:35:03 -0400 Subject: [PATCH] flutter fixes --- veilid-flutter/lib/veilid_ffi.dart | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/veilid-flutter/lib/veilid_ffi.dart b/veilid-flutter/lib/veilid_ffi.dart index cfadb6a4..545641cc 100644 --- a/veilid-flutter/lib/veilid_ffi.dart +++ b/veilid-flutter/lib/veilid_ffi.dart @@ -338,8 +338,9 @@ Future processFuturePlain(Future future) { switch (list[0] as int) { case messageOk: { - if (list[1] == null) { - throw VeilidAPIExceptionInternal("Null MESSAGE_OK value"); + if (list[1] == null && null is! T) { + throw const VeilidAPIExceptionInternal( + "Null MESSAGE_OK value on non-nullable type"); } return list[1] as T; } @@ -377,10 +378,15 @@ Future processFutureJson( } case messageOkJson: { - if (list[1] == null) { - throw VeilidAPIExceptionInternal("Null MESSAGE_OK_JSON value"); + if (list[1] is! String) { + throw const VeilidAPIExceptionInternal( + "Non-string MESSAGE_OK_JSON value"); } var ret = jsonDecode(list[1] as String); + if (ret == null) { + throw const VeilidAPIExceptionInternal( + "Null JSON object on non nullable type"); + } return jsonConstructor(ret); } case messageErrJson: @@ -416,7 +422,14 @@ Future processFutureOptJson( if (list[1] == null) { return null; } + if (list[1] is! String) { + throw const VeilidAPIExceptionInternal( + "Non-string MESSAGE_OK_JSON optional value"); + } var ret = jsonDecode(list[1] as String); + if (ret == null) { + return null; + } return jsonConstructor(ret); } case messageErrJson: