This document provides a high-level overview into the architecture of Aquascope. The goal is to provide enough information such that a potential contributor can orient themselves relatively quickly within the database. It doesn't explain relevant analyses or related concepts, for that you should be looking at the documentation.
TODO
Aquascope is a rustc plugin, utilizing the rustc_plugin
crate. Below is a rough diagram showing the control-flow of the Aquascope project, it's important to focus on the three components with gear icons in the top-right corner.
-
The
front
(green box) reads a Rust crate and splits this up into bodies. You should be familiar with a MIRBody
but we really care about the BodyWithBorrowckFacts which contains the borrow check information provided by Polonius. The code for this is found inaquascope_front
, it's a simple crate that gets these bodies from rustc and then serializes the output information post-analysis. There's not much else to see here. -
The Permissions analysis (orange box) produces a
PermissionsCtxt
.❗ The
PermissionsCtxt
is the core data structure for working with permissions. It provides conversion functions to (and from) rustc primitives, as well as accessors for the permissions on aPath
. Please read its documentation.The permissions analysis works by translating the Polonius input/output facts into something permissions oriented, the translation is quite straightforward and there's a nice set of Datalog rules provided for ease-of-reading. The Datalog rules are written in
aquascope::analysis::permissions::output
, but this isn't necessary to understand, only for the curious. Because Aquascope stores more information about aBody
, we use our ownAquascopeFacts
that parallel theRustcFacts
. As stated above, thePermissionsCtxt
provides conversion functions two and it's unsafe to use the raw facts from rustc.After building the
PermissionsCtxt
theAquascopeAnalysis
can be constructed. This struct provides helper functions for working with source spans. For example, it holds information about the live ranges of a borrow and the source spans for this range. -
Generating visualizations (blue boxes) are where we actually use the permissions facts to generate information for a visualization. Currently, we only have two analyses which are internally referred to as the boundaries and steps analysis. In the Aquascope diagrams, the boundaries analysis computes the expected vs actual permissions for a single path usage, which are shown as the stacked letter icons. The steps analysis computes the differences in permissions between control flow points, shown as the tables to the right hand side. The complete boundaries analysis lives at
aquascope::analysis::boundaries
and the stepper correspondingly ataquascope::analysis::stepper
.⚠️ The stepper analysis is more complicated than you might think and it isn't recommended reading for newcomers.The module documentation for the boundaries analysis provides a detailed walk through of how it works and utilizes permissions and span information. If you yourself are looking to add a new analysis this is considered a must read.
We use CodeMirror 6 (CM) for an interactive environment as well as visualizations rendering the visualizations. The static diagrams are represented as a CM Decoration
.
TODO: talk about serializing and generating TS bindings.