d4rt 0.0.3
d4rt: ^0.0.3 copied to clipboard
An interpreter and runtime for the Dart language. It allows you to execute Dart code dynamically, bridge native classes, and build advanced scripting or plugin systems in your Dart/Flutter applications
d4rt #
d4rt (pronounced "dart") is an interpreter and runtime for the Dart language, written in Dart.
It allows you to execute Dart code dynamically, bridge native classes, and build advanced scripting or plugin systems in your Dart/Flutter applications.
Features #
- Dart interpreter: Run Dart code dynamically at runtime.
- Bridging system: Expose your own Dart/Flutter classes, enums, and methods to interpreted code.
- Async/await support: Handle asynchronous code and Futures.
- Class, enum, and extension support: Use most Dart language features, including classes, inheritance, mixins, enums, and extensions.
- Pattern matching: Support for Dart's pattern matching in switch/case and assignments.
- Custom logging: Integrated, configurable logger for debugging interpreted code.
- Extensible: Add your own bridges for custom types and native APIs.
Installation #
Add to your pubspec.yaml
:
dependencies:
d4rt: # latest version
Then run:
dart pub get
Usage Example #
import 'package:d4rt/d4rt.dart';
void main() {
final code = '''
int fib(int n) {
if (n <= 1) return n;
return fib(n - 1) + fib(n - 2);
}
main() {
return fib(6);
}
''';
final interpreter = D4rt();
final result = interpreter.execute(code);
print('Result: $result'); // Result: 8
}
Bridging Native Classes & Enums #
You can expose your own Dart classes and enums to the interpreter using the bridge system. Here are minimal examples:
Bridge a Dart Class (Minimal) #
import 'package:d4rt/d4rt.dart';
class MyClass {
int value;
MyClass(this.value);
int doubleValue() => value * 2;
}
final myClassBridge = BridgedClassDefinition(
nativeType: MyClass,
name: 'MyClass',
constructors: {
'': (visitor, positionalArgs, namedArgs) => MyClass(positionalArgs[0] as int),
},
methods: {
'doubleValue': (visitor, target, positionalArgs, namedArgs) => (target as MyClass).doubleValue(),
},
getters: {
'value': (visitor, target) => (target as MyClass).value,
},
);
void main() {
final interpreter = D4rt();
interpreter.defineBridge(myClassBridge);
final code = '''
main() {
var obj = MyClass(21);
return obj.doubleValue();
}
''';
final result = interpreter.execute(code);
print(result); // 42
}
Bridge a Dart Enum (Minimal) #
import 'package:d4rt/d4rt.dart';
enum Color { red, green, blue }
final colorEnumBridge = BridgedEnumDefinition<Color>(
name: 'Color',
values: Color.values,
);
void main() {
final interpreter = D4rt();
interpreter.registerBridgedEnum(colorEnumBridge);
final code = '''
main() {
return Color.green.name;
}
''';
final result = interpreter.execute(code);
print(result); // green
}
Supported Features #
Feature | Status / Notes |
---|---|
Classes & Inheritance | ✅ Full support (abstract, inheritance, mixins, interfaces, sealed, base, final) |
Enums | ✅ Full support (fields, methods, static, named values, index, name) |
Mixins | ✅ Supported (declaration, application, on clause, constraints) |
Extensions | ✅ Supported (methods, getters, setters, operators) |
Async/await | ✅ Supported (async functions, await, Futures) |
Pattern matching | ✅ Supported (switch/case, if-case, destructuring, list/map/record patterns) |
Collections (List, Map, Set) | ✅ Supported (literals, spread, if/for, nested, null-aware, records) |
Top-level functions | ✅ Supported (named, anonymous, closures, nested) |
Getters/Setters | ✅ Supported (instance, static, extension, bridge) |
Static members | ✅ Supported (fields, methods, getters/setters, bridge) |
Switch/case | ✅ Supported (classic, pattern, default, fallthrough, exhaustive checks) |
Try/catch/finally | ✅ Supported (multiple catch, on/type, rethrow, stacktrace) |
Imports | 🚫 Not supported in interpreted code (bridges only via API) |
Generics | ⚠️ Partial (basic generic classes/functions, no runtime type checks) |
Operator overloading | ⚠️ Partial (via extensions, not via class operator methods) |
FFI | 🚫 Not supported |
Isolates | 🚫 Not supported |
Reflection/Mirrors | 🚫 Not supported |
Records | ✅ Supported (positional, named, pattern matching) |
String interpolation | ✅ Supported |
Cascade notation (.. ) |
✅ Supported |
Null safety | ✅ Supported (null-aware ops, checks, patterns) |
Type tests (is , as ) |
✅ Supported |
Exception handling | ✅ Supported (throw, rethrow, custom errors) |
See the documentation for details and limitations.
Limitations #
- No support for
import
/export
directives in interpreted code. - Generics and operator overloading are partially supported.
- Some advanced Dart features (isolates, FFI, mirrors) are not available.
- The interpreter is not a full Dart VM: some language features may behave differently.
Documentation #
Contributing #
Contributions are welcome!
Feel free to open issues, suggest features, or submit pull requests.
License #
MIT License. See LICENSE.
About the Name #
d4rt is a play on the word "dart", using "4" as a stylized "A".
It is pronounced exactly like "dart".