5b7968346d
This adds a third reference to Field declaration, so that we know have three references, one for each use case: 1) fieldReference used for initialization; in FieldInitializer and as the key in the InstanceConstant.fieldValues map. 2) getterReference used for reading; in InstanceGet, StaticGet and SuperPropertyGet 3) setterReference used for writing; in InstanceSet, StaticSet and SuperPropertySet TEST=existing Change-Id: I223f130e808e7f19a831c1fe5e3a4725d1bcdc3b Reviewed-on: https://dart-review.googlesource.com/c/sdk/+/203770 Commit-Queue: Johnni Winther <johnniwinther@google.com> Reviewed-by: Jens Johansen <jensj@google.com> |
||
---|---|---|
.. | ||
bin | ||
doc | ||
lib | ||
test | ||
tool | ||
.gitignore | ||
analysis_options.yaml | ||
AUTHORS | ||
binary.md | ||
codereview.settings | ||
LICENSE | ||
PRESUBMIT.py | ||
problems.md | ||
pubspec.yaml | ||
README.md |
Dart Kernel
Dart Kernel is a small high-level language derived from Dart. It is designed for use as an intermediate format for whole-program analysis and transformations, and to be consumed by codegen and execution backends.
The kernel language has an in-memory representation in Dart and can be serialized as binary or text.
Both the kernel language and its implementations are unstable and are under development.
This package contains the Dart part of the implementation and contains:
- A transformable IR for the kernel language
- Serialization of kernel code
Note: The APIs in this package are in an early state; developers should be careful about depending on this package. In particular, there is no semver contract for release versions of this package. Please depend directly on individual versions.
See ast.dart for the in-memory IR, or binary.md for a description of the binary format. For now, the textual format is very ad-hoc and cannot be parsed back in.