[INFO] cloning repository https://github.com/rizrmd/f1
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rizrmd/f1" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frizrmd%2Ff1", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frizrmd%2Ff1'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 10e1e9ece056707bc38460f244e84593f1cf75ff
[INFO] testing rizrmd/f1 against master#733b47ea4b1b86216f14ef56e49440c33933f230+rustflags=-Copt-level=3 for pr-138759
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frizrmd%2Ff1" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/rizrmd/f1
[INFO] finished tweaking git repo https://github.com/rizrmd/f1
[INFO] tweaked toml for git repo https://github.com/rizrmd/f1 written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/rizrmd/f1 on toolchain 733b47ea4b1b86216f14ef56e49440c33933f230
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/rizrmd/f1 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0073f45a3df092bb57be3667d4be7de1294d8886651b085604c9194d224373e3
[INFO] running `Command { std: "docker" "start" "-a" "0073f45a3df092bb57be3667d4be7de1294d8886651b085604c9194d224373e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0073f45a3df092bb57be3667d4be7de1294d8886651b085604c9194d224373e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0073f45a3df092bb57be3667d4be7de1294d8886651b085604c9194d224373e3", kill_on_drop: false }`
[INFO] [stdout] 0073f45a3df092bb57be3667d4be7de1294d8886651b085604c9194d224373e3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ea9a64b14a0a508049f4c86a05cfc783178b041502cb0cc6ac2f3eaf0412726e
[INFO] running `Command { std: "docker" "start" "-a" "ea9a64b14a0a508049f4c86a05cfc783178b041502cb0cc6ac2f3eaf0412726e", kill_on_drop: false }`
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling bitflags v2.9.2
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling rustix v1.0.8
[INFO] [stderr]    Compiling litrs v0.4.2
[INFO] [stderr]    Compiling libc v0.2.175
[INFO] [stderr]    Compiling convert_case v0.7.1
[INFO] [stderr]    Compiling memchr v2.7.5
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling adler2 v2.0.1
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling crc32fast v1.5.0
[INFO] [stderr]    Compiling linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling miniz_oxide v0.8.9
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling serial-core v0.4.0
[INFO] [stderr]    Compiling termios v0.2.2
[INFO] [stderr]    Compiling ioctl-rs v0.1.6
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling document-features v0.2.11
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling flate2 v1.1.2
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling strict v0.2.0
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling crossbeam-deque v0.8.6
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling png v0.17.16
[INFO] [stderr]    Compiling crossbeam-queue v0.3.12
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling serial-unix v0.4.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling bytemuck v1.23.2
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]    Compiling x11rb-protocol v0.13.1
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling nix v0.25.1
[INFO] [stderr]    Compiling serial v0.4.0
[INFO] [stderr]    Compiling minimad v0.13.1
[INFO] [stderr]    Compiling vte_generate_state_changes v0.1.2
[INFO] [stderr]    Compiling str_indices v0.4.4
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling ropey v1.6.1
[INFO] [stderr]    Compiling image v0.25.6
[INFO] [stderr]    Compiling vte v0.13.1
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling x11rb v0.13.1
[INFO] [stderr]    Compiling arboard v3.6.0
[INFO] [stderr]    Compiling derive_more-impl v2.0.1
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling lazy-regex-proc_macros v3.4.1
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling derive_more v2.0.1
[INFO] [stderr]    Compiling crossterm v0.29.0
[INFO] [stderr]    Compiling lazy-regex v3.4.1
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling coolor v1.1.0
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling filedescriptor v0.8.3
[INFO] [stderr]    Compiling portable-pty v0.8.1
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling crokey-proc_macros v1.2.0
[INFO] [stderr]    Compiling ratatui v0.28.1
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling crokey v1.2.0
[INFO] [stderr]    Compiling termimad v0.30.1
[INFO] [stderr]    Compiling f1 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]    --> src/file_operations.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |                     let (message, is_error) = match result {
[INFO] [stdout]     |                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_error`
[INFO] [stdout]    --> src/file_operations.rs:125:35
[INFO] [stdout]     |
[INFO] [stdout] 125 |                     let (message, is_error) = match result {
[INFO] [stdout]     |                                   ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tree_view`
[INFO] [stdout]    --> src/file_operations.rs:134:29
[INFO] [stdout]     |
[INFO] [stdout] 134 |                 if let Some(tree_view) = &mut self.tree_view {
[INFO] [stdout]     |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tree_view`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `active_index`
[INFO] [stdout]   --> src/handlers/mouse.rs:10:13
[INFO] [stdout]    |
[INFO] [stdout] 10 |         let active_index = self.tab_manager.active_index();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_active_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_word_separator` is never used
[INFO] [stdout]  --> src/app.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn is_word_separator(ch: char) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update_status_message` is never used
[INFO] [stdout]    --> src/app.rs:123:12
[INFO] [stdout]     |
[INFO] [stdout] 70  | impl App {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn update_status_message(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/cursor.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 22  | impl Cursor {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn move_word_left(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn move_word_right(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 215 |     pub fn select_all(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 225 |     pub fn move_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn move_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     pub fn move_up_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn move_down_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn move_word_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn move_word_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 279 |     pub fn move_to_line_start_with_selection(&mut self, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     pub fn move_to_line_end_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CLIPBOARD` is never used
[INFO] [stdout]  --> src/keyboard.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static CLIPBOARD: OnceLock<Arc<Mutex<String>>> = OnceLock::new();
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_key_event` is never used
[INFO] [stdout]   --> src/keyboard.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn handle_key_event(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert_char` is never used
[INFO] [stdout]    --> src/keyboard.rs:297:4
[INFO] [stdout]     |
[INFO] [stdout] 297 | fn insert_char(buffer: &mut RopeBuffer, cursor: &mut Cursor, ch: char) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert_newline` is never used
[INFO] [stdout]    --> src/keyboard.rs:312:4
[INFO] [stdout]     |
[INFO] [stdout] 312 | fn insert_newline(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_char_backward` is never used
[INFO] [stdout]    --> src/keyboard.rs:318:4
[INFO] [stdout]     |
[INFO] [stdout] 318 | fn delete_char_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_char_forward` is never used
[INFO] [stdout]    --> src/keyboard.rs:328:4
[INFO] [stdout]     |
[INFO] [stdout] 328 | fn delete_char_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_word_backward` is never used
[INFO] [stdout]    --> src/keyboard.rs:335:4
[INFO] [stdout]     |
[INFO] [stdout] 335 | fn delete_word_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_word_forward` is never used
[INFO] [stdout]    --> src/keyboard.rs:345:4
[INFO] [stdout]     |
[INFO] [stdout] 345 | fn delete_word_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:357:4
[INFO] [stdout]     |
[INFO] [stdout] 357 | fn delete_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_clipboard` is never used
[INFO] [stdout]    --> src/keyboard.rs:372:4
[INFO] [stdout]     |
[INFO] [stdout] 372 | fn get_clipboard() -> Arc<Mutex<String>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:378:4
[INFO] [stdout]     |
[INFO] [stdout] 378 | fn copy_selection(buffer: &RopeBuffer, cursor: &Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cut_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:401:4
[INFO] [stdout]     |
[INFO] [stdout] 401 | fn cut_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cut_current_line` is never used
[INFO] [stdout]    --> src/keyboard.rs:406:4
[INFO] [stdout]     |
[INFO] [stdout] 406 | fn cut_current_line(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `paste_from_clipboard` is never used
[INFO] [stdout]    --> src/keyboard.rs:444:4
[INFO] [stdout]     |
[INFO] [stdout] 444 | fn paste_from_clipboard(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]    --> src/keyboard.rs:502:5
[INFO] [stdout]     |
[INFO] [stdout] 501 | pub enum EditorCommand {
[INFO] [stdout]     |          ------------- variants in this enum
[INFO] [stdout] 502 |     Quit,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 503 |     Save,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 504 |     NewTab,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 505 |     NewTerminal,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 506 |     CloseTab,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 507 |     NextTab,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 508 |     PrevTab,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 509 |     PageUp,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 510 |     PageDown,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 511 |     Modified,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 512 |     ToggleMenu,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 513 |     OpenFile,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 514 |     CurrentTab,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 515 |     Undo,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 516 |     Redo,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 517 |     TogglePreview,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 518 |     ToggleWordWrap,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 519 |     FocusTreeView,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 520 |     FocusEditor,
[INFO] [stdout] 521 |     Find,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 522 |     FindReplace,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `EditorCommand` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `TreeContextMenu` is never constructed
[INFO] [stdout]   --> src/menu.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 7  | pub enum MenuState {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 12 |     TreeContextMenu(TreeContextMenuState),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MenuState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `last_scroll_time` is never read
[INFO] [stdout]   --> src/menu.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct FilePickerState {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     last_scroll_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilePickerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/menu.rs:169:12
[INFO] [stdout]     |
[INFO] [stdout] 70  | impl FilePickerState {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn update_filter(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     fn search_recursive(&mut self, dir: &PathBuf, query: &str, depth: usize, max_depth: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 302 |     pub fn scroll_up(&mut self, base_amount: usize) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 312 |     pub fn scroll_down(&mut self, base_amount: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 323 |     fn update_scroll_acceleration(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 362 |     pub fn move_left(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 367 |     pub fn move_right(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 377 |     pub fn select(&mut self) -> Option<PathBuf> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fuzzy_match` is never used
[INFO] [stdout]    --> src/menu.rs:430:4
[INFO] [stdout]     |
[INFO] [stdout] 430 | fn fuzzy_match(text: &str, pattern: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `open_tree_context_menu`, `open_tree_empty_area_menu`, `handle_up`, `handle_down`, and `handle_enter` are never used
[INFO] [stdout]    --> src/menu.rs:600:12
[INFO] [stdout]     |
[INFO] [stdout] 452 | impl MenuSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 600 |     pub fn open_tree_context_menu(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 663 |     pub fn open_tree_empty_area_menu(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 720 |     pub fn handle_up(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 729 |     pub fn handle_down(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 738 |     pub fn handle_enter(&mut self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `slice` is never used
[INFO] [stdout]   --> src/rope_buffer.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 9  | impl RopeBuffer {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn slice(&self, range: Range<usize>) -> ropey::RopeSlice<'_> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `replace_all` is never used
[INFO] [stdout]    --> src/tab.rs:464:12
[INFO] [stdout]     |
[INFO] [stdout] 84  | impl Tab {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 464 |     pub fn replace_all(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `move_up`, `move_down`, `get_selected_action`, `is_position_inside`, and `get_clicked_item` are never used
[INFO] [stdout]    --> src/ui/menu_component.rs:66:12
[INFO] [stdout]     |
[INFO] [stdout] 38  | impl MenuComponent {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66  |     pub fn move_up(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72  |     pub fn move_down(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78  |     pub fn get_selected_action(&self) -> Option<&MenuAction> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn is_position_inside(&self, area: &Rect, x: u16, y: u16) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn get_clicked_item(&self, area: &Rect, x: u16, y: u16) -> Option<usize> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `select_word_at_cursor` and `delete_input_selection` are never used
[INFO] [stdout]    --> src/handlers/ui_utilities.rs:159:12
[INFO] [stdout]     |
[INFO] [stdout] 7   | impl App {
[INFO] [stdout]     | -------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn select_word_at_cursor(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     pub fn delete_input_selection(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/app.rs:361:21
[INFO] [stdout]     |
[INFO] [stdout] 361 |                     tree_view.expand_to_file(path);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 361 |                     let _ = tree_view.expand_to_file(path);
[INFO] [stdout]     |                     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/handlers/main_keyboard.rs:117:33
[INFO] [stdout]     |
[INFO] [stdout] 117 | ...                   tree_view.toggle_directory();
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 117 |                                 let _ = tree_view.toggle_directory();
[INFO] [stdout]     |                                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/handlers/main_keyboard.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |                         tree_view.toggle_directory();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 123 |                         let _ = tree_view.toggle_directory();
[INFO] [stdout]     |                         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 20s
[INFO] running `Command { std: "docker" "inspect" "ea9a64b14a0a508049f4c86a05cfc783178b041502cb0cc6ac2f3eaf0412726e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ea9a64b14a0a508049f4c86a05cfc783178b041502cb0cc6ac2f3eaf0412726e", kill_on_drop: false }`
[INFO] [stdout] ea9a64b14a0a508049f4c86a05cfc783178b041502cb0cc6ac2f3eaf0412726e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d7b1ea42ed8a2e5e4e891ce631b3c41e7f89af138f0a45782f78add6de33d632
[INFO] running `Command { std: "docker" "start" "-a" "d7b1ea42ed8a2e5e4e891ce631b3c41e7f89af138f0a45782f78add6de33d632", kill_on_drop: false }`
[INFO] [stderr]    Compiling f1 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `message`
[INFO] [stdout]    --> src/file_operations.rs:125:26
[INFO] [stdout]     |
[INFO] [stdout] 125 |                     let (message, is_error) = match result {
[INFO] [stdout]     |                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_error`
[INFO] [stdout]    --> src/file_operations.rs:125:35
[INFO] [stdout]     |
[INFO] [stdout] 125 |                     let (message, is_error) = match result {
[INFO] [stdout]     |                                   ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_error`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tree_view`
[INFO] [stdout]    --> src/file_operations.rs:134:29
[INFO] [stdout]     |
[INFO] [stdout] 134 |                 if let Some(tree_view) = &mut self.tree_view {
[INFO] [stdout]     |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tree_view`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `active_index`
[INFO] [stdout]   --> src/handlers/mouse.rs:10:13
[INFO] [stdout]    |
[INFO] [stdout] 10 |         let active_index = self.tab_manager.active_index();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_active_index`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_word_separator` is never used
[INFO] [stdout]  --> src/app.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn is_word_separator(ch: char) -> bool {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `update_status_message` is never used
[INFO] [stdout]    --> src/app.rs:123:12
[INFO] [stdout]     |
[INFO] [stdout] 70  | impl App {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn update_status_message(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/cursor.rs:106:12
[INFO] [stdout]     |
[INFO] [stdout] 22  | impl Cursor {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn move_word_left(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub fn move_word_right(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 215 |     pub fn select_all(&mut self, buffer: &RopeBuffer) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 225 |     pub fn move_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn move_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     pub fn move_up_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 252 |     pub fn move_down_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 261 |     pub fn move_word_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn move_word_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 279 |     pub fn move_to_line_start_with_selection(&mut self, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     pub fn move_to_line_end_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CLIPBOARD` is never used
[INFO] [stdout]  --> src/keyboard.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static CLIPBOARD: OnceLock<Arc<Mutex<String>>> = OnceLock::new();
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_key_event` is never used
[INFO] [stdout]   --> src/keyboard.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub fn handle_key_event(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert_char` is never used
[INFO] [stdout]    --> src/keyboard.rs:297:4
[INFO] [stdout]     |
[INFO] [stdout] 297 | fn insert_char(buffer: &mut RopeBuffer, cursor: &mut Cursor, ch: char) {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `insert_newline` is never used
[INFO] [stdout]    --> src/keyboard.rs:312:4
[INFO] [stdout]     |
[INFO] [stdout] 312 | fn insert_newline(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_char_backward` is never used
[INFO] [stdout]    --> src/keyboard.rs:318:4
[INFO] [stdout]     |
[INFO] [stdout] 318 | fn delete_char_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_char_forward` is never used
[INFO] [stdout]    --> src/keyboard.rs:328:4
[INFO] [stdout]     |
[INFO] [stdout] 328 | fn delete_char_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_word_backward` is never used
[INFO] [stdout]    --> src/keyboard.rs:335:4
[INFO] [stdout]     |
[INFO] [stdout] 335 | fn delete_word_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_word_forward` is never used
[INFO] [stdout]    --> src/keyboard.rs:345:4
[INFO] [stdout]     |
[INFO] [stdout] 345 | fn delete_word_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:357:4
[INFO] [stdout]     |
[INFO] [stdout] 357 | fn delete_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_clipboard` is never used
[INFO] [stdout]    --> src/keyboard.rs:372:4
[INFO] [stdout]     |
[INFO] [stdout] 372 | fn get_clipboard() -> Arc<Mutex<String>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:378:4
[INFO] [stdout]     |
[INFO] [stdout] 378 | fn copy_selection(buffer: &RopeBuffer, cursor: &Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cut_selection` is never used
[INFO] [stdout]    --> src/keyboard.rs:401:4
[INFO] [stdout]     |
[INFO] [stdout] 401 | fn cut_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cut_current_line` is never used
[INFO] [stdout]    --> src/keyboard.rs:406:4
[INFO] [stdout]     |
[INFO] [stdout] 406 | fn cut_current_line(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `paste_from_clipboard` is never used
[INFO] [stdout]    --> src/keyboard.rs:444:4
[INFO] [stdout]     |
[INFO] [stdout] 444 | fn paste_from_clipboard(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]    --> src/keyboard.rs:502:5
[INFO] [stdout]     |
[INFO] [stdout] 501 | pub enum EditorCommand {
[INFO] [stdout]     |          ------------- variants in this enum
[INFO] [stdout] 502 |     Quit,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 503 |     Save,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 504 |     NewTab,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 505 |     NewTerminal,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout] 506 |     CloseTab,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 507 |     NextTab,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 508 |     PrevTab,
[INFO] [stdout]     |     ^^^^^^^
[INFO] [stdout] 509 |     PageUp,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 510 |     PageDown,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 511 |     Modified,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 512 |     ToggleMenu,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 513 |     OpenFile,
[INFO] [stdout]     |     ^^^^^^^^
[INFO] [stdout] 514 |     CurrentTab,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 515 |     Undo,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 516 |     Redo,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 517 |     TogglePreview,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 518 |     ToggleWordWrap,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout] 519 |     FocusTreeView,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 520 |     FocusEditor,
[INFO] [stdout] 521 |     Find,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] 522 |     FindReplace,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `EditorCommand` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `TreeContextMenu` is never constructed
[INFO] [stdout]   --> src/menu.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 7  | pub enum MenuState {
[INFO] [stdout]    |          --------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 12 |     TreeContextMenu(TreeContextMenuState),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MenuState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `last_scroll_time` is never read
[INFO] [stdout]   --> src/menu.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 36 | pub struct FilePickerState {
[INFO] [stdout]    |            --------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     last_scroll_time: Option<Instant>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FilePickerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/menu.rs:169:12
[INFO] [stdout]     |
[INFO] [stdout] 70  | impl FilePickerState {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn update_filter(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |     fn search_recursive(&mut self, dir: &PathBuf, query: &str, depth: usize, max_depth: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 302 |     pub fn scroll_up(&mut self, base_amount: usize) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 312 |     pub fn scroll_down(&mut self, base_amount: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 323 |     fn update_scroll_acceleration(&mut self) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 362 |     pub fn move_left(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 367 |     pub fn move_right(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 377 |     pub fn select(&mut self) -> Option<PathBuf> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fuzzy_match` is never used
[INFO] [stdout]    --> src/menu.rs:430:4
[INFO] [stdout]     |
[INFO] [stdout] 430 | fn fuzzy_match(text: &str, pattern: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `open_tree_context_menu`, `open_tree_empty_area_menu`, `handle_up`, `handle_down`, and `handle_enter` are never used
[INFO] [stdout]    --> src/menu.rs:600:12
[INFO] [stdout]     |
[INFO] [stdout] 452 | impl MenuSystem {
[INFO] [stdout]     | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 600 |     pub fn open_tree_context_menu(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 663 |     pub fn open_tree_empty_area_menu(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 720 |     pub fn handle_up(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 729 |     pub fn handle_down(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 738 |     pub fn handle_enter(&mut self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `slice` is never used
[INFO] [stdout]   --> src/rope_buffer.rs:62:12
[INFO] [stdout]    |
[INFO] [stdout] 9  | impl RopeBuffer {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn slice(&self, range: Range<usize>) -> ropey::RopeSlice<'_> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `replace_all` is never used
[INFO] [stdout]    --> src/tab.rs:464:12
[INFO] [stdout]     |
[INFO] [stdout] 84  | impl Tab {
[INFO] [stdout]     | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 464 |     pub fn replace_all(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `move_up`, `move_down`, `get_selected_action`, `is_position_inside`, and `get_clicked_item` are never used
[INFO] [stdout]    --> src/ui/menu_component.rs:66:12
[INFO] [stdout]     |
[INFO] [stdout] 38  | impl MenuComponent {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66  |     pub fn move_up(&mut self) {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 72  |     pub fn move_down(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 78  |     pub fn get_selected_action(&self) -> Option<&MenuAction> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn is_position_inside(&self, area: &Rect, x: u16, y: u16) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 177 |     pub fn get_clicked_item(&self, area: &Rect, x: u16, y: u16) -> Option<usize> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `select_word_at_cursor` and `delete_input_selection` are never used
[INFO] [stdout]    --> src/handlers/ui_utilities.rs:159:12
[INFO] [stdout]     |
[INFO] [stdout] 7   | impl App {
[INFO] [stdout]     | -------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn select_word_at_cursor(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     pub fn delete_input_selection(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/app.rs:361:21
[INFO] [stdout]     |
[INFO] [stdout] 361 |                     tree_view.expand_to_file(path);
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 361 |                     let _ = tree_view.expand_to_file(path);
[INFO] [stdout]     |                     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/handlers/main_keyboard.rs:117:33
[INFO] [stdout]     |
[INFO] [stdout] 117 | ...                   tree_view.toggle_directory();
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 117 |                                 let _ = tree_view.toggle_directory();
[INFO] [stdout]     |                                 +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]    --> src/handlers/main_keyboard.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |                         tree_view.toggle_directory();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 123 |                         let _ = tree_view.toggle_directory();
[INFO] [stdout]     |                         +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 1.70s
[INFO] running `Command { std: "docker" "inspect" "d7b1ea42ed8a2e5e4e891ce631b3c41e7f89af138f0a45782f78add6de33d632", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d7b1ea42ed8a2e5e4e891ce631b3c41e7f89af138f0a45782f78add6de33d632", kill_on_drop: false }`
[INFO] [stdout] d7b1ea42ed8a2e5e4e891ce631b3c41e7f89af138f0a45782f78add6de33d632
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+733b47ea4b1b86216f14ef56e49440c33933f230" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] dc29a9f3781f1a392e0962204628e9910355c2a10bc6c10a5e40109dc8b3afc4
[INFO] running `Command { std: "docker" "start" "-a" "dc29a9f3781f1a392e0962204628e9910355c2a10bc6c10a5e40109dc8b3afc4", kill_on_drop: false }`
[INFO] [stderr] warning: unused variable: `message`
[INFO] [stderr]    --> src/file_operations.rs:125:26
[INFO] [stderr]     |
[INFO] [stderr] 125 |                     let (message, is_error) = match result {
[INFO] [stderr]     |                          ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_message`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `is_error`
[INFO] [stderr]    --> src/file_operations.rs:125:35
[INFO] [stderr]     |
[INFO] [stderr] 125 |                     let (message, is_error) = match result {
[INFO] [stderr]     |                                   ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_error`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `tree_view`
[INFO] [stderr]    --> src/file_operations.rs:134:29
[INFO] [stderr]     |
[INFO] [stderr] 134 |                 if let Some(tree_view) = &mut self.tree_view {
[INFO] [stderr]     |                             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_tree_view`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `active_index`
[INFO] [stderr]   --> src/handlers/mouse.rs:10:13
[INFO] [stderr]    |
[INFO] [stderr] 10 |         let active_index = self.tab_manager.active_index();
[INFO] [stderr]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_active_index`
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_word_separator` is never used
[INFO] [stderr]  --> src/app.rs:5:8
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub fn is_word_separator(ch: char) -> bool {
[INFO] [stderr]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: method `update_status_message` is never used
[INFO] [stderr]    --> src/app.rs:123:12
[INFO] [stderr]     |
[INFO] [stderr] 70  | impl App {
[INFO] [stderr]     | -------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 123 |     pub fn update_status_message(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/cursor.rs:106:12
[INFO] [stderr]     |
[INFO] [stderr] 22  | impl Cursor {
[INFO] [stderr]     | ----------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 106 |     pub fn move_word_left(&mut self, buffer: &RopeBuffer) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 147 |     pub fn move_word_right(&mut self, buffer: &RopeBuffer) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 215 |     pub fn select_all(&mut self, buffer: &RopeBuffer) {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 225 |     pub fn move_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 234 |     pub fn move_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 243 |     pub fn move_up_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 252 |     pub fn move_down_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 261 |     pub fn move_word_left_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 270 |     pub fn move_word_right_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 279 |     pub fn move_to_line_start_with_selection(&mut self, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 288 |     pub fn move_to_line_end_with_selection(&mut self, buffer: &RopeBuffer, extend_selection: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `CLIPBOARD` is never used
[INFO] [stderr]  --> src/keyboard.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | static CLIPBOARD: OnceLock<Arc<Mutex<String>>> = OnceLock::new();
[INFO] [stderr]   |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `handle_key_event` is never used
[INFO] [stderr]   --> src/keyboard.rs:11:8
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub fn handle_key_event(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `insert_char` is never used
[INFO] [stderr]    --> src/keyboard.rs:297:4
[INFO] [stderr]     |
[INFO] [stderr] 297 | fn insert_char(buffer: &mut RopeBuffer, cursor: &mut Cursor, ch: char) {
[INFO] [stderr]     |    ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `insert_newline` is never used
[INFO] [stderr]    --> src/keyboard.rs:312:4
[INFO] [stderr]     |
[INFO] [stderr] 312 | fn insert_newline(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_char_backward` is never used
[INFO] [stderr]    --> src/keyboard.rs:318:4
[INFO] [stderr]     |
[INFO] [stderr] 318 | fn delete_char_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_char_forward` is never used
[INFO] [stderr]    --> src/keyboard.rs:328:4
[INFO] [stderr]     |
[INFO] [stderr] 328 | fn delete_char_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_word_backward` is never used
[INFO] [stderr]    --> src/keyboard.rs:335:4
[INFO] [stderr]     |
[INFO] [stderr] 335 | fn delete_word_backward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_word_forward` is never used
[INFO] [stderr]    --> src/keyboard.rs:345:4
[INFO] [stderr]     |
[INFO] [stderr] 345 | fn delete_word_forward(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `delete_selection` is never used
[INFO] [stderr]    --> src/keyboard.rs:357:4
[INFO] [stderr]     |
[INFO] [stderr] 357 | fn delete_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_clipboard` is never used
[INFO] [stderr]    --> src/keyboard.rs:372:4
[INFO] [stderr]     |
[INFO] [stderr] 372 | fn get_clipboard() -> Arc<Mutex<String>> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `copy_selection` is never used
[INFO] [stderr]    --> src/keyboard.rs:378:4
[INFO] [stderr]     |
[INFO] [stderr] 378 | fn copy_selection(buffer: &RopeBuffer, cursor: &Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cut_selection` is never used
[INFO] [stderr]    --> src/keyboard.rs:401:4
[INFO] [stderr]     |
[INFO] [stderr] 401 | fn cut_selection(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cut_current_line` is never used
[INFO] [stderr]    --> src/keyboard.rs:406:4
[INFO] [stderr]     |
[INFO] [stderr] 406 | fn cut_current_line(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `paste_from_clipboard` is never used
[INFO] [stderr]    --> src/keyboard.rs:444:4
[INFO] [stderr]     |
[INFO] [stderr] 444 | fn paste_from_clipboard(buffer: &mut RopeBuffer, cursor: &mut Cursor) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple variants are never constructed
[INFO] [stderr]    --> src/keyboard.rs:502:5
[INFO] [stderr]     |
[INFO] [stderr] 501 | pub enum EditorCommand {
[INFO] [stderr]     |          ------------- variants in this enum
[INFO] [stderr] 502 |     Quit,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 503 |     Save,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 504 |     NewTab,
[INFO] [stderr]     |     ^^^^^^
[INFO] [stderr] 505 |     NewTerminal,
[INFO] [stderr]     |     ^^^^^^^^^^^
[INFO] [stderr] 506 |     CloseTab,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr] 507 |     NextTab,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr] 508 |     PrevTab,
[INFO] [stderr]     |     ^^^^^^^
[INFO] [stderr] 509 |     PageUp,
[INFO] [stderr]     |     ^^^^^^
[INFO] [stderr] 510 |     PageDown,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr] 511 |     Modified,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr] 512 |     ToggleMenu,
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr] 513 |     OpenFile,
[INFO] [stderr]     |     ^^^^^^^^
[INFO] [stderr] 514 |     CurrentTab,
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr] 515 |     Undo,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 516 |     Redo,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 517 |     TogglePreview,
[INFO] [stderr]     |     ^^^^^^^^^^^^^
[INFO] [stderr] 518 |     ToggleWordWrap,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^
[INFO] [stderr] 519 |     FocusTreeView,
[INFO] [stderr]     |     ^^^^^^^^^^^^^
[INFO] [stderr] 520 |     FocusEditor,
[INFO] [stderr] 521 |     Find,
[INFO] [stderr]     |     ^^^^
[INFO] [stderr] 522 |     FindReplace,
[INFO] [stderr]     |     ^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `EditorCommand` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `TreeContextMenu` is never constructed
[INFO] [stderr]   --> src/menu.rs:12:5
[INFO] [stderr]    |
[INFO] [stderr] 7  | pub enum MenuState {
[INFO] [stderr]    |          --------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 12 |     TreeContextMenu(TreeContextMenuState),
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `MenuState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `last_scroll_time` is never read
[INFO] [stderr]   --> src/menu.rs:44:5
[INFO] [stderr]    |
[INFO] [stderr] 36 | pub struct FilePickerState {
[INFO] [stderr]    |            --------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 44 |     last_scroll_time: Option<Instant>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FilePickerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/menu.rs:169:12
[INFO] [stderr]     |
[INFO] [stderr] 70  | impl FilePickerState {
[INFO] [stderr]     | -------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 169 |     pub fn update_filter(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 207 |     fn search_recursive(&mut self, dir: &PathBuf, query: &str, depth: usize, max_depth: usize) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 302 |     pub fn scroll_up(&mut self, base_amount: usize) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 312 |     pub fn scroll_down(&mut self, base_amount: usize) {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 323 |     fn update_scroll_acceleration(&mut self) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 362 |     pub fn move_left(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 367 |     pub fn move_right(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 377 |     pub fn select(&mut self) -> Option<PathBuf> {
[INFO] [stderr]     |            ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `fuzzy_match` is never used
[INFO] [stderr]    --> src/menu.rs:430:4
[INFO] [stderr]     |
[INFO] [stderr] 430 | fn fuzzy_match(text: &str, pattern: &str) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `open_tree_context_menu`, `open_tree_empty_area_menu`, `handle_up`, `handle_down`, and `handle_enter` are never used
[INFO] [stderr]    --> src/menu.rs:600:12
[INFO] [stderr]     |
[INFO] [stderr] 452 | impl MenuSystem {
[INFO] [stderr]     | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 600 |     pub fn open_tree_context_menu(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 663 |     pub fn open_tree_empty_area_menu(
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 720 |     pub fn handle_up(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 729 |     pub fn handle_down(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 738 |     pub fn handle_enter(&mut self) -> Option<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `slice` is never used
[INFO] [stderr]   --> src/rope_buffer.rs:62:12
[INFO] [stderr]    |
[INFO] [stderr] 9  | impl RopeBuffer {
[INFO] [stderr]    | --------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 62 |     pub fn slice(&self, range: Range<usize>) -> ropey::RopeSlice<'_> {
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `replace_all` is never used
[INFO] [stderr]    --> src/tab.rs:464:12
[INFO] [stderr]     |
[INFO] [stderr] 84  | impl Tab {
[INFO] [stderr]     | -------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 464 |     pub fn replace_all(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `move_up`, `move_down`, `get_selected_action`, `is_position_inside`, and `get_clicked_item` are never used
[INFO] [stderr]    --> src/ui/menu_component.rs:66:12
[INFO] [stderr]     |
[INFO] [stderr] 38  | impl MenuComponent {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 66  |     pub fn move_up(&mut self) {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 72  |     pub fn move_down(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 78  |     pub fn get_selected_action(&self) -> Option<&MenuAction> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 173 |     pub fn is_position_inside(&self, area: &Rect, x: u16, y: u16) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 177 |     pub fn get_clicked_item(&self, area: &Rect, x: u16, y: u16) -> Option<usize> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated functions `select_word_at_cursor` and `delete_input_selection` are never used
[INFO] [stderr]    --> src/handlers/ui_utilities.rs:159:12
[INFO] [stderr]     |
[INFO] [stderr] 7   | impl App {
[INFO] [stderr]     | -------- associated functions in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 159 |     pub fn select_word_at_cursor(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 187 |     pub fn delete_input_selection(input_state: &mut crate::menu::InputDialogState) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/app.rs:361:21
[INFO] [stderr]     |
[INFO] [stderr] 361 |                     tree_view.expand_to_file(path);
[INFO] [stderr]     |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr]     = note: `#[warn(unused_must_use)]` on by default
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 361 |                     let _ = tree_view.expand_to_file(path);
[INFO] [stderr]     |                     +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/handlers/main_keyboard.rs:117:33
[INFO] [stderr]     |
[INFO] [stderr] 117 | ...                   tree_view.toggle_directory();
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 117 |                                 let _ = tree_view.toggle_directory();
[INFO] [stderr]     |                                 +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused `Result` that must be used
[INFO] [stderr]    --> src/handlers/main_keyboard.rs:123:25
[INFO] [stderr]     |
[INFO] [stderr] 123 |                         tree_view.toggle_directory();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stderr] help: use `let _ = ...` to ignore the resulting value
[INFO] [stderr]     |
[INFO] [stderr] 123 |                         let _ = tree_view.toggle_directory();
[INFO] [stderr]     |                         +++++++
[INFO] [stderr] 
[INFO] [stderr] warning: `f1` (bin "f1" test) generated 34 warnings
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.17s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/f1-113d36c7be1dc230)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "dc29a9f3781f1a392e0962204628e9910355c2a10bc6c10a5e40109dc8b3afc4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "dc29a9f3781f1a392e0962204628e9910355c2a10bc6c10a5e40109dc8b3afc4", kill_on_drop: false }`
[INFO] [stdout] dc29a9f3781f1a392e0962204628e9910355c2a10bc6c10a5e40109dc8b3afc4
