decode method
Decodes a data
to a Commitment.
If allowNull
is true and the data
cannot be decoded successfully,
then null is returned. However, if allowNull
is false and the data
cannot be decoded successfully, then an UnimplementedError is thrown.
The allowNull
is very handy when an API changes and a new enum value is added or removed,
and users are still using an old app with the old code.
Implementation
Commitment? decode(dynamic data, {bool allowNull = true}) {
if (data != null) {
switch (data.toString()) {
case r'Confirmed': return Commitment.confirmed;
case r'Finalized': return Commitment.finalized;
case r'Processed': return Commitment.processed;
default:
if (!allowNull) {
throw ArgumentError('Unknown enum value to decode: $data');
}
}
}
return null;
}