runtime_type
A non-opaque representation of types at runtime.
Normally, Type
objects are opaque and cannot be used for actual logic. RuntimeType
allows for operations such as sub- or super-type checking, type checks, and casting using a variable instead of a literal.
To use, replace your type literals with calls to the RuntimeType
constructor:
// Before
final stringType = String;
// After
final stringType = RuntimeType<String>();
A word of warning
Please only use this library if you're sure it's what you want. If you're not completely at ease with the Dart language, ask someone who is whether your problem can be solved some other way, as Dart's type system is normally enough to handle problems.
How it works
Instead of using Type
instances to track information about a type, RuntimeType
uses a generic type to hold the same information. Then, by using that generic and Dart's handling of generic subtype checking, we can implement most of the functions that normal type literals have.
If you've seen this trick before, this package uses the same principle:
bool isTypeASubtypeOfB<A, B>() => <A>[] is List<B>;
However, that trick does not work when A
and B
cannot be resolved statically - which is why this package creates RuntimeType
objects statically, but which can then be passed around and used dynamically as the type information is held within the object itself.
Libraries
- mirrors
- Extra functionality to use RuntimeType with
dart:mirrors
. - runtime_type
- A non-opaque representation of types at runtime.