From 6f4d2d48e49f33acfdd222ec92175e2034346a0b Mon Sep 17 00:00:00 2001 From: Jeremy Leibs Date: Thu, 30 Nov 2023 17:44:22 +0100 Subject: [PATCH 1/2] Move ResetBlueprint to a SystemCommand (#4408) ### What This avoids an annoying warning pop-up where data queries aren't found by making the blueprint life-cycle more deterministic. ### Checklist * [x] I have read and agree to [Contributor Guide](https://github.com/rerun-io/rerun/blob/main/CONTRIBUTING.md) and the [Code of Conduct](https://github.com/rerun-io/rerun/blob/main/CODE_OF_CONDUCT.md) * [x] I've included a screenshot or gif (if applicable) * [x] I have tested [app.rerun.io](https://app.rerun.io/pr/4408) (if applicable) * [x] The PR title and labels are set such as to maximize their usefulness for the next release's CHANGELOG - [PR Build Summary](https://build.rerun.io/pr/4408) - [Docs preview](https://rerun.io/preview/fbec79f174b8275a440cc483315edd4bfe269375/docs) - [Examples preview](https://rerun.io/preview/fbec79f174b8275a440cc483315edd4bfe269375/examples) - [Recent benchmark results](https://build.rerun.io/graphs/crates.html) - [Wasm size tracking](https://build.rerun.io/graphs/sizes.html) --- crates/re_viewer/src/app.rs | 5 +++++ crates/re_viewer/src/ui/blueprint_panel.rs | 14 +++++--------- crates/re_viewer_context/src/command_sender.rs | 3 +++ 3 files changed, 13 insertions(+), 9 deletions(-) diff --git a/crates/re_viewer/src/app.rs b/crates/re_viewer/src/app.rs index dd3a897859db..f161ee4a0982 100644 --- a/crates/re_viewer/src/app.rs +++ b/crates/re_viewer/src/app.rs @@ -356,6 +356,11 @@ impl App { } SystemCommand::ResetViewer => self.reset(store_hub, egui_ctx), + SystemCommand::ResetBlueprint => { + // By clearing the blueprint it will be re-populated with the defaults + // at the beginning of the next frame. + store_hub.clear_blueprint(); + } SystemCommand::UpdateBlueprint(blueprint_id, updates) => { let blueprint_db = store_hub.store_db_mut(&blueprint_id); for row in updates { diff --git a/crates/re_viewer/src/ui/blueprint_panel.rs b/crates/re_viewer/src/ui/blueprint_panel.rs index 8401a8e6641b..7f7579c9477e 100644 --- a/crates/re_viewer/src/ui/blueprint_panel.rs +++ b/crates/re_viewer/src/ui/blueprint_panel.rs @@ -1,4 +1,4 @@ -use re_viewer_context::ViewerContext; +use re_viewer_context::{SystemCommandSender as _, ViewerContext}; use re_viewport::{SpaceInfoCollection, ViewportBlueprint}; /// Show the Blueprint section of the left panel based on the current [`ViewportBlueprint`] @@ -15,7 +15,7 @@ pub fn blueprint_panel_ui( Some("The Blueprint is where you can configure the Rerun Viewer"), |ui| { blueprint.add_new_spaceview_button_ui(ctx, ui, spaces_info); - reset_button_ui(blueprint, ctx, ui, spaces_info); + reset_blueprint_button_ui(ctx, ui); }, ); }); @@ -25,18 +25,14 @@ pub fn blueprint_panel_ui( blueprint.tree_ui(ctx, ui); } -fn reset_button_ui( - blueprint: &mut ViewportBlueprint<'_>, - ctx: &ViewerContext<'_>, - ui: &mut egui::Ui, - spaces_info: &SpaceInfoCollection, -) { +fn reset_blueprint_button_ui(ctx: &ViewerContext<'_>, ui: &mut egui::Ui) { if ctx .re_ui .small_icon_button(ui, &re_ui::icons::RESET) .on_hover_text("Re-populate Viewport with automatically chosen Space Views") .clicked() { - blueprint.reset(ctx, spaces_info); + ctx.command_sender + .send_system(re_viewer_context::SystemCommand::ResetBlueprint); } } diff --git a/crates/re_viewer_context/src/command_sender.rs b/crates/re_viewer_context/src/command_sender.rs index 4de6ac5ed72a..b05631f6e05f 100644 --- a/crates/re_viewer_context/src/command_sender.rs +++ b/crates/re_viewer_context/src/command_sender.rs @@ -17,6 +17,9 @@ pub enum SystemCommand { /// Reset the `Viewer` to the default state ResetViewer, + /// Reset the `Blueprint` to the default state + ResetBlueprint, + /// Change the active recording-id in the `StoreHub` SetRecordingId(StoreId), From 68b68b6c6a496e80a5097880a5125910f4137b08 Mon Sep 17 00:00:00 2001 From: Andreas Reich Date: Fri, 1 Dec 2023 09:58:50 +0100 Subject: [PATCH 2/2] Update egui and wgpu (#4111) ### What * Fixes #3973 * Depends on https://github.com/emilk/egui/pull/3505 ### Test Matrix Make sure to click through a few examples to cover at least points, lines and meshes. (Arkit is a good one!) * [ ] Test window-related stuff on Linux: * [ ] check that resizing the window works * [ ] that the icon shows * [ ] that file->open works * [ ] that the DPI is sane and persisted on restart * [ ] Look for any other weird regressions * [x] Mac * [x] native * [x] WebGL Firefox * [x] WebGL Chrome * [x] WebGL Safari * [x] (optional) WebGPU Chrome * [x] Linux * [x] native * [x] WebGL Firefox * [x] WebGL Chrome * [x] Windows * [x] native * [x] WebGL Firefox * [x] WebGL Chrome * [x] WebGL Edge * [ ] (optional) WebGPU Chrome * [x] Merge egui PR ### Checklist * [x] https://github.com/emilk/egui/pull/3505 has been merged * [x] I have read and agree to [Contributor Guide](https://github.com/rerun-io/rerun/blob/main/CONTRIBUTING.md) and the [Code of Conduct](https://github.com/rerun-io/rerun/blob/main/CODE_OF_CONDUCT.md) * [x] I've included a screenshot or gif (if applicable) * [x] I have tested [demo.rerun.io](https://demo.rerun.io/pr/4111) (if applicable) * [x] The PR title and labels are set such as to maximize their usefulness for the next release's CHANGELOG - [PR Build Summary](https://build.rerun.io/pr/4111) - [Docs preview](https://rerun.io/preview/73199e5727c18529cdbd2dd3956af17204403f96/docs) - [Examples preview](https://rerun.io/preview/73199e5727c18529cdbd2dd3956af17204403f96/examples) - [Recent benchmark results](https://ref.rerun.io/dev/bench/) - [Wasm size tracking](https://ref.rerun.io/dev/sizes/) --------- Co-authored-by: Emil Ernerfeldt Co-authored-by: Antoine Beyeler --- Cargo.lock | 802 +++++++++++++----- Cargo.toml | 70 +- crates/re_build_web_viewer/Cargo.toml | 2 +- crates/re_log_encoding/Cargo.toml | 12 +- crates/re_renderer/examples/framework.rs | 6 +- .../re_renderer/src/draw_phases/outlines.rs | 12 +- .../src/draw_phases/picking_layer.rs | 10 +- .../re_renderer/src/draw_phases/screenshot.rs | 4 +- crates/re_renderer/src/view_builder.rs | 6 +- .../src/space_view_class.rs | 10 +- crates/re_space_view_spatial/src/eye.rs | 7 +- .../src/space_view_class.rs | 5 +- crates/re_time_panel/src/lib.rs | 4 +- crates/re_ui/Cargo.toml | 8 +- crates/re_ui/examples/re_ui_example.rs | 72 +- crates/re_ui/src/design_tokens.rs | 6 +- crates/re_ui/src/lib.rs | 38 +- crates/re_viewer/Cargo.toml | 2 +- crates/re_viewer/src/app.rs | 87 +- crates/re_viewer/src/lib.rs | 1 + crates/re_viewer/src/native.rs | 34 +- crates/re_viewer/src/screenshotter.rs | 26 +- crates/re_viewer/src/ui/rerun_menu.rs | 22 +- crates/re_viewer/src/ui/top_panel.rs | 36 +- crates/re_viewer/src/web.rs | 2 + crates/re_viewer_context/src/app_options.rs | 12 - crates/re_viewport/src/auto_layout.rs | 4 +- .../src/blueprint/viewport_layout_ext.rs | 2 +- crates/re_viewport/src/viewport.rs | 16 +- crates/re_viewport/src/viewport_blueprint.rs | 6 +- deny.toml | 8 +- examples/rust/extend_viewer_ui/src/main.rs | 2 +- 32 files changed, 826 insertions(+), 508 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 653912778006..69bde678b955 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -20,9 +20,9 @@ checksum = "c71b1793ee61086797f5c80b6efa2b8ffa6d5dd703f118545808a7f2e27f7046" [[package]] name = "accesskit" -version = "0.11.0" +version = "0.12.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "02c98a5d094590335462354da402d754fe2cb78f0e6ce5024611c28ed539c1de" +checksum = "ca8410747ed85a17c4a1e9ed3f5a74d3e7bdcc876cf9a18ff40ae21d645997b2" dependencies = [ "enumn", "serde", @@ -30,18 +30,18 @@ dependencies = [ [[package]] name = "accesskit_consumer" -version = "0.15.0" +version = "0.16.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca541e0fdb600916d196a940228df99b86d804fd2e6ef13894d7814f2799db43" +checksum = "8c17cca53c09fbd7288667b22a201274b9becaa27f0b91bf52a526db95de45e6" dependencies = [ "accesskit", ] [[package]] name = "accesskit_macos" -version = "0.7.1" +version = "0.10.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4baea9413f0daf1cd4aab199bc09f8139cd726ce7673d523c27d186b8b878325" +checksum = "cd3b6ae1eabbfbced10e840fd3fce8a93ae84f174b3e4ba892ab7bcb42e477a7" dependencies = [ "accesskit", "accesskit_consumer", @@ -51,38 +51,40 @@ dependencies = [ [[package]] name = "accesskit_unix" -version = "0.5.0" +version = "0.6.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b4d1517421278cc8e67422d0786a18cf4291093ebe49eadf1cf989ff80e57f90" +checksum = "6c8c9b4467d77cacfbc93cee9aa8e7822f6d527c774efdca5f8b3a5280c34847" dependencies = [ "accesskit", "accesskit_consumer", "async-channel", + "async-once-cell", "atspi", - "futures-lite", + "futures-lite 1.13.0", + "once_cell", "serde", "zbus", ] [[package]] name = "accesskit_windows" -version = "0.14.0" +version = "0.15.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e11c7f177739f23bd19bb856e4a64fdd96eb8638ec0a6a6dde9a7019a9e91c53" +checksum = "afcae27ec0974fc7c3b0b318783be89fd1b2e66dd702179fe600166a38ff4a0b" dependencies = [ "accesskit", "accesskit_consumer", - "arrayvec", "once_cell", "paste", - "windows", + "static_assertions", + "windows 0.48.0", ] [[package]] name = "accesskit_winit" -version = "0.14.1" +version = "0.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "14f1bd64cd0b480cafb7bdd91eb489a1ff50f0f5702437b9efa32a25b8bb82a1" +checksum = "88e39fcec2e10971e188730b7a76bab60647dacc973d4591855ebebcadfaa738" dependencies = [ "accesskit", "accesskit_macos", @@ -97,7 +99,7 @@ version = "0.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a76fd60b23679b7d19bd066031410fb7e458ccc5e958eb5c325888ce4baedc97" dependencies = [ - "gimli", + "gimli 0.27.2", ] [[package]] @@ -119,9 +121,9 @@ dependencies = [ [[package]] name = "ahash" -version = "0.8.5" +version = "0.8.6" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cd7d5a2cecb58716e47d67d5703a249964b14c7be1ec3cad3affc295b2d1c35d" +checksum = "91429305e9f0a25f6205c5b8e0d2db09e0708a7a6df0f42212bb56c32c8ac97a" dependencies = [ "cfg-if", "getrandom", @@ -303,7 +305,7 @@ version = "0.17.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a0f73029049896b3d70ba17756afef171ceef3569016cfa9dbca58d29e0e16f9" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "arrow-format", "bytemuck", "chrono", @@ -328,7 +330,7 @@ version = "0.37.3+1.3.251" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "39e9c3835d686b0a6084ab4234fcd1b07dbf6e4767dce60874b12356a25ecd4a" dependencies = [ - "libloading", + "libloading 0.7.4", ] [[package]] @@ -355,18 +357,18 @@ version = "0.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7c48ccdbf6ca6b121e0f586cbc0e73ae440e56c67c30fa0873b4e110d9c26d2b" dependencies = [ - "event-listener", + "event-listener 2.5.3", "futures-core", ] [[package]] name = "async-channel" -version = "1.8.0" +version = "1.9.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cf46fee83e5ccffc220104713af3292ff9bc7c64c7de289f66dae8e38d826833" +checksum = "81953c529336010edd6d8e358f886d9581267795c61b19475b71314bffa46d35" dependencies = [ "concurrent-queue", - "event-listener", + "event-listener 2.5.3", "futures-core", ] @@ -376,11 +378,11 @@ version = "1.5.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6fa3dc5f2a8564f07759c008b9109dc0d39de92a88d5588b8a5036d286383afb" dependencies = [ - "async-lock", + "async-lock 2.7.0", "async-task", "concurrent-queue", "fastrand", - "futures-lite", + "futures-lite 1.13.0", "slab", ] @@ -390,10 +392,10 @@ version = "1.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "279cf904654eeebfa37ac9bb1598880884924aab82e290aa65c9e77a0e142e06" dependencies = [ - "async-lock", + "async-lock 2.7.0", "autocfg", "blocking", - "futures-lite", + "futures-lite 1.13.0", ] [[package]] @@ -404,10 +406,10 @@ checksum = "f1b6f5d7df27bd294849f8eec66ecfc63d11814df7a4f5d74168a2394467b776" dependencies = [ "async-channel", "async-executor", - "async-io", - "async-lock", + "async-io 1.13.0", + "async-lock 2.7.0", "blocking", - "futures-lite", + "futures-lite 1.13.0", "once_cell", ] @@ -417,27 +419,81 @@ version = "1.13.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fc5b45d93ef0529756f812ca52e44c221b35341892d3dcc34132ac02f3dd2af" dependencies = [ - "async-lock", + "async-lock 2.7.0", "autocfg", "cfg-if", "concurrent-queue", - "futures-lite", + "futures-lite 1.13.0", "log", "parking", - "polling", - "rustix", + "polling 2.8.0", + "rustix 0.37.19", "slab", "socket2", "waker-fn", ] +[[package]] +name = "async-io" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "41ed9d5715c2d329bf1b4da8d60455b99b187f27ba726df2883799af9af60997" +dependencies = [ + "async-lock 3.1.0", + "cfg-if", + "concurrent-queue", + "futures-io", + "futures-lite 2.0.1", + "parking", + "polling 3.3.0", + "rustix 0.38.24", + "slab", + "tracing", + "waker-fn", + "windows-sys 0.48.0", +] + [[package]] name = "async-lock" version = "2.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fa24f727524730b077666307f2734b4a1a1c57acb79193127dcc8914d5242dd7" dependencies = [ - "event-listener", + "event-listener 2.5.3", +] + +[[package]] +name = "async-lock" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "deb2ab2aa8a746e221ab826c73f48bc6ba41be6763f0855cb249eb6d154cf1d7" +dependencies = [ + "event-listener 3.1.0", + "event-listener-strategy", + "pin-project-lite", +] + +[[package]] +name = "async-once-cell" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9338790e78aa95a416786ec8389546c4b6a1dfc3dc36071ed9518a9413a542eb" + +[[package]] +name = "async-process" +version = "1.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ea6438ba0a08d81529c69b36700fa2f95837bfe3e776ab39cde9c14d9149da88" +dependencies = [ + "async-io 1.13.0", + "async-lock 2.7.0", + "async-signal", + "blocking", + "cfg-if", + "event-listener 3.1.0", + "futures-lite 1.13.0", + "rustix 0.38.24", + "windows-sys 0.48.0", ] [[package]] @@ -451,6 +507,24 @@ dependencies = [ "syn 2.0.32", ] +[[package]] +name = "async-signal" +version = "0.2.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9e47d90f65a225c4527103a8d747001fc56e375203592b25ad103e1ca13124c5" +dependencies = [ + "async-io 2.2.0", + "async-lock 2.7.0", + "atomic-waker", + "cfg-if", + "futures-core", + "futures-io", + "rustix 0.38.24", + "signal-hook-registry", + "slab", + "windows-sys 0.48.0", +] + [[package]] name = "async-std" version = "1.12.0" @@ -459,13 +533,13 @@ checksum = "62565bb4402e926b29953c785397c6dc0391b7b446e45008b0049eb43cec6f5d" dependencies = [ "async-channel", "async-global-executor", - "async-io", - "async-lock", + "async-io 1.13.0", + "async-lock 2.7.0", "crossbeam-utils", "futures-channel", "futures-core", "futures-io", - "futures-lite", + "futures-lite 1.13.0", "gloo-timers", "kv-log-macro", "log", @@ -502,29 +576,50 @@ checksum = "1181e1e0d1fce796a03db1ae795d67167da795f9cf4a39c37589e85ef57f26d3" [[package]] name = "atspi" -version = "0.10.1" +version = "0.19.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "674e7a3376837b2e7d12d34d58ac47073c491dc3bf6f71a7adaf687d4d817faa" +checksum = "6059f350ab6f593ea00727b334265c4dfc7fd442ee32d264794bd9bdc68e87ca" +dependencies = [ + "atspi-common", + "atspi-connection", + "atspi-proxies", +] + +[[package]] +name = "atspi-common" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "92af95f966d2431f962bc632c2e68eda7777330158bf640c4af4249349b2cdf5" dependencies = [ - "async-recursion", - "async-trait", - "atspi-macros", "enumflags2", - "futures-lite", "serde", - "tracing", + "static_assertions", "zbus", "zbus_names", + "zvariant", ] [[package]] -name = "atspi-macros" -version = "0.2.0" +name = "atspi-connection" +version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "97fb4870a32c0eaa17e35bca0e6b16020635157121fb7d45593d242c295bc768" +checksum = "a0c65e7d70f86d4c0e3b2d585d9bf3f979f0b19d635a336725a88d279f76b939" dependencies = [ - "quote", - "syn 1.0.109", + "atspi-common", + "atspi-proxies", + "futures-lite 1.13.0", + "zbus", +] + +[[package]] +name = "atspi-proxies" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6495661273703e7a229356dcbe8c8f38223d697aacfaf0e13590a9ac9977bb52" +dependencies = [ + "atspi-common", + "serde", + "zbus", ] [[package]] @@ -602,9 +697,9 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" [[package]] name = "bitflags" -version = "2.3.1" +version = "2.4.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6776fc96284a0bb647b615056fc496d1fe1644a7ab01829818a6d91cae888b84" +checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07" [[package]] name = "block" @@ -647,11 +742,11 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "77231a1c8f801696fc0123ec6150ce92cffb8e164a02afb9c8ddee0e9b65ad65" dependencies = [ "async-channel", - "async-lock", + "async-lock 2.7.0", "async-task", "atomic-waker", "fastrand", - "futures-lite", + "futures-lite 1.13.0", "log", ] @@ -1284,8 +1379,8 @@ version = "0.7.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e16e44ab292b1dddfdaf7be62cfd8877df52f2f3fde5858d95bab606be259f20" dependencies = [ - "bitflags 2.3.1", - "libloading", + "bitflags 2.4.1", + "libloading 0.8.1", "winapi", ] @@ -1383,7 +1478,7 @@ version = "0.5.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ac1b7517328c04c2aa68422fc60a41b92208182142ed04a25879c26c8f878794" dependencies = [ - "libloading", + "libloading 0.7.4", ] [[package]] @@ -1418,9 +1513,9 @@ checksum = "68b0cf012f1230e43cd00ebb729c6bb58707ecfa8ad08b52ef3a4ccd2697fc30" [[package]] name = "ecolor" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "cfdf4e52dbbb615cfd30cf5a5265335c217b5fd8d669593cea74a517d9c605af" +checksum = "4b7637fc2e74d17e52931bac90ff4fc061ac776ada9c7fa272f24cdca5991972" dependencies = [ "bytemuck", "serde", @@ -1428,9 +1523,9 @@ dependencies = [ [[package]] name = "eframe" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "26d9efede6c8905d3fc51a5ec9a506d4da4011bbcae0253d0304580fe40af3f5" +checksum = "cdd73918a828c35a7efb4d7188ea973df4bffc589178ed95f521c917b03ddcfa" dependencies = [ "bytemuck", "cocoa", @@ -1462,12 +1557,12 @@ dependencies = [ [[package]] name = "egui" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8bd69fed5fcf4fbb8225b24e80ea6193b61e17a625db105ef0c4d71dde6eb8b7" +checksum = "c55bcb864b764eb889515a38b8924757657a250738ad15126637ee2df291ee6b" dependencies = [ "accesskit", - "ahash 0.8.5", + "ahash 0.8.6", "backtrace", "epaint", "log", @@ -1479,11 +1574,12 @@ dependencies = [ [[package]] name = "egui-wgpu" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "62d4c9ab93d9528c184ef1d695c8c99b2e6d50833696ec3f513063efeee0fe77" +checksum = "2d8ea73b329649be625fac2c9b190a2a8f9a66f98610c4b09124b596c6695053" dependencies = [ "bytemuck", + "egui", "epaint", "log", "puffin", @@ -1495,9 +1591,9 @@ dependencies = [ [[package]] name = "egui-winit" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c15479a96d9fadccf5dac690bdc6373b97b8e1c0dd28367058f25a5298da0195" +checksum = "3b673606b6606b12b95e3a3194d7882bf5cff302db36a520b8144c7c342e4e84" dependencies = [ "accesskit_winit", "arboard", @@ -1514,9 +1610,9 @@ dependencies = [ [[package]] name = "egui_commonmark" -version = "0.9.2" +version = "0.10.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a1665b7659f041aa99d3f97ec11d5f1f7062cd757e2ebd12e13532b96a348a6b" +checksum = "bfa443d412387b02e274094687e0beca21d809014433bf8d2666b3a20994c67f" dependencies = [ "egui", "egui_extras", @@ -1525,32 +1621,32 @@ dependencies = [ [[package]] name = "egui_extras" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "68ffe3fe5c00295f91c2a61a74ee271c32f74049c94ba0b1cea8f26eb478bc07" +checksum = "4b880044250106e673610c9a15d62692ef8af396593058f334be6f2a4d9544a5" dependencies = [ "egui", "ehttp", "enum-map", "image", "log", - "mime_guess", + "mime_guess2", "puffin", "serde", ] [[package]] name = "egui_glow" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce6726c08798822280038bbad2e32f4fc3cbed800cd51c6e34e99cd2d60cc1bc" +checksum = "262151f9d57c557c02a40a46f27b9e050a6eb0b006b94dced9c6f4519a04d489" dependencies = [ "bytemuck", "egui", "egui-winit", - "glow", + "glow 0.12.3", "log", - "memoffset 0.6.5", + "memoffset 0.7.1", "puffin", "wasm-bindgen", "web-sys", @@ -1558,20 +1654,20 @@ dependencies = [ [[package]] name = "egui_plot" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c7f33a00fe8eb1ba56535b3dbacdecc7a1365a328908a97c5f3c81bb466be72b" +checksum = "b37b2edcdd197db41825266ae7979bd7591fa2eb6b40152375ac05eb323eb9d2" dependencies = [ "egui", ] [[package]] name = "egui_tiles" -version = "0.3.1" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54986fb00d53325eaa4033cb5d8b1c1a77d4173fa3ed0d6602c6a542b151ace9" +checksum = "9b0d2e43a355b2d49f85e288c80ba28a94d581a47abb8cf3de13262a2500abf6" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "egui", "itertools 0.11.0", "log", @@ -1602,9 +1698,9 @@ checksum = "7fcaabb2fef8c910e7f4c7ce9f67a1283a1715879a7c230ca9d6d1ae31f16d91" [[package]] name = "emath" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1ef2b29de53074e575c18b694167ccbe6e5191f7b25fe65175a0d905a32eeec0" +checksum = "a045c6c0b44b35e98513fc1e9d183ab42881ac27caccb9fa345465601f56cce4" dependencies = [ "bytemuck", "serde", @@ -1705,12 +1801,12 @@ dependencies = [ [[package]] name = "epaint" -version = "0.23.0" +version = "0.24.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "58067b840d009143934d91d8dcb8ded054d8301d7c11a517ace0a99bb1e1595e" +checksum = "7d1b9e000d21bab9b535ce78f9f7745be28b3f777f6c7223936561c5c7fefab8" dependencies = [ "ab_glyph", - "ahash 0.8.5", + "ahash 0.8.6", "bytemuck", "ecolor", "emath", @@ -1720,6 +1816,12 @@ dependencies = [ "serde", ] +[[package]] +name = "equivalent" +version = "1.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5443807d6dff69373d433ab9ef5378ad8df50ca6298caf15de6e52e24aaf54d5" + [[package]] name = "errno" version = "0.3.1" @@ -1763,6 +1865,27 @@ version = "2.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0206175f82b8d6bf6652ff7d71a1e27fd2e4efde587fd368662814d6ec1d9ce0" +[[package]] +name = "event-listener" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d93877bcde0eb80ca09131a08d23f0a5c18a620b01db137dba666d18cd9b30c2" +dependencies = [ + "concurrent-queue", + "parking", + "pin-project-lite", +] + +[[package]] +name = "event-listener-strategy" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d96b852f1345da36d551b9473fa1e2b1eb5c5195585c6c018118bc92a8d91160" +dependencies = [ + "event-listener 3.1.0", + "pin-project-lite", +] + [[package]] name = "ewebsock" version = "0.4.0" @@ -1789,6 +1912,12 @@ dependencies = [ "tokio", ] +[[package]] +name = "fallible-iterator" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4443176a9f2c162692bd3d352d745ef9413eec5782a80d8fd6f8a1ac692a07f7" + [[package]] name = "fastrand" version = "1.9.0" @@ -1858,6 +1987,18 @@ dependencies = [ "miniz_oxide 0.7.1", ] +[[package]] +name = "flume" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "55ac459de2512911e4b674ce33cf20befaba382d05b62b008afc1c8b57cbf181" +dependencies = [ + "futures-core", + "futures-sink", + "nanorand", + "spin 0.9.8", +] + [[package]] name = "fnv" version = "1.0.7" @@ -1993,6 +2134,16 @@ dependencies = [ "waker-fn", ] +[[package]] +name = "futures-lite" +version = "2.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3831c2651acb5177cbd83943f3d9c8912c5ad03c76afcc0e9511ba568ec5ebb" +dependencies = [ + "futures-core", + "pin-project-lite", +] + [[package]] name = "futures-macro" version = "0.3.28" @@ -2067,12 +2218,34 @@ dependencies = [ "wasm-bindgen", ] +[[package]] +name = "gimli" +version = "0.26.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "22030e2c5a68ec659fde1e949a745124b48e6fa8b045b7ed5bd1fe4ccc5c4e5d" +dependencies = [ + "fallible-iterator", + "indexmap 1.9.3", + "stable_deref_trait", +] + [[package]] name = "gimli" version = "0.27.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ad0a93d233ebf96623465aad4046a8d3aa4da22d4f4beba5388838c8a434bbb4" +[[package]] +name = "gl_generator" +version = "0.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1a95dfc23a2b4a9a2f5ab41d194f8bfda3cabec42af4e39f08c339eb2a0c124d" +dependencies = [ + "khronos_api", + "log", + "xml-rs", +] + [[package]] name = "glam" version = "0.22.0" @@ -2113,6 +2286,18 @@ dependencies = [ "web-sys", ] +[[package]] +name = "glow" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "886c2a30b160c4c6fec8f987430c26b526b7988ca71f664e6a699ddf6f9601e4" +dependencies = [ + "js-sys", + "slotmap", + "wasm-bindgen", + "web-sys", +] + [[package]] name = "gltf" version = "1.1.0" @@ -2151,13 +2336,22 @@ dependencies = [ "serde_json", ] +[[package]] +name = "glutin_wgl_sys" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c8098adac955faa2d31079b65dc48841251f69efd3ac25477903fc424362ead" +dependencies = [ + "gl_generator", +] + [[package]] name = "gpu-alloc" version = "0.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "fbcd2dba93594b227a1f57ee09b8b9da8892c34d55aa332e034a228d0fe6a171" dependencies = [ - "bitflags 2.3.1", + "bitflags 2.4.1", "gpu-alloc-types", ] @@ -2167,20 +2361,21 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "98ff03b468aa837d70984d55f5d3f846f6ec31fe34bbb97c4f85219caeee1ca4" dependencies = [ - "bitflags 2.3.1", + "bitflags 2.4.1", ] [[package]] name = "gpu-allocator" -version = "0.22.0" +version = "0.23.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ce95f9e2e11c2c6fadfce42b5af60005db06576f231f5c92550fdded43c423e8" +checksum = "40fe17c8a05d60c38c0a4e5a3c802f2f1ceb66b76c67d96ffb34bef0475a7fad" dependencies = [ "backtrace", "log", + "presser", "thiserror", "winapi", - "windows", + "windows 0.51.1", ] [[package]] @@ -2215,7 +2410,7 @@ dependencies = [ "futures-sink", "futures-util", "http", - "indexmap", + "indexmap 1.9.3", "slab", "tokio", "tokio-util", @@ -2260,10 +2455,16 @@ version = "0.13.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "43a3c133739dddd0d2990f9a4bdf8eb4b21ef50e4851ca85ab661199821d510e" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "rayon", ] +[[package]] +name = "hashbrown" +version = "0.14.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f93e7192158dbcda357bdec5fb5788eebf8bbac027f3f33e719d29135ae84156" + [[package]] name = "hassle-rs" version = "0.10.0" @@ -2273,7 +2474,7 @@ dependencies = [ "bitflags 1.3.2", "com-rs", "libc", - "libloading", + "libloading 0.7.4", "thiserror", "widestring", "winapi", @@ -2448,6 +2649,16 @@ dependencies = [ "hashbrown 0.12.3", ] +[[package]] +name = "indexmap" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d530e1a18b1cb4c484e6e34556a0d948706958449fca0cab753d649f2bce3d1f" +dependencies = [ + "equivalent", + "hashbrown 0.14.2", +] + [[package]] name = "indoc" version = "1.0.9" @@ -2533,7 +2744,7 @@ checksum = "adcf93614601c8129ddf72e2d5633df827ba6551541c6d8c59520a371475be1f" dependencies = [ "hermit-abi 0.3.1", "io-lifetimes", - "rustix", + "rustix 0.37.19", "windows-sys 0.48.0", ] @@ -2609,15 +2820,21 @@ dependencies = [ [[package]] name = "khronos-egl" -version = "4.1.0" +version = "6.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8c2352bd1d0bceb871cb9d40f24360c8133c11d7486b68b5381c1dd1a32015e3" +checksum = "6aae1df220ece3c0ada96b8153459b67eebe9ae9212258bb0134ae60416fdf76" dependencies = [ "libc", - "libloading", + "libloading 0.8.1", "pkg-config", ] +[[package]] +name = "khronos_api" +version = "3.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e2db585e1d738fc771bf08a151420d3ed193d9d895a36df7f6f8a9456b911ddc" + [[package]] name = "kqueue" version = "1.0.7" @@ -2725,9 +2942,9 @@ dependencies = [ [[package]] name = "libc" -version = "0.2.144" +version = "0.2.150" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b00cc1c228a6782d0f076e7b232802e0c5689d41bb5df366f2a6b6621cfdfe1" +checksum = "89d92a4743f9a61002fae18374ed11e7973f530cb3a3255fb354818118b2203c" [[package]] name = "libloading" @@ -2739,6 +2956,16 @@ dependencies = [ "winapi", ] +[[package]] +name = "libloading" +version = "0.8.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c571b676ddfc9a8c12f1f3d3085a7b163966a8fd8098a90640953ce5f6170161" +dependencies = [ + "cfg-if", + "windows-sys 0.48.0", +] + [[package]] name = "libm" version = "0.2.7" @@ -2767,6 +2994,12 @@ version = "0.3.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ef53942eb7bf7ff43a617b3e2c1c4a5ecf5944a7c1bc12d7ee39bbb15e5c1519" +[[package]] +name = "linux-raw-sys" +version = "0.4.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "969488b55f8ac402214f3f5fd243ebb7206cf82de60d3172994707a4bcc2b829" + [[package]] name = "litrs" version = "0.2.3" @@ -2817,9 +3050,9 @@ dependencies = [ [[package]] name = "lz4_flex" -version = "0.10.0" +version = "0.11.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8b8c72594ac26bfd34f2d99dfced2edfaddfe8a476e3ff2ca0eb293d925c4f83" +checksum = "3ea9b256699eda7b0387ffbc776dd625e28bde3918446381781245b7a50349d8" dependencies = [ "twox-hash", ] @@ -2917,11 +3150,11 @@ dependencies = [ [[package]] name = "metal" -version = "0.26.0" +version = "0.27.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "623b5e6cefd76e58f774bd3cc0c6f5c7615c58c03a97815245a25c3c9bdee318" +checksum = "c43f73953f8cbe511f021b58f18c3ce1c3d1ae13fe953293e13345bf83217f25" dependencies = [ - "bitflags 2.3.1", + "bitflags 2.4.1", "block", "core-graphics-types", "foreign-types 0.5.0", @@ -2955,6 +3188,16 @@ dependencies = [ "unicase", ] +[[package]] +name = "mime_guess2" +version = "2.0.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "25a3333bb1609500601edc766a39b4c1772874a4ce26022f4d866854dc020c41" +dependencies = [ + "mime", + "unicase", +] + [[package]] name = "minimal" version = "0.12.0-alpha.1+dev" @@ -3047,15 +3290,15 @@ dependencies = [ [[package]] name = "naga" -version = "0.13.0" +version = "0.14.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c1ceaaa4eedaece7e4ec08c55c640ba03dbb73fb812a6570a59bcf1930d0f70e" +checksum = "61d829abac9f5230a85d8cc83ec0879b4c09790208ae25b5ea031ef84562e071" dependencies = [ "bit-set", - "bitflags 2.3.1", + "bitflags 2.4.1", "codespan-reporting", "hexf-parse", - "indexmap", + "indexmap 2.1.0", "log", "num-traits", "rustc-hash", @@ -3065,6 +3308,15 @@ dependencies = [ "unicode-xid", ] +[[package]] +name = "nanorand" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6a51313c5820b0b02bd422f4b44776fbf47961755c74ce64afc73bfad10226c3" +dependencies = [ + "getrandom", +] + [[package]] name = "ndarray" version = "0.15.6" @@ -3515,7 +3767,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4dd7d28ee937e54fe3080c91faa1c3a46c06de6252988a7f4592ba2310ef22a4" dependencies = [ "fixedbitset", - "indexmap", + "indexmap 1.9.3", ] [[package]] @@ -3526,9 +3778,9 @@ checksum = "5be167a7af36ee22fe3115051bc51f6e6c7054c9348e28deb4f49bd6f705a315" [[package]] name = "pin-project-lite" -version = "0.2.9" +version = "0.2.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e0a7ae3ac2f1173085d398531c705756c94a4c56843785df85a60c1a0afac116" +checksum = "8afb450f006bf6385ca15ef45d71d2288452bc3683ce2e2cacc0d18e4be60b58" [[package]] name = "pin-utils" @@ -3612,14 +3864,14 @@ version = "0.29.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "caa1f5af0505c67333487c1287f29644c172afbab7374e48a77843646064411c" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "arrow2", "bitflags 1.3.2", "chrono", "comfy-table", "either", "hashbrown 0.13.2", - "indexmap", + "indexmap 1.9.3", "num-traits", "once_cell", "polars-arrow", @@ -3711,6 +3963,20 @@ dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "polling" +version = "3.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e53b6af1f60f36f8c2ac2aad5459d75a5a9b4be1e8cdd40264f315d78193e531" +dependencies = [ + "cfg-if", + "concurrent-queue", + "pin-project-lite", + "rustix 0.38.24", + "tracing", + "windows-sys 0.48.0", +] + [[package]] name = "pollster" version = "0.3.0" @@ -3723,6 +3989,12 @@ version = "0.2.17" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" +[[package]] +name = "presser" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e8cf8e6a8aa66ce33f63993ffc4ea4271eb5b0530a9002db8455ea6050c77bfa" + [[package]] name = "prettyplease" version = "0.1.25" @@ -3834,15 +4106,14 @@ dependencies = [ [[package]] name = "puffin" -version = "0.16.0" +version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "76425abd4e1a0ad4bd6995dd974b52f414fca9974171df8e3708b3e660d05a21" +checksum = "0e0b84517b2fb755da3a634bc030fcbc7b6337a786aa25a7fb350cdd51ab5e15" dependencies = [ "anyhow", "bincode", "byteorder", "cfg-if", - "instant", "lz4_flex", "once_cell", "parking_lot 0.12.1", @@ -3851,9 +4122,9 @@ dependencies = [ [[package]] name = "puffin_http" -version = "0.13.0" +version = "0.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "13bffc600c35913d282ae1e96a6ffcdf36dc7a7cdb9310e0ba15914d258c8193" +checksum = "fcf8e52cf00569807b02e8089a85e859c00476182730cda9718c94b12cdc31b8" dependencies = [ "anyhow", "crossbeam-channel", @@ -4056,7 +4327,7 @@ dependencies = [ name = "re_arrow_store" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "arrow2", "criterion", @@ -4145,7 +4416,7 @@ dependencies = [ name = "re_data_store" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "criterion", "document-features", @@ -4176,7 +4447,7 @@ dependencies = [ name = "re_data_ui" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "bytemuck", "egui", @@ -4268,7 +4539,7 @@ dependencies = [ name = "re_log_types" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "arrow2", "backtrace", @@ -4303,7 +4574,7 @@ dependencies = [ name = "re_memory" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "backtrace", "emath", "itertools 0.11.0", @@ -4347,7 +4618,7 @@ dependencies = [ name = "re_renderer" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "arrow2", "async-executor", @@ -4400,7 +4671,7 @@ dependencies = [ name = "re_sdk" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "crossbeam", "document-features", @@ -4430,7 +4701,7 @@ dependencies = [ name = "re_sdk_comms" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "crossbeam", "document-features", "rand", @@ -4492,7 +4763,7 @@ dependencies = [ name = "re_space_view_spatial" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "bytemuck", "criterion", @@ -4526,7 +4797,7 @@ dependencies = [ name = "re_space_view_tensor" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "bytemuck", "egui", @@ -4607,7 +4878,7 @@ dependencies = [ name = "re_string_interner" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "nohash-hasher", "once_cell", "parking_lot 0.12.1", @@ -4618,7 +4889,7 @@ dependencies = [ name = "re_tensor_ops" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "ndarray", "re_types", "serde", @@ -4763,7 +5034,7 @@ dependencies = [ name = "re_viewer" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "bytemuck", "cfg-if", @@ -4822,7 +5093,7 @@ dependencies = [ name = "re_viewer_context" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "anyhow", "arboard", "bytemuck", @@ -4860,7 +5131,7 @@ dependencies = [ name = "re_viewport" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "arrow2", "egui", "egui_tiles", @@ -5038,7 +5309,7 @@ dependencies = [ name = "rerun_c" version = "0.12.0-alpha.1+dev" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", "arrow2", "once_cell", "parking_lot 0.12.1", @@ -5082,7 +5353,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "241a0deb168c88050d872294f7b3106c1dfa8740942bcc97bc91b98e97b5c501" dependencies = [ "ashpd", - "async-io", + "async-io 1.13.0", "block", "dispatch", "futures-util", @@ -5109,7 +5380,7 @@ dependencies = [ "cc", "libc", "once_cell", - "spin", + "spin 0.5.2", "untrusted", "web-sys", "winapi", @@ -5362,7 +5633,20 @@ dependencies = [ "errno", "io-lifetimes", "libc", - "linux-raw-sys", + "linux-raw-sys 0.3.8", + "windows-sys 0.48.0", +] + +[[package]] +name = "rustix" +version = "0.38.24" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ad981d6c340a49cdc40a1028d9c6084ec7e9fa33fcb839cab656a267071e234" +dependencies = [ + "bitflags 2.4.1", + "errno", + "libc", + "linux-raw-sys 0.4.11", "windows-sys 0.48.0", ] @@ -5515,7 +5799,7 @@ version = "0.9.21" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d9d684e3ec7de3bf5466b32bd75303ac16f0736426e5a4e0d6e489559ce1249c" dependencies = [ - "indexmap", + "indexmap 1.9.3", "itoa", "ryu", "serde", @@ -5715,6 +5999,15 @@ version = "0.5.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6e63cff320ae2c57904679ba7cb63280a3dc4613885beafb148ee7bf9aa9042d" +[[package]] +name = "spin" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6980e8d7511241f8acf4aebddbb1ff938df5eebe98691418c4468d0b72a96a67" +dependencies = [ + "lock_api", +] + [[package]] name = "spirv" version = "0.2.0+1.5.4" @@ -5725,6 +6018,12 @@ dependencies = [ "num-traits", ] +[[package]] +name = "stable_deref_trait" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a8f112729512f8e442d81f95a8a7ddf2b7c6b8a1a6f509a95864142b30cab2d3" + [[package]] name = "static_assertions" version = "1.1.0" @@ -5840,7 +6139,7 @@ dependencies = [ "cfg-if", "fastrand", "redox_syscall 0.3.5", - "rustix", + "rustix 0.37.19", "windows-sys 0.45.0", ] @@ -6011,7 +6310,7 @@ version = "4.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b450e3ba06251ec4fc76917dafeaf55805ffb26dbf7d5500bfb9511ce63a0d1f" dependencies = [ - "ahash 0.8.5", + "ahash 0.8.6", ] [[package]] @@ -6081,7 +6380,7 @@ version = "0.19.10" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2380d56e8670370eee6566b0bfd4265f65b3f432e8c6d85623f728d4fa31f739" dependencies = [ - "indexmap", + "indexmap 1.9.3", "toml_datetime", "winnow", ] @@ -6363,15 +6662,17 @@ dependencies = [ [[package]] name = "walrus" -version = "0.19.0" +version = "0.20.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4eb08e48cde54c05f363d984bb54ce374f49e242def9468d2e1b6c2372d291f8" +checksum = "2c03529cd0c4400a2449f640d2f27cd1b48c3065226d15e26d98e4429ab0adb7" dependencies = [ "anyhow", + "gimli 0.26.2", "id-arena", "leb128", "log", "walrus-macro", + "wasm-encoder", "wasmparser", ] @@ -6405,9 +6706,9 @@ checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423" [[package]] name = "wasm-bindgen" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7706a72ab36d8cb1f80ffbf0e071533974a60d0a308d01a5d0375bf60499a342" +checksum = "0ed0d4f68a3015cc185aff4db9506a015f4b96f95303897bfa23f846db54064e" dependencies = [ "cfg-if", "wasm-bindgen-macro", @@ -6415,9 +6716,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-backend" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5ef2b6d3c510e9625e5fe6f509ab07d66a760f0885d858736483c32ed7809abd" +checksum = "1b56f625e64f3a1084ded111c4d5f477df9f8c92df113852fa5a374dbda78826" dependencies = [ "bumpalo", "log", @@ -6430,9 +6731,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-cli-support" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d21c60239a09bf9bab8dfa752be4e6c637db22296b9ded493800090448692da9" +checksum = "cf8226e223e2dfbe8f921b7f20b82d1b5d86a6b143e9d6286cca8edd16695583" dependencies = [ "anyhow", "base64 0.9.3", @@ -6452,9 +6753,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-externref-xform" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bafbe1984f67cc12645f12ab65e6145e8ddce1ab265d0be58435f25bb0ce2608" +checksum = "b8a719be856d8b0802c7195ca26ee6eb02cb9639a12b80be32db960ce9640cb8" dependencies = [ "anyhow", "walrus", @@ -6474,9 +6775,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dee495e55982a3bd48105a7b947fd2a9b4a8ae3010041b9e0faab3f9cd028f1d" +checksum = "0162dbf37223cd2afce98f3d0785506dcb8d266223983e4b5b525859e6e182b2" dependencies = [ "quote", "wasm-bindgen-macro-support", @@ -6484,9 +6785,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-macro-support" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "54681b18a46765f095758388f2d0cf16eb8d4169b639ab575a8f5693af210c7b" +checksum = "f0eb82fcb7930ae6219a7ecfd55b217f5f0893484b7a13022ebb2b2bf20b5283" dependencies = [ "proc-macro2", "quote", @@ -6497,9 +6798,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-multi-value-xform" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "581419e3995571a1d2d066e360ca1c0c09da097f5a53c98e6f00d96eddaf0ffe" +checksum = "a12766255d4b9026700376cc81894eeb62903e4414cbc94675f6f9babd9cfb76" dependencies = [ "anyhow", "walrus", @@ -6507,15 +6808,15 @@ dependencies = [ [[package]] name = "wasm-bindgen-shared" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca6ad05a4870b2bf5fe995117d3728437bd27d7cd5f06f13c17443ef369775a1" +checksum = "7ab9b36309365056cd639da3134bf87fa8f3d86008abf99e612384a6eecd459f" [[package]] name = "wasm-bindgen-threads-xform" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e05d272073981137e8426cf2a6830d43d1f84f988a050b2f8b210f0e266b8983" +checksum = "13c2b14c5b9c2c7aa9dd1eb7161857de9783f40e98582e7f41f2d7c04ffdc155" dependencies = [ "anyhow", "walrus", @@ -6524,9 +6825,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-wasm-conventions" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0e9c65b1ff5041ea824ca24c519948aec16fb6611c617d601623c0657dfcd47b" +checksum = "aaedf88769cb23c6fd2e3bfed65bcbff6c5d92c8336afbd80d2dfcc8eb5cf047" dependencies = [ "anyhow", "walrus", @@ -6534,9 +6835,9 @@ dependencies = [ [[package]] name = "wasm-bindgen-wasm-interpreter" -version = "0.2.87" +version = "0.2.89" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7c5c796220738ab5d44666f37205728a74141c0039d1166bcf8110b26bafaa1e" +checksum = "a8a79039df1e0822e6d66508ec86052993deac201e26060f62abcd85e1daf951" dependencies = [ "anyhow", "log", @@ -6544,6 +6845,15 @@ dependencies = [ "wasm-bindgen-wasm-conventions", ] +[[package]] +name = "wasm-encoder" +version = "0.29.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "18c41dbd92eaebf3612a39be316540b8377c871cb9bde6b064af962984912881" +dependencies = [ + "leb128", +] + [[package]] name = "wasm-streams" version = "0.3.0" @@ -6574,9 +6884,9 @@ dependencies = [ [[package]] name = "wasmparser" -version = "0.77.1" +version = "0.80.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5fe3d5405e9ea6c1317a656d6e0820912d8b7b3607823a7596117c8f666daf6f" +checksum = "449167e2832691a1bff24cde28d2804e90e09586a448c8e76984792c44334a6b" [[package]] name = "wayland-client" @@ -6716,12 +7026,13 @@ checksum = "9193164d4de03a926d909d3bc7c30543cecb35400c02114792c2cae20d5e2dbb" [[package]] name = "wgpu" -version = "0.17.0" +version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7472f3b69449a8ae073f6ec41d05b6f846902d92a6c45313c50cb25857b736ce" +checksum = "30e7d227c9f961f2061c26f4cb0fbd4df0ef37e056edd0931783599d6c94ef24" dependencies = [ "arrayvec", "cfg-if", + "flume", "js-sys", "log", "naga", @@ -6740,13 +7051,13 @@ dependencies = [ [[package]] name = "wgpu-core" -version = "0.17.0" +version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ecf7454d9386f602f7399225c92dd2fbdcde52c519bc8fb0bd6fbeb388075dc2" +checksum = "837e02ddcdc6d4a9b56ba4598f7fd4202a7699ab03f6ef4dcdebfad2c966aea6" dependencies = [ "arrayvec", "bit-vec", - "bitflags 2.3.1", + "bitflags 2.4.1", "codespan-reporting", "log", "naga", @@ -6763,19 +7074,20 @@ dependencies = [ [[package]] name = "wgpu-hal" -version = "0.17.0" +version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6654a13885a17f475e8324efb46dc6986d7aaaa98353330f8de2077b153d0101" +checksum = "1e30b9a8155c83868e82a8c5d3ce899de6c3961d2ef595de8fc168a1677fc2d8" dependencies = [ "android_system_properties", "arrayvec", "ash", "bit-set", - "bitflags 2.3.1", + "bitflags 2.4.1", "block", "core-graphics-types", "d3d12", - "glow", + "glow 0.13.0", + "glutin_wgl_sys", "gpu-alloc", "gpu-allocator", "gpu-descriptor", @@ -6783,11 +7095,12 @@ dependencies = [ "js-sys", "khronos-egl", "libc", - "libloading", + "libloading 0.8.1", "log", "metal", "naga", "objc", + "once_cell", "parking_lot 0.12.1", "profiling", "range-alloc", @@ -6804,11 +7117,11 @@ dependencies = [ [[package]] name = "wgpu-types" -version = "0.17.0" +version = "0.18.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ee64d7398d0c2f9ca48922c902ef69c42d000c759f3db41e355f4a570b052b67" +checksum = "0d5ed5f0edf0de351fe311c53304986315ce866f394a2e6df0c4b3c70774bcdd" dependencies = [ - "bitflags 2.3.1", + "bitflags 2.4.1", "js-sys", "web-sys", ] @@ -6872,20 +7185,39 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f" [[package]] name = "windows" -version = "0.44.0" +version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9e745dab35a0c4c77aa3ce42d595e13d2003d6902d6b08c9ef5fc326d08da12b" +checksum = "e686886bc078bc1b0b600cac0147aadb815089b6e4da64016cbd754b6342700f" dependencies = [ "windows-implement", "windows-interface", - "windows-targets 0.42.2", + "windows-targets 0.48.5", +] + +[[package]] +name = "windows" +version = "0.51.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca229916c5ee38c2f2bc1e9d8f04df975b4bd93f9955dc69fabb5d91270045c9" +dependencies = [ + "windows-core", + "windows-targets 0.48.5", +] + +[[package]] +name = "windows-core" +version = "0.51.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f1f8cf84f35d2db49a46868f947758c7a1138116f7fac3bc844f43ade1292e64" +dependencies = [ + "windows-targets 0.48.5", ] [[package]] name = "windows-implement" -version = "0.44.0" +version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6ce87ca8e3417b02dc2a8a22769306658670ec92d78f1bd420d6310a67c245c6" +checksum = "5e2ee588991b9e7e6c8338edf3333fbe4da35dc72092643958ebb43f0ab2c49c" dependencies = [ "proc-macro2", "quote", @@ -6894,9 +7226,9 @@ dependencies = [ [[package]] name = "windows-interface" -version = "0.44.0" +version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "853f69a591ecd4f810d29f17e902d40e349fb05b0b11fff63b08b826bfe39c7f" +checksum = "e6fb8df20c9bcaa8ad6ab513f7b40104840c8867d5751126e4df3b08388d0cc7" dependencies = [ "proc-macro2", "quote", @@ -6918,7 +7250,7 @@ version = "0.48.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9" dependencies = [ - "windows-targets 0.48.0", + "windows-targets 0.48.5", ] [[package]] @@ -6938,17 +7270,17 @@ dependencies = [ [[package]] name = "windows-targets" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7b1eb6f0cd7c80c79759c929114ef071b87354ce476d9d94271031c0497adfd5" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" dependencies = [ - "windows_aarch64_gnullvm 0.48.0", - "windows_aarch64_msvc 0.48.0", - "windows_i686_gnu 0.48.0", - "windows_i686_msvc 0.48.0", - "windows_x86_64_gnu 0.48.0", - "windows_x86_64_gnullvm 0.48.0", - "windows_x86_64_msvc 0.48.0", + "windows_aarch64_gnullvm 0.48.5", + "windows_aarch64_msvc 0.48.5", + "windows_i686_gnu 0.48.5", + "windows_i686_msvc 0.48.5", + "windows_x86_64_gnu 0.48.5", + "windows_x86_64_gnullvm 0.48.5", + "windows_x86_64_msvc 0.48.5", ] [[package]] @@ -6959,9 +7291,9 @@ checksum = "597a5118570b68bc08d8d59125332c54f1ba9d9adeedeef5b99b02ba2b0698f8" [[package]] name = "windows_aarch64_gnullvm" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" [[package]] name = "windows_aarch64_msvc" @@ -6971,9 +7303,9 @@ checksum = "e08e8864a60f06ef0d0ff4ba04124db8b0fb3be5776a5cd47641e942e58c4d43" [[package]] name = "windows_aarch64_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" [[package]] name = "windows_i686_gnu" @@ -6983,9 +7315,9 @@ checksum = "c61d927d8da41da96a81f029489353e68739737d3beca43145c8afec9a31a84f" [[package]] name = "windows_i686_gnu" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" [[package]] name = "windows_i686_msvc" @@ -6995,9 +7327,9 @@ checksum = "44d840b6ec649f480a41c8d80f9c65108b92d89345dd94027bfe06ac444d1060" [[package]] name = "windows_i686_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" [[package]] name = "windows_x86_64_gnu" @@ -7007,9 +7339,9 @@ checksum = "8de912b8b8feb55c064867cf047dda097f92d51efad5b491dfb98f6bbb70cb36" [[package]] name = "windows_x86_64_gnu" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" [[package]] name = "windows_x86_64_gnullvm" @@ -7019,9 +7351,9 @@ checksum = "26d41b46a36d453748aedef1486d5c7a85db22e56aff34643984ea85514e94a3" [[package]] name = "windows_x86_64_gnullvm" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" [[package]] name = "windows_x86_64_msvc" @@ -7031,9 +7363,9 @@ checksum = "9aec5da331524158c6d1a4ac0ab1541149c0b9505fde06423b02f5ef0106b9f0" [[package]] name = "windows_x86_64_msvc" -version = "0.48.0" +version = "0.48.5" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" [[package]] name = "winit" @@ -7169,22 +7501,24 @@ dependencies = [ [[package]] name = "zbus" -version = "3.12.0" +version = "3.14.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "29242fa5ec5693629ae74d6eb1f69622a9511f600986d6d9779bccf36ac316e3" +checksum = "31de390a2d872e4cd04edd71b425e29853f786dc99317ed72d73d6fcf5ebb948" dependencies = [ "async-broadcast", "async-executor", "async-fs", - "async-io", - "async-lock", + "async-io 1.13.0", + "async-lock 2.7.0", + "async-process", "async-recursion", "async-task", "async-trait", + "blocking", "byteorder", "derivative", "enumflags2", - "event-listener", + "event-listener 2.5.3", "futures-core", "futures-sink", "futures-util", @@ -7208,9 +7542,9 @@ dependencies = [ [[package]] name = "zbus_macros" -version = "3.12.0" +version = "3.14.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "537793e26e9af85f774801dc52c6f6292352b2b517c5cf0449ffd3735732a53a" +checksum = "41d1794a946878c0e807f55a397187c11fc7a038ba5d868e7db4f3bd7760bc9d" dependencies = [ "proc-macro-crate", "proc-macro2", @@ -7222,9 +7556,9 @@ dependencies = [ [[package]] name = "zbus_names" -version = "2.5.1" +version = "2.6.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "82441e6033be0a741157a72951a3e4957d519698f3a824439cc131c5ba77ac2a" +checksum = "fb80bb776dbda6e23d705cf0123c3b95df99c4ebeaec6c2599d4a5419902b4a9" dependencies = [ "serde", "static_assertions", @@ -7233,18 +7567,18 @@ dependencies = [ [[package]] name = "zerocopy" -version = "0.7.11" +version = "0.7.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c19fae0c8a9efc6a8281f2e623db8af1db9e57852e04cde3e754dd2dc29340f" +checksum = "686b7e407015242119c33dab17b8f61ba6843534de936d94368856528eae4dcc" dependencies = [ "zerocopy-derive", ] [[package]] name = "zerocopy-derive" -version = "0.7.11" +version = "0.7.21" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fc56589e9ddd1f1c28d4b4b5c773ce232910a6bb67a70133d61c9e347585efe9" +checksum = "020f3dfe25dfc38dfea49ce62d5d45ecdd7f0d8a724fa63eb36b6eba4ec76806" dependencies = [ "proc-macro2", "quote", @@ -7269,7 +7603,7 @@ version = "0.2.14" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "29ca36c2e02af0d8d7ee977542bfe33ed1c516be73d3c1faa4420af46e96ceee" dependencies = [ - "bitflags 2.3.1", + "bitflags 2.4.1", ] [[package]] @@ -7284,9 +7618,9 @@ dependencies = [ [[package]] name = "zvariant" -version = "3.13.0" +version = "3.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5cb36cd95352132911c9c99fdcc1635de5c2c139bd34cbcf6dfb8350ee8ff6a7" +checksum = "44b291bee0d960c53170780af148dca5fa260a63cdd24f1962fa82e03e53338c" dependencies = [ "byteorder", "enumflags2", @@ -7299,9 +7633,9 @@ dependencies = [ [[package]] name = "zvariant_derive" -version = "3.13.0" +version = "3.15.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9b34951e1ac64f3a1443fe7181256b9ed6a811a1631917566c3d5ca718d8cf33" +checksum = "934d7a7dfc310d6ee06c87ffe88ef4eca7d3e37bb251dece2ef93da8f17d8ecd" dependencies = [ "proc-macro-crate", "proc-macro2", @@ -7312,9 +7646,9 @@ dependencies = [ [[package]] name = "zvariant_utils" -version = "1.0.0" +version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53b22993dbc4d128a17a3b6c92f1c63872dd67198537ee728d8b5d7c40640a8b" +checksum = "7234f0d811589db492d16893e3f21e8e2fd282e6d01b0cddee310322062cc200" dependencies = [ "proc-macro2", "quote", diff --git a/Cargo.toml b/Cargo.toml index 5b3123f08538..3e8992693368 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -70,6 +70,28 @@ re_web_viewer_server = { path = "crates/re_web_viewer_server", version = "=0.12. re_ws_comms = { path = "crates/re_ws_comms", version = "=0.12.0-alpha.1", default-features = false } rerun = { path = "crates/rerun", version = "=0.12.0-alpha.1", default-features = false } +# egui-crates: +ecolor = "0.24.1" +eframe = { version = "0.24.1", default-features = false, features = [ + "accesskit", + "default_fonts", + "puffin", + "wayland", + "x11", +] } +egui = { version = "0.24.1", features = [ + "callstack", + "extra_debug_asserts", + "log", + "puffin", +] } +egui_commonmark = { version = "0.10", default-features = false } +egui_extras = { version = "0.24.1", features = ["http", "image", "puffin"] } +egui_plot = "0.24.1" +egui_tiles = "0.4" +egui-wgpu = "0.24.1" +emath = "0.24.1" + # All of our direct external dependencies should be found here: ahash = "0.8" anyhow = "1.0" @@ -94,27 +116,7 @@ criterion = "0.5" crossbeam = "0.8" directories-next = "2" document-features = "0.2" -ecolor = "0.23.0" -eframe = { version = "0.23.0", default-features = false, features = [ - "accesskit", - "default_fonts", - "puffin", - "wayland", - "x11", -] } -egui = { version = "0.23.0", features = [ - "callstack", - "extra_debug_asserts", - "log", - "puffin", -] } -egui_commonmark = { version = "0.9.2", default-features = false } -egui_extras = { version = "0.23.0", features = ["http", "image", "puffin"] } -egui_plot = "0.23.0" -egui_tiles = "0.3.1" -egui-wgpu = "0.23.0" ehttp = "0.3.1" -emath = "0.23.0" enumset = "1.0.12" env_logger = "0.10" epaint = "0.23.0" @@ -132,6 +134,7 @@ infer = "0.15" # infer MIME type by checking the magic number signature itertools = "0.11" js-sys = "0.3" lazy_static = "1.4" +lz4_flex = "0.11" log = "0.4" log-once = "0.4" macaw = "0.18" @@ -156,8 +159,8 @@ polars-lazy = "0.29" polars-ops = "0.29" poll-promise = "0.3" pollster = "0.3" -puffin = "0.16" -puffin_http = "0.13" +puffin = "0.18" +puffin_http = "0.15" rand = { version = "0.8", default-features = false } rayon = "1.7" rfd = { version = "0.12", default_features = false, features = ["xdg-portal"] } @@ -192,7 +195,7 @@ unindent = "0.1" uuid = "1.1" vec1 = "1.8" walkdir = "2.0" -wasm-bindgen = "0.2.87" +wasm-bindgen = "0.2.89" wasm-bindgen-futures = "0.4.33" web-sys = "0.3.61" web-time = "0.2.0" @@ -200,8 +203,8 @@ webbrowser = "0.8" winit = "0.28.7" # TODO(andreas): Try to get rid of `fragile-send-sync-non-atomic-wasm`. This requires re_renderer being aware of single-thread restriction on resources. # See also https://gpuweb.github.io/gpuweb/explainer/#multithreading-transfer (unsolved part of the Spec as of writing!) -wgpu = { version = "0.17.0", features = ["fragile-send-sync-non-atomic-wasm"] } -wgpu-core = "0.17.0" +wgpu = { version = "0.18.0", features = ["fragile-send-sync-non-atomic-wasm"] } +wgpu-core = "0.18.0" xshell = "0.2" zip = { version = "0.6", default-features = false } zune-core = "0.2" @@ -232,3 +235,20 @@ debug = true # If that is not possible, patch to a branch that has a PR open on the upstream repo. # As a last resport, patch with a commit to our own repository. # ALWAYS document what PR the commit hash is part of, or when it was merged into the upstream trunk. + +# ecolor = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# eframe = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# egui = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# egui_extras = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# egui-wgpu = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# emath = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 +# epaint = { git = "https://github.com/emilk/egui.git", rev = "a2b15b23ad26f077e229d492cd1571d97217d570" } # egui master 2023-11-23 + +# Useful while developing: +# ecolor = { path = "../../egui/crates/ecolor" } +# eframe = { path = "../../egui/crates/eframe" } +# egui = { path = "../../egui/crates/egui" } +# egui_extras = { path = "../../egui/crates/egui_extras" } +# egui-wgpu = { path = "../../egui/crates/egui-wgpu" } +# emath = { path = "../../egui/crates/emath" } +# epaint = { path = "../../egui/crates/epaint" } diff --git a/crates/re_build_web_viewer/Cargo.toml b/crates/re_build_web_viewer/Cargo.toml index ccde803a299e..9046c0cd45a1 100644 --- a/crates/re_build_web_viewer/Cargo.toml +++ b/crates/re_build_web_viewer/Cargo.toml @@ -21,4 +21,4 @@ re_error.workspace = true anyhow.workspace = true cargo_metadata = "0.15" -wasm-bindgen-cli-support = "0.2.87" +wasm-bindgen-cli-support = "0.2.89" diff --git a/crates/re_log_encoding/Cargo.toml b/crates/re_log_encoding/Cargo.toml index f12118f83506..35bcbe044f8b 100644 --- a/crates/re_log_encoding/Cargo.toml +++ b/crates/re_log_encoding/Cargo.toml @@ -42,20 +42,20 @@ thiserror.workspace = true web-time.workspace = true # Optional external dependencies: +lz4_flex = { workspace = true, optional = true } rmp-serde = { workspace = true, optional = true } -lz4_flex = { version = "0.10", optional = true } # Web dependencies: [target.'cfg(target_arch = "wasm32")'.dependencies] -js-sys = "0.3" -wasm-bindgen = "0.2" -wasm-bindgen-futures = "0.4" -web-sys = { version = "0.3.52", features = ["Window"] } +js-sys.workspace = true +wasm-bindgen.workspace = true +wasm-bindgen-futures.workspace = true +web-sys = { workspace = true, features = ["Window"] } [dev-dependencies] re_types = { workspace = true, features = ["datagen", "serde"] } -criterion = "0.5" +criterion.workspace = true mimalloc.workspace = true serde_test.workspace = true diff --git a/crates/re_renderer/examples/framework.rs b/crates/re_renderer/examples/framework.rs index 74c5b9cff610..6ee3231e4ee3 100644 --- a/crates/re_renderer/examples/framework.rs +++ b/crates/re_renderer/examples/framework.rs @@ -112,7 +112,9 @@ impl Application { let size = window.inner_size(); let instance = wgpu::Instance::new(wgpu::InstanceDescriptor { backends: supported_backends(), + flags: wgpu::InstanceFlags::default(), dx12_shader_compiler: wgpu::Dx12Compiler::Fxc, + gles_minor_version: wgpu::Gles3MinorVersion::Automatic, }); #[allow(unsafe_code, clippy::undocumented_unsafe_blocks)] let surface = unsafe { instance.create_surface(&window) }.unwrap(); @@ -282,10 +284,12 @@ impl Application { resolve_target: None, ops: wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::BLACK), - store: true, + store: wgpu::StoreOp::Store, }, })], depth_stencil_attachment: None, + timestamp_writes: None, + occlusion_query_set: None, }); for draw_result in &draw_results { diff --git a/crates/re_renderer/src/draw_phases/outlines.rs b/crates/re_renderer/src/draw_phases/outlines.rs index 66ff1b5e891e..e57e35511791 100644 --- a/crates/re_renderer/src/draw_phases/outlines.rs +++ b/crates/re_renderer/src/draw_phases/outlines.rs @@ -354,17 +354,19 @@ impl OutlineMaskProcessor { resolve_target: None, // We're going to do a manual resolve. ops: wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT), - store: true, + store: wgpu::StoreOp::Store, }, })], depth_stencil_attachment: Some(wgpu::RenderPassDepthStencilAttachment { view: &self.mask_depth.default_view, depth_ops: Some(wgpu::Operations { load: ViewBuilder::DEFAULT_DEPTH_CLEAR, - store: false, + store: wgpu::StoreOp::Discard, }), stencil_ops: None, }), + timestamp_writes: None, + occlusion_query_set: None, }) } @@ -377,7 +379,7 @@ impl OutlineMaskProcessor { let ops = wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT), // Clear is the closest to "don't care" - store: true, + store: wgpu::StoreOp::Store, }; // Initialize the jump flooding into voronoi texture 0 by looking at the mask texture. @@ -390,6 +392,8 @@ impl OutlineMaskProcessor { ops, })], depth_stencil_attachment: None, + timestamp_writes: None, + occlusion_query_set: None, }); let render_pipeline_init = @@ -412,6 +416,8 @@ impl OutlineMaskProcessor { ops, })], depth_stencil_attachment: None, + timestamp_writes: None, + occlusion_query_set: None, }); jumpflooding_step.set_pipeline(render_pipeline_step); diff --git a/crates/re_renderer/src/draw_phases/picking_layer.rs b/crates/re_renderer/src/draw_phases/picking_layer.rs index cdd738270c51..c11ca73f4271 100644 --- a/crates/re_renderer/src/draw_phases/picking_layer.rs +++ b/crates/re_renderer/src/draw_phases/picking_layer.rs @@ -321,17 +321,19 @@ impl PickingLayerProcessor { resolve_target: None, ops: wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT), - store: true, // Store for readback! + store: wgpu::StoreOp::Store, // Store for readback! }, })], depth_stencil_attachment: Some(wgpu::RenderPassDepthStencilAttachment { view: &self.picking_depth_target.default_view, depth_ops: Some(wgpu::Operations { load: ViewBuilder::DEFAULT_DEPTH_CLEAR, - store: true, // Store for readback! + store: wgpu::StoreOp::Store, // Store for readback! }), stencil_ops: None, }), + timestamp_writes: None, + occlusion_query_set: None, }); pass.set_bind_group(0, &self.bind_group_0, &[]); @@ -590,10 +592,12 @@ impl DepthReadbackWorkaround { resolve_target: None, ops: wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT), - store: true, // Store for readback! + store: wgpu::StoreOp::Store, // Store for readback! }, })], depth_stencil_attachment: None, + timestamp_writes: None, + occlusion_query_set: None, }); let pipeline = pools.render_pipelines.get_resource(self.render_pipeline)?; diff --git a/crates/re_renderer/src/draw_phases/screenshot.rs b/crates/re_renderer/src/draw_phases/screenshot.rs index b5759245ed9e..28a46398f9e9 100644 --- a/crates/re_renderer/src/draw_phases/screenshot.rs +++ b/crates/re_renderer/src/draw_phases/screenshot.rs @@ -88,10 +88,12 @@ impl ScreenshotProcessor { resolve_target: None, ops: wgpu::Operations { load: wgpu::LoadOp::Clear(wgpu::Color::TRANSPARENT), - store: true, + store: wgpu::StoreOp::Store, }, })], depth_stencil_attachment: None, + timestamp_writes: None, + occlusion_query_set: None, }); pass diff --git a/crates/re_renderer/src/view_builder.rs b/crates/re_renderer/src/view_builder.rs index f46f2752c706..07dc9e4d6b33 100644 --- a/crates/re_renderer/src/view_builder.rs +++ b/crates/re_renderer/src/view_builder.rs @@ -556,17 +556,19 @@ impl ViewBuilder { }), // Don't care about the result, it's going to be resolved to the resolve target. // This can have be much better perf, especially on tiler gpus. - store: false, + store: wgpu::StoreOp::Discard, }, })], depth_stencil_attachment: Some(wgpu::RenderPassDepthStencilAttachment { view: &setup.depth_buffer.default_view, depth_ops: Some(wgpu::Operations { load: Self::DEFAULT_DEPTH_CLEAR, - store: false, + store: wgpu::StoreOp::Discard, }), stencil_ops: None, }), + timestamp_writes: None, + occlusion_query_set: None, }); pass.set_bind_group(0, &setup.bind_group_0, &[]); diff --git a/crates/re_space_view_bar_chart/src/space_view_class.rs b/crates/re_space_view_bar_chart/src/space_view_class.rs index de57e1da1c53..af56a3cf00cd 100644 --- a/crates/re_space_view_bar_chart/src/space_view_class.rs +++ b/crates/re_space_view_bar_chart/src/space_view_class.rs @@ -141,13 +141,9 @@ impl SpaceViewClass for BarChartSpaceView { let zoom_both_axis = !ui.input(|i| i.modifiers.contains(controls::ASPECT_SCROLL_MODIFIER)); ui.scope(|ui| { - let mut plot = - Plot::new("bar_chart_plot") - .clamp_grid(true) - .allow_zoom(egui_plot::AxisBools { - x: true, - y: zoom_both_axis, - }); + let mut plot = Plot::new("bar_chart_plot") + .clamp_grid(true) + .allow_zoom([true, zoom_both_axis]); if *root_entity_properties.show_legend { plot = plot.legend(Legend { diff --git a/crates/re_space_view_spatial/src/eye.rs b/crates/re_space_view_spatial/src/eye.rs index a3119e72a68a..8955c67b08df 100644 --- a/crates/re_space_view_spatial/src/eye.rs +++ b/crates/re_space_view_spatial/src/eye.rs @@ -371,6 +371,8 @@ impl OrbitEye { return; // e.g. we're typing in a TextField } + let os = egui_ctx.os(); + let requires_repaint = egui_ctx.input(|input| { let dt = input.stable_dt.at_most(0.1); @@ -390,10 +392,7 @@ impl OrbitEye { } else { 1.0 }) - * (if input - .modifiers - .contains(RuntimeModifiers::slow_down(&egui_ctx.os())) - { + * (if input.modifiers.contains(RuntimeModifiers::slow_down(&os)) { 0.1 } else { 1.0 diff --git a/crates/re_space_view_time_series/src/space_view_class.rs b/crates/re_space_view_time_series/src/space_view_class.rs index 856421888b2f..6f2df44303ef 100644 --- a/crates/re_space_view_time_series/src/space_view_class.rs +++ b/crates/re_space_view_time_series/src/space_view_class.rs @@ -193,10 +193,7 @@ impl SpaceViewClass for TimeSeriesSpaceView { let time_zone_for_timestamps = ctx.app_options.time_zone_for_timestamps; let mut plot = Plot::new(plot_id_src) - .allow_zoom(egui_plot::AxisBools { - x: true, - y: zoom_both_axis, - }) + .allow_zoom([true, zoom_both_axis]) .x_axis_formatter(move |time, _, _| { format_time( time_type, diff --git a/crates/re_time_panel/src/lib.rs b/crates/re_time_panel/src/lib.rs index 523f242c0037..005dc6147acc 100644 --- a/crates/re_time_panel/src/lib.rs +++ b/crates/re_time_panel/src/lib.rs @@ -143,7 +143,7 @@ impl TimePanel { ui.visuals().widgets.noninteractive.bg_stroke, ); - ui.spacing_mut().scroll_bar_outer_margin = 4.0; // needed, because we have no panel margin on the right side. + ui.spacing_mut().scroll.bar_outer_margin = 4.0; // needed, because we have no panel margin on the right side. // Add extra margin on the left which was intentionally missing on the controls. let mut streams_frame = egui::Frame::default(); @@ -238,7 +238,7 @@ impl TimePanel { let time_bg_x_range = Rangef::new(time_x_left, ui.max_rect().right()); let time_fg_x_range = { // Painting to the right of the scroll bar (if any) looks bad: - let right = ui.max_rect().right() - ui.spacing_mut().scroll_bar_outer_margin; + let right = ui.max_rect().right() - ui.spacing_mut().scroll.bar_outer_margin; debug_assert!(time_x_left < right); Rangef::new(time_x_left, right) }; diff --git a/crates/re_ui/Cargo.toml b/crates/re_ui/Cargo.toml index 1de8e075d024..93445132cb52 100644 --- a/crates/re_ui/Cargo.toml +++ b/crates/re_ui/Cargo.toml @@ -23,10 +23,7 @@ all-features = true [features] -default = ["eframe"] - -eframe = ["dep:eframe"] - +default = [] [dependencies] egui_extras.workspace = true @@ -37,9 +34,6 @@ strum.workspace = true strum_macros.workspace = true sublime_fuzzy.workspace = true -## Optional dependencies: -eframe = { workspace = true, optional = true, default-features = false } - [dev-dependencies] eframe = { workspace = true, default-features = false, features = ["wgpu"] } egui_tiles.workspace = true diff --git a/crates/re_ui/examples/re_ui_example.rs b/crates/re_ui/examples/re_ui_example.rs index def7fdf32fc3..2191ffef27b1 100644 --- a/crates/re_ui/examples/re_ui_example.rs +++ b/crates/re_ui/examples/re_ui_example.rs @@ -33,20 +33,19 @@ fn main() -> eframe::Result<()> { re_log::setup_native_logging(); let native_options = eframe::NativeOptions { - app_id: Some("rerun_example_re_ui_example".to_owned()), + viewport: egui::ViewportBuilder::default() + .with_app_id("re_ui_example") + .with_decorations(!re_ui::CUSTOM_WINDOW_DECORATIONS) // Maybe hide the OS-specific "chrome" around the window + .with_fullsize_content_view(re_ui::FULLSIZE_CONTENT) + .with_inner_size([1200.0, 800.0]) + .with_title_shown(!re_ui::FULLSIZE_CONTENT) + .with_titlebar_buttons_shown(!re_ui::CUSTOM_WINDOW_DECORATIONS) + .with_titlebar_shown(!re_ui::FULLSIZE_CONTENT) + .with_transparent(re_ui::CUSTOM_WINDOW_DECORATIONS), // To have rounded corners without decorations we need transparency - initial_window_size: Some([1200.0, 800.0].into()), follow_system_theme: false, default_theme: eframe::Theme::Dark, - #[cfg(target_os = "macos")] - fullsize_content: re_ui::FULLSIZE_CONTENT, - - // Maybe hide the OS-specific "chrome" around the window: - decorated: !re_ui::CUSTOM_WINDOW_DECORATIONS, - // To have rounded corners we need transparency: - transparent: re_ui::CUSTOM_WINDOW_DECORATIONS, - ..Default::default() }; @@ -90,7 +89,7 @@ impl ExampleApp { let (logger, text_log_rx) = re_log::ChannelLogger::new(re_log::LevelFilter::Info); re_log::add_boxed_logger(Box::new(logger)).unwrap(); - let tree = egui_tiles::Tree::new_tabs(vec![1, 2, 3]); + let tree = egui_tiles::Tree::new_tabs("my_tree", vec![1, 2, 3]); let (command_sender, command_receiver) = command_channel(); @@ -147,16 +146,11 @@ impl eframe::App for ExampleApp { [0.0; 4] // transparent so we can get rounded corners when doing [`re_ui::CUSTOM_WINDOW_DECORATIONS`] } - fn update(&mut self, egui_ctx: &egui::Context, frame: &mut eframe::Frame) { + fn update(&mut self, egui_ctx: &egui::Context, _frame: &mut eframe::Frame) { self.show_text_logs_as_notifications(); self.toasts.show(egui_ctx); - egui::gui_zoom::zoom_with_keyboard_shortcuts( - egui_ctx, - frame.info().native_pixels_per_point, - ); - - self.top_bar(egui_ctx, frame); + self.top_bar(egui_ctx); egui::TopBottomPanel::bottom("bottom_panel") .frame(self.re_ui.bottom_panel_frame()) @@ -362,6 +356,19 @@ impl eframe::App for ExampleApp { #[allow(clippy::single_match)] match cmd { UICommand::ToggleCommandPalette => self.cmd_palette.toggle(), + UICommand::ZoomIn => { + let mut zoom_factor = egui_ctx.zoom_factor(); + zoom_factor += 0.1; + egui_ctx.set_zoom_factor(zoom_factor); + } + UICommand::ZoomOut => { + let mut zoom_factor = egui_ctx.zoom_factor(); + zoom_factor -= 0.1; + egui_ctx.set_zoom_factor(zoom_factor); + } + UICommand::ZoomReset => { + egui_ctx.set_zoom_factor(1.0); + } _ => {} } } @@ -369,21 +376,8 @@ impl eframe::App for ExampleApp { } impl ExampleApp { - fn top_bar(&mut self, egui_ctx: &egui::Context, frame: &mut eframe::Frame) { - let native_pixels_per_point = frame.info().native_pixels_per_point; - let fullscreen = { - #[cfg(target_arch = "wasm32")] - { - false - } - #[cfg(not(target_arch = "wasm32"))] - { - frame.info().window_info.fullscreen - } - }; - let top_bar_style = self - .re_ui - .top_bar_style(native_pixels_per_point, fullscreen, false); + fn top_bar(&mut self, egui_ctx: &egui::Context) { + let top_bar_style = self.re_ui.top_bar_style(false); egui::TopBottomPanel::top("top_bar") .frame(self.re_ui.top_panel_frame()) @@ -395,7 +389,7 @@ impl ExampleApp { ui.menu_button("File", |ui| file_menu(ui, &self.command_sender)); - self.top_bar_ui(ui, frame); + self.top_bar_ui(ui); }) .response; @@ -403,21 +397,23 @@ impl ExampleApp { if !re_ui::NATIVE_WINDOW_BAR { let title_bar_response = _response.interact(egui::Sense::click()); if title_bar_response.double_clicked() { - frame.set_maximized(!frame.info().window_info.maximized); + let maximized = ui.input(|i| i.viewport().maximized.unwrap_or(false)); + ui.ctx() + .send_viewport_cmd(egui::ViewportCommand::Maximized(!maximized)); } else if title_bar_response.is_pointer_button_down_on() { - frame.drag_window(); + ui.ctx().send_viewport_cmd(egui::ViewportCommand::StartDrag); } } }); } - fn top_bar_ui(&mut self, ui: &mut egui::Ui, frame: &mut eframe::Frame) { + fn top_bar_ui(&mut self, ui: &mut egui::Ui) { ui.with_layout(egui::Layout::right_to_left(egui::Align::Center), |ui| { // From right-to-left: if re_ui::CUSTOM_WINDOW_DECORATIONS { ui.add_space(8.0); - re_ui::native_window_buttons_ui(frame, ui); + re_ui::native_window_buttons_ui(ui); ui.separator(); } else { ui.add_space(16.0); diff --git a/crates/re_ui/src/design_tokens.rs b/crates/re_ui/src/design_tokens.rs index 91ac9f3b2030..9c4de5c21cbf 100644 --- a/crates/re_ui/src/design_tokens.rs +++ b/crates/re_ui/src/design_tokens.rs @@ -182,9 +182,9 @@ fn apply_design_tokens(ctx: &egui::Context) -> DesignTokens { egui_style.spacing.combo_width = 8.0; // minimum width of ComboBox - keep them small, with the down-arrow close. - egui_style.spacing.scroll_bar_inner_margin = 2.0; - egui_style.spacing.scroll_bar_width = 6.0; - egui_style.spacing.scroll_bar_outer_margin = 2.0; + egui_style.spacing.scroll.bar_inner_margin = 2.0; + egui_style.spacing.scroll.bar_width = 6.0; + egui_style.spacing.scroll.bar_outer_margin = 2.0; // don't color hyperlinks #2733 egui_style.visuals.hyperlink_color = default; diff --git a/crates/re_ui/src/lib.rs b/crates/re_ui/src/lib.rs index 2a36f0f35452..96d694766ea8 100644 --- a/crates/re_ui/src/lib.rs +++ b/crates/re_ui/src/lib.rs @@ -279,17 +279,12 @@ impl ReUi { } } - pub fn top_bar_style( - &self, - native_pixels_per_point: Option, - fullscreen: bool, - style_like_web: bool, - ) -> TopBarStyle { - let gui_zoom = if let Some(native_pixels_per_point) = native_pixels_per_point { - native_pixels_per_point / self.egui_ctx.pixels_per_point() - } else { - 1.0 - }; + pub fn top_bar_style(&self, style_like_web: bool) -> TopBarStyle { + let egui_zoom_factor = self.egui_ctx.zoom_factor(); + let fullscreen = self + .egui_ctx + .input(|i| i.viewport().fullscreen) + .unwrap_or(false); // On Mac, we share the same space as the native red/yellow/green close/minimize/maximize buttons. // This means we need to make room for them. @@ -315,14 +310,14 @@ impl ReUi { let height = native_buttons_size_in_native_scale.y; // …but never shrink below the native button height when zoomed out. - height.max(gui_zoom * native_buttons_size_in_native_scale.y) + height.max(native_buttons_size_in_native_scale.y / egui_zoom_factor) } else { Self::top_bar_height() - Self::top_bar_margin().sum().y }; let indent = if make_room_for_window_buttons { // Always use the same width measured in native GUI coordinates: - gui_zoom * native_buttons_size_in_native_scale.x + native_buttons_size_in_native_scale.x / egui_zoom_factor } else { 0.0 }; @@ -976,10 +971,9 @@ impl ReUi { /// Assumes it is in a right-to-left layout. /// /// Use when [`CUSTOM_WINDOW_DECORATIONS`] is set. -#[cfg(feature = "eframe")] #[cfg(not(target_arch = "wasm32"))] -pub fn native_window_buttons_ui(frame: &mut eframe::Frame, ui: &mut egui::Ui) { - use egui::{Button, RichText}; +pub fn native_window_buttons_ui(ui: &mut egui::Ui) { + use egui::{Button, RichText, ViewportCommand}; let button_height = 12.0; @@ -987,22 +981,24 @@ pub fn native_window_buttons_ui(frame: &mut eframe::Frame, ui: &mut egui::Ui) { .add(Button::new(RichText::new("❌").size(button_height))) .on_hover_text("Close the window"); if close_response.clicked() { - frame.close(); + ui.ctx().send_viewport_cmd(ViewportCommand::Close); } - if frame.info().window_info.maximized { + let maximized = ui.input(|i| i.viewport().maximized.unwrap_or(false)); + if maximized { let maximized_response = ui .add(Button::new(RichText::new("🗗").size(button_height))) .on_hover_text("Restore window"); if maximized_response.clicked() { - frame.set_maximized(false); + ui.ctx() + .send_viewport_cmd(ViewportCommand::Maximized(false)); } } else { let maximized_response = ui .add(Button::new(RichText::new("🗗").size(button_height))) .on_hover_text("Maximize window"); if maximized_response.clicked() { - frame.set_maximized(true); + ui.ctx().send_viewport_cmd(ViewportCommand::Maximized(true)); } } @@ -1010,7 +1006,7 @@ pub fn native_window_buttons_ui(frame: &mut eframe::Frame, ui: &mut egui::Ui) { .add(Button::new(RichText::new("🗕").size(button_height))) .on_hover_text("Minimize the window"); if minimized_response.clicked() { - frame.set_minimized(true); + ui.ctx().send_viewport_cmd(ViewportCommand::Minimized(true)); } } diff --git a/crates/re_viewer/Cargo.toml b/crates/re_viewer/Cargo.toml index 1a472b1c42c6..c73e018dc5e6 100644 --- a/crates/re_viewer/Cargo.toml +++ b/crates/re_viewer/Cargo.toml @@ -62,7 +62,7 @@ re_time_panel.workspace = true re_tracing = { workspace = true, features = ["server"] } re_types_core.workspace = true re_types.workspace = true -re_ui = { workspace = true, features = ["eframe"] } +re_ui.workspace = true re_viewer_context.workspace = true re_viewport.workspace = true re_ws_comms = { workspace = true, features = ["client"] } diff --git a/crates/re_viewer/src/app.rs b/crates/re_viewer/src/app.rs index f161ee4a0982..e3e811be90ae 100644 --- a/crates/re_viewer/src/app.rs +++ b/crates/re_viewer/src/app.rs @@ -85,7 +85,7 @@ impl Default for StartupOptions { #[cfg(not(target_arch = "wasm32"))] const MIN_ZOOM_FACTOR: f32 = 0.2; #[cfg(not(target_arch = "wasm32"))] -const MAX_ZOOM_FACTOR: f32 = 4.0; +const MAX_ZOOM_FACTOR: f32 = 5.0; /// The Rerun Viewer as an [`eframe`] application. pub struct App { @@ -199,7 +199,7 @@ impl App { #[cfg(not(target_arch = "wasm32"))] if let Some(screenshot_path) = startup_options.screenshot_to_path_then_quit.clone() { - screenshotter.screenshot_to_path_then_quit(screenshot_path); + screenshotter.screenshot_to_path_then_quit(&re_ui.egui_ctx, screenshot_path); } let (command_sender, command_receiver) = command_channel(); @@ -302,13 +302,12 @@ impl App { fn run_pending_ui_commands( &mut self, - frame: &mut eframe::Frame, egui_ctx: &egui::Context, app_blueprint: &AppBlueprint<'_>, store_context: Option<&StoreContext<'_>>, ) { while let Some(cmd) = self.command_receiver.recv_ui() { - self.run_ui_command(frame, egui_ctx, app_blueprint, store_context, cmd); + self.run_ui_command(egui_ctx, app_blueprint, store_context, cmd); } } @@ -377,7 +376,6 @@ impl App { fn run_ui_command( &mut self, - _frame: &mut eframe::Frame, _egui_ctx: &egui::Context, app_blueprint: &AppBlueprint<'_>, store_context: Option<&StoreContext<'_>>, @@ -424,9 +422,10 @@ impl App { .send_system(SystemCommand::CloseRecordingId(cur_rec.clone())); } } + #[cfg(not(target_arch = "wasm32"))] UICommand::Quit => { - _frame.close(); + _egui_ctx.send_viewport_cmd(egui::ViewportCommand::Close); } UICommand::ResetViewer => self.command_sender.send_system(SystemCommand::ResetViewer), @@ -454,19 +453,28 @@ impl App { #[cfg(not(target_arch = "wasm32"))] UICommand::ToggleFullscreen => { - _frame.set_fullscreen(!_frame.info().window_info.fullscreen); + let fullscreen = _egui_ctx.input(|i| i.viewport().fullscreen.unwrap_or(false)); + _egui_ctx.send_viewport_cmd(egui::ViewportCommand::Fullscreen(!fullscreen)); } #[cfg(not(target_arch = "wasm32"))] UICommand::ZoomIn => { - self.app_options_mut().zoom_factor += 0.1; + let mut zoom_factor = _egui_ctx.zoom_factor(); + zoom_factor += 0.1; + zoom_factor = zoom_factor.clamp(MIN_ZOOM_FACTOR, MAX_ZOOM_FACTOR); + zoom_factor = (zoom_factor * 10.).round() / 10.; + _egui_ctx.set_zoom_factor(zoom_factor); } #[cfg(not(target_arch = "wasm32"))] UICommand::ZoomOut => { - self.app_options_mut().zoom_factor -= 0.1; + let mut zoom_factor = _egui_ctx.zoom_factor(); + zoom_factor -= 0.1; + zoom_factor = zoom_factor.clamp(MIN_ZOOM_FACTOR, MAX_ZOOM_FACTOR); + zoom_factor = (zoom_factor * 10.).round() / 10.; + _egui_ctx.set_zoom_factor(zoom_factor); } #[cfg(not(target_arch = "wasm32"))] UICommand::ZoomReset => { - self.app_options_mut().zoom_factor = 1.0; + _egui_ctx.set_zoom_factor(1.0); } UICommand::SelectionPrevious => { @@ -511,7 +519,7 @@ impl App { #[cfg(not(target_arch = "wasm32"))] UICommand::ScreenshotWholeApp => { - self.screenshotter.request_screenshot(); + self.screenshotter.request_screenshot(_egui_ctx); } #[cfg(not(target_arch = "wasm32"))] UICommand::PrintDatastore => { @@ -647,7 +655,7 @@ impl App { fn ui( &mut self, egui_ctx: &egui::Context, - frame: &mut eframe::Frame, + frame: &eframe::Frame, app_blueprint: &AppBlueprint<'_>, gpu_resource_stats: &WgpuResourcePoolStatistics, store_context: Option<&StoreContext<'_>>, @@ -666,14 +674,7 @@ impl App { crate::ui::mobile_warning_ui(&self.re_ui, ui); - crate::ui::top_panel( - app_blueprint, - store_context, - ui, - frame, - self, - gpu_resource_stats, - ); + crate::ui::top_panel(app_blueprint, store_context, ui, self, gpu_resource_stats); self.memory_panel_ui(ui, gpu_resource_stats, store_stats); @@ -1022,12 +1023,14 @@ impl eframe::App for App { #[cfg(not(target_arch = "wasm32"))] if let Some(resolution_in_points) = self.startup_options.resolution_in_points.take() { - frame.set_window_size(resolution_in_points.into()); + egui_ctx.send_viewport_cmd(egui::ViewportCommand::InnerSize( + resolution_in_points.into(), + )); } #[cfg(not(target_arch = "wasm32"))] - if self.screenshotter.update(egui_ctx, frame).quit { - frame.close(); + if self.screenshotter.update(egui_ctx).quit { + egui_ctx.send_viewport_cmd(egui::ViewportCommand::Close); return; } @@ -1050,25 +1053,6 @@ impl eframe::App for App { } } - #[cfg(not(target_arch = "wasm32"))] - if self.screenshotter.is_screenshotting() { - // Make screenshots high-quality by pretending we have a high-dpi display, whether we do or not: - egui_ctx.set_pixels_per_point(2.0); - } else { - // Ensure zoom factor is sane and in 10% steps at all times before applying it. - { - let mut zoom_factor = self.app_options().zoom_factor; - zoom_factor = zoom_factor.clamp(MIN_ZOOM_FACTOR, MAX_ZOOM_FACTOR); - zoom_factor = (zoom_factor * 10.).round() / 10.; - self.state.app_options_mut().zoom_factor = zoom_factor; - } - - // Apply zoom factor on top of natively reported pixel per point. - let pixels_per_point = frame.info().native_pixels_per_point.unwrap_or(1.0) - * self.app_options().zoom_factor; - egui_ctx.set_pixels_per_point(pixels_per_point); - } - // TODO(andreas): store the re_renderer somewhere else. let gpu_resource_stats = { let egui_renderer = { @@ -1138,25 +1122,28 @@ impl eframe::App for App { self.handle_dropping_files(egui_ctx); // Run pending commands last (so we don't have to wait for a repaint before they are run): - self.run_pending_ui_commands(frame, egui_ctx, &app_blueprint, store_context.as_ref()); + self.run_pending_ui_commands(egui_ctx, &app_blueprint, store_context.as_ref()); self.run_pending_system_commands(&mut store_hub, egui_ctx); // Return the `StoreHub` to the Viewer so we have it on the next frame self.store_hub = Some(store_hub); + // Check for returned screenshot: + #[cfg(not(target_arch = "wasm32"))] + egui_ctx.input(|i| { + for event in &i.raw.events { + if let egui::Event::Screenshot { image, .. } = event { + self.screenshotter.save(image); + } + } + }); + // Frame time measurer - must be last self.frame_time_history.add( egui_ctx.input(|i| i.time), frame_start.elapsed().as_secs_f32(), ); } - - #[cfg(not(target_arch = "wasm32"))] - fn post_rendering(&mut self, _window_size: [u32; 2], frame: &eframe::Frame) { - if let Some(screenshot) = frame.screenshot() { - self.screenshotter.save(&screenshot); - } - } } /// Add built-in space views to the registry. diff --git a/crates/re_viewer/src/lib.rs b/crates/re_viewer/src/lib.rs index d6aaed495fd8..d8570a645264 100644 --- a/crates/re_viewer/src/lib.rs +++ b/crates/re_viewer/src/lib.rs @@ -162,6 +162,7 @@ pub(crate) fn wgpu_options() -> egui_wgpu::WgpuConfiguration { #[must_use] pub fn customize_eframe(cc: &eframe::CreationContext<'_>) -> re_ui::ReUi { re_tracing::profile_function!(); + if let Some(render_state) = &cc.wgpu_render_state { use re_renderer::{config::RenderContextConfig, RenderContext}; diff --git a/crates/re_viewer/src/native.rs b/crates/re_viewer/src/native.rs index b6a4408319fc..51a723bdb343 100644 --- a/crates/re_viewer/src/native.rs +++ b/crates/re_viewer/src/native.rs @@ -80,21 +80,17 @@ fn check_graphics_driver(wgpu_render_state: Option<&egui_wgpu::RenderState>) { pub fn eframe_options() -> eframe::NativeOptions { re_tracing::profile_function!(); eframe::NativeOptions { - // Controls where on disk the app state is persisted. - app_id: Some(APP_ID.to_owned()), - - initial_window_size: Some([1600.0, 1200.0].into()), - min_window_size: Some([320.0, 450.0].into()), // Should be high enough to fit the rerun menu - - icon_data: icon_data(), - - #[cfg(target_os = "macos")] - fullsize_content: re_ui::FULLSIZE_CONTENT, - - // Maybe hide the OS-specific "chrome" around the window: - decorated: !re_ui::CUSTOM_WINDOW_DECORATIONS, - // To have rounded corners we need transparency: - transparent: re_ui::CUSTOM_WINDOW_DECORATIONS, + viewport: egui::ViewportBuilder::default() + .with_app_id(APP_ID) // Controls where on disk the app state is persisted + .with_decorations(!re_ui::CUSTOM_WINDOW_DECORATIONS) // Maybe hide the OS-specific "chrome" around the window + .with_fullsize_content_view(re_ui::FULLSIZE_CONTENT) + .with_icon(icon_data()) + .with_inner_size([1600.0, 1200.0]) + .with_min_inner_size([320.0, 450.0]) // Should be high enough to fit the rerun menu + .with_title_shown(!re_ui::FULLSIZE_CONTENT) + .with_titlebar_buttons_shown(!re_ui::CUSTOM_WINDOW_DECORATIONS) + .with_titlebar_shown(!re_ui::FULLSIZE_CONTENT) + .with_transparent(re_ui::CUSTOM_WINDOW_DECORATIONS), // To have rounded corners without decorations we need transparency follow_system_theme: false, default_theme: eframe::Theme::Dark, @@ -109,7 +105,7 @@ pub fn eframe_options() -> eframe::NativeOptions { } #[allow(clippy::unnecessary_wraps)] -fn icon_data() -> Option { +fn icon_data() -> egui::IconData { re_tracing::profile_function!(); cfg_if::cfg_if! { @@ -124,8 +120,8 @@ fn icon_data() -> Option { }; // We include the .png with `include_bytes`. If that fails, things are extremely broken. - match eframe::IconData::try_from_png_bytes(app_icon_png_bytes) { - Ok(icon_data) => Some(icon_data), + match eframe::icon_data::from_png_bytes(app_icon_png_bytes) { + Ok(icon_data) => icon_data, Err(err) => { #[cfg(debug_assertions)] panic!("Failed to load app icon: {err}"); @@ -133,7 +129,7 @@ fn icon_data() -> Option { #[cfg(not(debug_assertions))] { re_log::warn!("Failed to load app icon: {err}"); - None + Default::default() } } } diff --git a/crates/re_viewer/src/screenshotter.rs b/crates/re_viewer/src/screenshotter.rs index 1d2728b8d070..960300a07444 100644 --- a/crates/re_viewer/src/screenshotter.rs +++ b/crates/re_viewer/src/screenshotter.rs @@ -8,6 +8,7 @@ pub struct Screenshotter { countdown: Option, target_path: Option, quit: bool, + pre_screenshot_zoom_factor: Option, } #[cfg(not(target_arch = "wasm32"))] @@ -22,31 +23,38 @@ impl Screenshotter { /// Used for generating screenshots in dev builds. /// /// Should only be called at startup. - pub fn screenshot_to_path_then_quit(&mut self, path: std::path::PathBuf) { + pub fn screenshot_to_path_then_quit( + &mut self, + egui_ctx: &egui::Context, + path: std::path::PathBuf, + ) { assert!(self.countdown.is_none(), "screenshotter misused"); - self.request_screenshot(); + self.request_screenshot(egui_ctx); self.target_path = Some(path); } - pub fn request_screenshot(&mut self) { + pub fn request_screenshot(&mut self, egui_ctx: &egui::Context) { // Give app time to change the style, and then wait for animations to finish: self.countdown = Some(10); + + self.pre_screenshot_zoom_factor = Some(egui_ctx.zoom_factor()); + // Make screenshots high-quality by pretending we have a high-dpi display, whether we do or not: + egui_ctx.set_pixels_per_point(2.0); } /// Call once per frame - pub fn update( - &mut self, - egui_ctx: &egui::Context, - frame: &mut eframe::Frame, - ) -> ScreenshotterOutput { + pub fn update(&mut self, egui_ctx: &egui::Context) -> ScreenshotterOutput { if let Some(countdown) = &mut self.countdown { if *countdown == 0 { - frame.request_screenshot(); + egui_ctx.send_viewport_cmd(egui::ViewportCommand::Screenshot); } else { *countdown -= 1; } egui_ctx.request_repaint(); // Make sure we keep counting down + } else if let Some(pre_screenshot_zoom_factor) = self.pre_screenshot_zoom_factor.take() { + // Restore zoom_factor + egui_ctx.set_zoom_factor(pre_screenshot_zoom_factor); } ScreenshotterOutput { quit: self.quit } diff --git a/crates/re_viewer/src/ui/rerun_menu.rs b/crates/re_viewer/src/ui/rerun_menu.rs index 10143522ebd0..31f1fc847277 100644 --- a/crates/re_viewer/src/ui/rerun_menu.rs +++ b/crates/re_viewer/src/ui/rerun_menu.rs @@ -13,7 +13,6 @@ impl App { &mut self, _store_context: Option<&StoreContext<'_>>, ui: &mut egui::Ui, - frame: &mut eframe::Frame, ) { // let desired_icon_height = ui.max_rect().height() - 2.0 * ui.spacing_mut().button_padding.y; let desired_icon_height = ui.max_rect().height() - 4.0; // TODO(emilk): figure out this fudge @@ -45,8 +44,8 @@ impl App { ui.add_space(spacing); // On the web the browser controls the zoom - let zoom_factor = self.app_options().zoom_factor; - ui.weak(format!("Zoom {:.0}%", zoom_factor * 100.0)) + let zoom_factor = ui.ctx().zoom_factor(); + ui.weak(format!("Current zoom: {:.0}%", zoom_factor * 100.0)) .on_hover_text( "The UI zoom level on top of the operating system's default value", ); @@ -76,7 +75,7 @@ impl App { ui.add_space(spacing); ui.menu_button("Options", |ui| { - self.options_menu_ui(ui, frame); + self.options_menu_ui(ui); }); ui.add_space(spacing); @@ -152,7 +151,7 @@ impl App { ui.label(label); } - fn options_menu_ui(&mut self, ui: &mut egui::Ui, _frame: &mut eframe::Frame) { + fn options_menu_ui(&mut self, ui: &mut egui::Ui) { ui.style_mut().wrap = Some(false); if self @@ -215,7 +214,7 @@ impl App { self.egui_debug_options_ui(ui); ui.separator(); - self.debug_menu_options_ui(ui, _frame); + self.debug_menu_options_ui(ui); } } @@ -316,13 +315,16 @@ impl App { } #[cfg(debug_assertions)] - fn debug_menu_options_ui(&mut self, ui: &mut egui::Ui, _frame: &mut eframe::Frame) { + fn debug_menu_options_ui(&mut self, ui: &mut egui::Ui) { #[cfg(not(target_arch = "wasm32"))] { if ui.button("Mobile size").clicked() { - // frame.set_window_size(egui::vec2(375.0, 812.0)); // iPhone 12 mini - _frame.set_window_size(egui::vec2(375.0, 667.0)); // iPhone SE 2nd gen - _frame.set_fullscreen(false); + // let size = egui::vec2(375.0, 812.0); // iPhone 12 mini + let size = egui::vec2(375.0, 667.0); // iPhone SE 2nd gen + ui.ctx() + .send_viewport_cmd(egui::ViewportCommand::Fullscreen(false)); + ui.ctx() + .send_viewport_cmd(egui::ViewportCommand::InnerSize(size)); ui.close_menu(); } ui.separator(); diff --git a/crates/re_viewer/src/ui/top_panel.rs b/crates/re_viewer/src/ui/top_panel.rs index bdf7e6a2f279..660895ecec39 100644 --- a/crates/re_viewer/src/ui/top_panel.rs +++ b/crates/re_viewer/src/ui/top_panel.rs @@ -10,27 +10,13 @@ pub fn top_panel( app_blueprint: &AppBlueprint<'_>, store_context: Option<&StoreContext<'_>>, ui: &mut egui::Ui, - frame: &mut eframe::Frame, app: &mut App, gpu_resource_stats: &WgpuResourcePoolStatistics, ) { re_tracing::profile_function!(); - let native_pixels_per_point = frame.info().native_pixels_per_point; - let fullscreen = { - #[cfg(target_arch = "wasm32")] - { - false - } - #[cfg(not(target_arch = "wasm32"))] - { - frame.info().window_info.fullscreen - } - }; let style_like_web = app.is_screenshotting(); - let top_bar_style = - app.re_ui() - .top_bar_style(native_pixels_per_point, fullscreen, style_like_web); + let top_bar_style = app.re_ui().top_bar_style(style_like_web); egui::TopBottomPanel::top("top_bar") .frame(app.re_ui().top_panel_frame()) @@ -40,14 +26,7 @@ pub fn top_panel( ui.set_height(top_bar_style.height); ui.add_space(top_bar_style.indent); - top_bar_ui( - app_blueprint, - store_context, - ui, - frame, - app, - gpu_resource_stats, - ); + top_bar_ui(app_blueprint, store_context, ui, app, gpu_resource_stats); }) .response; @@ -55,9 +34,11 @@ pub fn top_panel( if !re_ui::NATIVE_WINDOW_BAR { let title_bar_response = _response.interact(egui::Sense::click()); if title_bar_response.double_clicked() { - frame.set_maximized(!frame.info().window_info.maximized); + let maximized = ui.input(|i| i.viewport().maximized.unwrap_or(false)); + ui.ctx() + .send_viewport_cmd(egui::ViewportCommand::Maximized(!maximized)); } else if title_bar_response.is_pointer_button_down_on() { - frame.drag_window(); + ui.ctx().send_viewport_cmd(egui::ViewportCommand::StartDrag); } } }); @@ -67,11 +48,10 @@ fn top_bar_ui( app_blueprint: &AppBlueprint<'_>, store_context: Option<&StoreContext<'_>>, ui: &mut egui::Ui, - frame: &mut eframe::Frame, app: &mut App, gpu_resource_stats: &WgpuResourcePoolStatistics, ) { - app.rerun_menu_button_ui(store_context, ui, frame); + app.rerun_menu_button_ui(store_context, ui); ui.add_space(12.0); website_link_ui(ui); @@ -87,7 +67,7 @@ fn top_bar_ui( if re_ui::CUSTOM_WINDOW_DECORATIONS && !cfg!(target_arch = "wasm32") { ui.add_space(8.0); #[cfg(not(target_arch = "wasm32"))] - re_ui::native_window_buttons_ui(frame, ui); + re_ui::native_window_buttons_ui(ui); ui.separator(); } else { // Make the first button the same distance form the side as from the top, diff --git a/crates/re_viewer/src/web.rs b/crates/re_viewer/src/web.rs index c780d15af67b..ca9140858404 100644 --- a/crates/re_viewer/src/web.rs +++ b/crates/re_viewer/src/web.rs @@ -1,3 +1,5 @@ +#![allow(clippy::mem_forget)] // False positives from #[wasm_bindgen] macro + use eframe::wasm_bindgen::{self, prelude::*}; use std::sync::Arc; diff --git a/crates/re_viewer_context/src/app_options.rs b/crates/re_viewer_context/src/app_options.rs index 98ed2df2aa0f..adb7a921d221 100644 --- a/crates/re_viewer_context/src/app_options.rs +++ b/crates/re_viewer_context/src/app_options.rs @@ -10,15 +10,6 @@ pub struct AppOptions { /// Show milliseconds, RAM usage, etc. pub show_metrics: bool, - /// Zoom factor, independent of OS points_per_pixel setting. - /// - /// At every frame we check the OS reported scaling (i.e. points_per_pixel) - /// and apply this zoom factor to determine the actual points_per_pixel. - /// This way, the zooming stays constant when switching between differently scaled screens. - /// (Since this is serialized, even between sessions!) - #[cfg(not(target_arch = "wasm32"))] - pub zoom_factor: f32, - /// Enable the experimental feature for space view screenshots. #[cfg(not(target_arch = "wasm32"))] pub experimental_space_view_screenshots: bool, @@ -41,9 +32,6 @@ impl Default for AppOptions { show_metrics: false, - #[cfg(not(target_arch = "wasm32"))] - zoom_factor: 1.0, - #[cfg(not(target_arch = "wasm32"))] experimental_space_view_screenshots: false, diff --git a/crates/re_viewport/src/auto_layout.rs b/crates/re_viewport/src/auto_layout.rs index 9a4df8a7f3dc..c2c3ebf18255 100644 --- a/crates/re_viewport/src/auto_layout.rs +++ b/crates/re_viewport/src/auto_layout.rs @@ -24,7 +24,7 @@ pub(crate) fn tree_from_space_views( re_log::trace!("Auto-layout of {} space views", space_views.len()); if space_views.is_empty() { - return egui_tiles::Tree::empty(); + return egui_tiles::Tree::empty("viewport_tree"); } let space_make_infos = space_views @@ -105,7 +105,7 @@ pub(crate) fn tree_from_space_views( } }; - egui_tiles::Tree::new(root, tiles) + egui_tiles::Tree::new("viewport_tree", root, tiles) } fn arrange_three( diff --git a/crates/re_viewport/src/blueprint/viewport_layout_ext.rs b/crates/re_viewport/src/blueprint/viewport_layout_ext.rs index 68d5d3c977cd..e9db0abefa18 100644 --- a/crates/re_viewport/src/blueprint/viewport_layout_ext.rs +++ b/crates/re_viewport/src/blueprint/viewport_layout_ext.rs @@ -4,7 +4,7 @@ impl Default for ViewportLayout { fn default() -> Self { Self { space_view_keys: Default::default(), - tree: Default::default(), + tree: egui_tiles::Tree::empty("viewport_tree"), auto_layout: true, } } diff --git a/crates/re_viewport/src/viewport.rs b/crates/re_viewport/src/viewport.rs index 9799913b4094..940561718ef3 100644 --- a/crates/re_viewport/src/viewport.rs +++ b/crates/re_viewport/src/viewport.rs @@ -127,7 +127,7 @@ impl<'a, 'b> Viewport<'a, 'b> { let tree = if let Some(space_view_id) = blueprint.maximized { let mut tiles = egui_tiles::Tiles::default(); let root = tiles.insert_pane(space_view_id); - maximized_tree = egui_tiles::Tree::new(root, tiles); + maximized_tree = egui_tiles::Tree::new("viewport_tree", root, tiles); &mut maximized_tree } else { if blueprint.tree.is_empty() { @@ -326,9 +326,7 @@ impl<'a, 'b> egui_tiles::Behavior for TabViewer<'a, 'b> { tab_widget.paint(ui); } - self.on_tab_button(tiles, tile_id, &response); - - response + self.on_tab_button(tiles, tile_id, response) } fn drag_ui( @@ -357,8 +355,8 @@ impl<'a, 'b> egui_tiles::Behavior for TabViewer<'a, 'b> { &mut self, tiles: &egui_tiles::Tiles, tile_id: egui_tiles::TileId, - button_response: &egui::Response, - ) { + button_response: egui::Response, + ) -> egui::Response { if button_response.clicked() { if let Some(egui_tiles::Tile::Pane(space_view_id)) = tiles.get(tile_id) { self.ctx @@ -369,18 +367,20 @@ impl<'a, 'b> egui_tiles::Behavior for TabViewer<'a, 'b> { self.ctx.rec_cfg.selection_state.clear_current(); } } + button_response } fn retain_pane(&mut self, space_view_id: &SpaceViewId) -> bool { self.space_views.contains_key(space_view_id) } - fn top_bar_rtl_ui( + fn top_bar_right_ui( &mut self, tiles: &egui_tiles::Tiles, ui: &mut egui::Ui, _tile_id: egui_tiles::TileId, tabs: &egui_tiles::Tabs, + _scroll_offset: &mut f32, ) { let Some(active) = tabs.active.and_then(|active| tiles.get(active)) else { return; @@ -573,7 +573,7 @@ impl TabWidget { } } - fn paint(self, ui: &mut egui::Ui) { + fn paint(self, ui: &egui::Ui) { ui.painter() .rect(self.rect, 0.0, self.bg_color, egui::Stroke::NONE); diff --git a/crates/re_viewport/src/viewport_blueprint.rs b/crates/re_viewport/src/viewport_blueprint.rs index c8c4c5377147..4bf2ea4f7a6e 100644 --- a/crates/re_viewport/src/viewport_blueprint.rs +++ b/crates/re_viewport/src/viewport_blueprint.rs @@ -97,7 +97,7 @@ impl<'a> ViewportBlueprint<'a> { // Note, it's important that these values match the behavior in `load_viewport_blueprint` below. *space_views = Default::default(); - *tree = Default::default(); + *tree = egui_tiles::Tree::empty("viewport_tree"); *maximized = None; *auto_layout = true; // Only enable auto-space-views if this is the app-default blueprint @@ -202,7 +202,7 @@ impl<'a> ViewportBlueprint<'a> { if self.auto_layout { // Re-run the auto-layout next frame: re_log::trace!("Added a space view with no user edits yet - will re-run auto-layout"); - self.tree = Default::default(); + self.tree = egui_tiles::Tree::empty("viewport_tree"); } else { // Try to insert it in the tree, in the top level: if let Some(root_id) = self.tree.root { @@ -214,7 +214,7 @@ impl<'a> ViewportBlueprint<'a> { container.add_child(tile_id); } else { re_log::trace!("Root was not a container - will re-run auto-layout"); - self.tree = Default::default(); + self.tree = egui_tiles::Tree::empty("viewport_tree"); } } else { re_log::trace!("No root found - will re-run auto-layout"); diff --git a/deny.toml b/deny.toml index 1930e2e629b3..f985979d014d 100644 --- a/deny.toml +++ b/deny.toml @@ -48,12 +48,16 @@ deny = [ skip = [ { name = "ahash" }, # Popular crate + fast release schedule = lots of crates still using old versions { name = "base64" }, # Too popular - { name = "foreign-types" }, # used for cocoa bindings. wgpu uses newer than winit. - { name = "foreign-types-shared" }, # as above. + { name = "foreign-types" }, # used for cocoa bindings. wgpu uses newer than eframe. + { name = "foreign-types-shared" }, # used for cocoa bindings. wgpu uses newer than eframe. + { name = "hashbrown" }, # Old version used by polar-rs + { name = "libloading" }, # Old version used by ash (vulkan binding), newer version used by khronos-egl { name = "memoffset" }, # Small crate { name = "nix" }, # difficult to avoid :( { name = "prettyplease" }, # Old version being used by prost + { name = "spin" }, # Old version used by rusttls { name = "time" }, # Too popular + { name = "windows" }, # Old version used by accesskit_windows, newer version used by wgpu ] skip-tree = [ { name = "cargo-run-wasm" }, # Dev-tool diff --git a/examples/rust/extend_viewer_ui/src/main.rs b/examples/rust/extend_viewer_ui/src/main.rs index 4743535b6ce6..a67799d88b32 100644 --- a/examples/rust/extend_viewer_ui/src/main.rs +++ b/examples/rust/extend_viewer_ui/src/main.rs @@ -31,7 +31,7 @@ async fn main() -> Result<(), Box> { .await?; let native_options = eframe::NativeOptions { - app_id: Some("rerun_example_app_id".to_owned()), + viewport: egui::ViewportBuilder::default().with_app_id("rerun_extend_viewer_ui_example"), ..re_viewer::native::eframe_options() };