mirror of
https://gitlab.com/veilid/veilid.git
synced 2025-01-11 15:29:30 -05:00
flutter fixes
This commit is contained in:
parent
7382d70deb
commit
f836065f85
@ -338,8 +338,9 @@ Future<T> processFuturePlain<T>(Future<dynamic> future) {
|
|||||||
switch (list[0] as int) {
|
switch (list[0] as int) {
|
||||||
case messageOk:
|
case messageOk:
|
||||||
{
|
{
|
||||||
if (list[1] == null) {
|
if (list[1] == null && null is! T) {
|
||||||
throw VeilidAPIExceptionInternal("Null MESSAGE_OK value");
|
throw const VeilidAPIExceptionInternal(
|
||||||
|
"Null MESSAGE_OK value on non-nullable type");
|
||||||
}
|
}
|
||||||
return list[1] as T;
|
return list[1] as T;
|
||||||
}
|
}
|
||||||
@ -377,10 +378,15 @@ Future<T> processFutureJson<T>(
|
|||||||
}
|
}
|
||||||
case messageOkJson:
|
case messageOkJson:
|
||||||
{
|
{
|
||||||
if (list[1] == null) {
|
if (list[1] is! String) {
|
||||||
throw VeilidAPIExceptionInternal("Null MESSAGE_OK_JSON value");
|
throw const VeilidAPIExceptionInternal(
|
||||||
|
"Non-string MESSAGE_OK_JSON value");
|
||||||
}
|
}
|
||||||
var ret = jsonDecode(list[1] as String);
|
var ret = jsonDecode(list[1] as String);
|
||||||
|
if (ret == null) {
|
||||||
|
throw const VeilidAPIExceptionInternal(
|
||||||
|
"Null JSON object on non nullable type");
|
||||||
|
}
|
||||||
return jsonConstructor(ret);
|
return jsonConstructor(ret);
|
||||||
}
|
}
|
||||||
case messageErrJson:
|
case messageErrJson:
|
||||||
@ -416,7 +422,14 @@ Future<T?> processFutureOptJson<T>(
|
|||||||
if (list[1] == null) {
|
if (list[1] == null) {
|
||||||
return 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);
|
var ret = jsonDecode(list[1] as String);
|
||||||
|
if (ret == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
return jsonConstructor(ret);
|
return jsonConstructor(ret);
|
||||||
}
|
}
|
||||||
case messageErrJson:
|
case messageErrJson:
|
||||||
|
Loading…
Reference in New Issue
Block a user