Revy is a proof-of-concept time-travel debugger for the Bevy game engine, built using Rerun.
The general idea is that one would use Revy to investigate gameplay/physics/general-behavior-ish kinds of bugs.
Revy is not a graphics debugger: for that you'd use e.g. RenderDoc.
It is not a performance profiler either: for that, Bevy integrates well with e.g. Tracy.
Revy works by snapshotting diffs of the Bevy database every frame that are then logged into the Rerun database.
This allows you to inspect and visualize the state of the engine at any point in time, either in real-time or after the fact.
These recordings can then be shared to be replayed or e.g. attached to bug reports.
revy.mp4
| Breakout | 3D shapes | Alien Cake Addict | 
|---|---|---|
| Live demo | Live demo | Live demo | 
- 
Install the Rerun Viewer ( 0.21).
- 
Add revyto your dependencies:revy = "0.21" # always matches the rerun version 
- 
Initialize the rerunplugin:.add_plugins({ let rec = revy::RecordingStreamBuilder::new("<your_app_name>").spawn().unwrap(); revy::RerunPlugin { rec } }) This will start a Rerun Viewer in the background and stream the recording data to it. 
 Check out theRecordingStreamBuilderdocs for other options (saving to file, connecting to a remote viewer, etc).
This repository comes with a number of pre-injected Bevy examples:
cargo run --example breakout
cargo run --example alien_cake_addictRevy will record every components of every single entity (), either using one of the builtin dedicated loggers, or using the generic reflection-based logger.
You can also register your own custom loggers by inserting a RerunComponentLoggers resource:
.insert_resource(revy::RerunComponentLoggers::new([
    (
        "bevy_render::view::visibility::ViewVisibility".into(),
        Some(revy::RerunLogger::new(
            |_world, _all_entities, entity, _component| {
                let suffix = None;
                use revy::external::rerun;
                let data = entity
                    .get::<ViewVisibility>()
                    .map(|vviz| {
                        revy::Aliased::<rerun::components::Text>::new(
                            "ViewVisibility",
                            rerun::components::Text(
                                if vviz.get() { ":)))" } else { ":'(" }.into(),
                            ),
                        )
                    })
                    .map(|data| Box::new(data) as _);
                (suffix, data)
            },
        )),
    ),
]))| Bevy | Revy | Rerun | 
|---|---|---|
| 0.13 | 0.14 | 0.14 | 
| 0.13 | 0.15 | 0.15 | 
| 0.13 | 0.16 | 0.16 | 
| 0.14 | 0.17 | 0.17 | 
| 0.15 | 0.20 | 0.20 | 
| 0.15 | 0.21 | 0.21 |