[INFO] crate treez 1.1.0 is already in cache [INFO] extracting crate treez 1.1.0 into work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/reg/treez/1.1.0 [INFO] extracting crate treez 1.1.0 into work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/reg/treez/1.1.0 [INFO] validating manifest of treez-1.1.0 on toolchain master#60960a260f7b5c695fd0717311d72ce62dd4eb43 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of treez-1.1.0 on toolchain try#266783e4e09e4e9d5307c1c8e695659c58bbcac7 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing treez-1.1.0 [INFO] finished frobbing treez-1.1.0 [INFO] frobbed toml for treez-1.1.0 written to work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/reg/treez/1.1.0/Cargo.toml [INFO] started frobbing treez-1.1.0 [INFO] finished frobbing treez-1.1.0 [INFO] frobbed toml for treez-1.1.0 written to work/ex/pr-63376/sources/try#266783e4e09e4e9d5307c1c8e695659c58bbcac7/reg/treez/1.1.0/Cargo.toml [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+266783e4e09e4e9d5307c1c8e695659c58bbcac7-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] checking treez-1.1.0 against master#60960a260f7b5c695fd0717311d72ce62dd4eb43 for pr-63376 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-63376/worker-2/master#60960a260f7b5c695fd0717311d72ce62dd4eb43:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-63376/sources/master#60960a260f7b5c695fd0717311d72ce62dd4eb43/reg/treez/1.1.0:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+60960a260f7b5c695fd0717311d72ce62dd4eb43-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] ccfdb5683ee6a1dab1447e036087489c26ac9255e14d2043dcd8276a4d3c2e22 [INFO] running `"docker" "start" "-a" "ccfdb5683ee6a1dab1447e036087489c26ac9255e14d2043dcd8276a4d3c2e22"` [INFO] [stderr] Checking mazth v0.0.0 [INFO] [stderr] Checking crossbeam-utils v0.6.6 [INFO] [stderr] Checking crossbeam-epoch v0.5.2 [INFO] [stderr] Checking chrono v0.4.7 [INFO] [stderr] Checking crossbeam-deque v0.5.2 [INFO] [stderr] Checking crossbeam-epoch v0.6.1 [INFO] [stderr] Checking crossbeam-channel v0.2.6 [INFO] [stderr] Checking crossbeam v0.4.1 [INFO] [stderr] Checking treez v1.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: unused import: `std::collections::HashSet` [INFO] [stderr] --> src/backtrack.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std::collections::HashSet; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Ordering`, `self` [INFO] [stderr] --> src/treap2.rs:1:16 [INFO] [stderr] | [INFO] [stderr] 1 | use std::cmp::{self,Ordering}; [INFO] [stderr] | ^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::mem` [INFO] [stderr] --> src/treap2.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::mem; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashSet` [INFO] [stderr] --> src/treap2.rs:3:24 [INFO] [stderr] | [INFO] [stderr] 3 | use std::collections::{HashSet,HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DerefMut`, `Deref` [INFO] [stderr] --> src/treap2.rs:5:16 [INFO] [stderr] | [INFO] [stderr] 5 | use std::ops::{Deref,DerefMut}; [INFO] [stderr] | ^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `RefMut` [INFO] [stderr] --> src/treap2.rs:6:25 [INFO] [stderr] | [INFO] [stderr] 6 | use std::cell::{RefCell,RefMut}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::chrono::prelude::*` [INFO] [stderr] --> src/treap2.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use self::chrono::prelude::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` head expression [INFO] [stderr] --> src/treap2.rs:654:24 [INFO] [stderr] | [INFO] [stderr] 654 | let t_l = match(l){ [INFO] [stderr] | ^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` head expression [INFO] [stderr] --> src/treap2.rs:665:24 [INFO] [stderr] | [INFO] [stderr] 665 | let t_r = match(r){ [INFO] [stderr] | ^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample': use Distribution instead [INFO] [stderr] --> src/policy.rs:9:33 [INFO] [stderr] | [INFO] [stderr] 9 | use self::rand::distributions::{IndependentSample, Range}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `self` [INFO] [stderr] --> src/treap2.rs:1:16 [INFO] [stderr] | [INFO] [stderr] 1 | use std::cmp::{self,Ordering}; [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::mem` [INFO] [stderr] --> src/treap2.rs:2:5 [INFO] [stderr] | [INFO] [stderr] 2 | use std::mem; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `HashSet` [INFO] [stderr] --> src/treap2.rs:3:24 [INFO] [stderr] | [INFO] [stderr] 3 | use std::collections::{HashSet,HashMap}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `DerefMut`, `Deref` [INFO] [stderr] --> src/treap2.rs:5:16 [INFO] [stderr] | [INFO] [stderr] 5 | use std::ops::{Deref,DerefMut}; [INFO] [stderr] | ^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `RefMut` [INFO] [stderr] --> src/treap2.rs:6:25 [INFO] [stderr] | [INFO] [stderr] 6 | use std::cell::{RefCell,RefMut}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` head expression [INFO] [stderr] --> src/treap2.rs:654:24 [INFO] [stderr] | [INFO] [stderr] 654 | let t_l = match(l){ [INFO] [stderr] | ^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `match` head expression [INFO] [stderr] --> src/treap2.rs:665:24 [INFO] [stderr] | [INFO] [stderr] 665 | let t_r = match(r){ [INFO] [stderr] | ^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1787:50 [INFO] [stderr] | [INFO] [stderr] 1787 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1804:50 [INFO] [stderr] | [INFO] [stderr] 1804 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1843:50 [INFO] [stderr] | [INFO] [stderr] 1843 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1857:50 [INFO] [stderr] | [INFO] [stderr] 1857 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1896:50 [INFO] [stderr] | [INFO] [stderr] 1896 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1910:50 [INFO] [stderr] | [INFO] [stderr] 1910 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1922:50 [INFO] [stderr] | [INFO] [stderr] 1922 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1961:50 [INFO] [stderr] | [INFO] [stderr] 1961 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:1975:50 [INFO] [stderr] | [INFO] [stderr] 1975 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:2108:54 [INFO] [stderr] | [INFO] [stderr] 2108 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around function argument [INFO] [stderr] --> src/treap2.rs:2133:54 [INFO] [stderr] | [INFO] [stderr] 2133 | .for_each(|(a,b)| assert!(equal_f32( (*a as f32), *b ) ) ); [INFO] [stderr] | ^^^^^^^^^^^ help: remove these parentheses [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample': use Distribution instead [INFO] [stderr] --> src/policy.rs:9:33 [INFO] [stderr] | [INFO] [stderr] 9 | use self::rand::distributions::{IndependentSample, Range}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:20:20 [INFO] [stderr] | [INFO] [stderr] 20 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let i = bounds_array.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:65:20 [INFO] [stderr] | [INFO] [stderr] 65 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:20:20 [INFO] [stderr] | [INFO] [stderr] 20 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let i = bounds_array.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'sarsa::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> src/policy.rs:65:20 [INFO] [stderr] | [INFO] [stderr] 65 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning[E0170]: pattern binding `Empty` is named the same as one of the variants of the type `treap::SearchResult` [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: to match on the variant, qualify the path: `treap::SearchResult::Empty` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root` [INFO] [stderr] --> src/treap2.rs:204:21 [INFO] [stderr] | [INFO] [stderr] 204 | let root = x.fixup_priority(); [INFO] [stderr] | ^^^^ help: consider prefixing with an underscore: `_root` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root2` [INFO] [stderr] --> src/treap2.rs:207:21 [INFO] [stderr] | [INFO] [stderr] 207 | let root2 = x.fixdown_priority(); [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_root2` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root` [INFO] [stderr] --> src/treap2.rs:230:21 [INFO] [stderr] | [INFO] [stderr] 230 | let root = child.as_ref().unwrap().fixup_priority(); [INFO] [stderr] | ^^^^ help: consider prefixing with an underscore: `_root` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `Empty` [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_Empty` [INFO] [stderr] [INFO] [stderr] warning: variable `count` is assigned to, but never used [INFO] [stderr] --> src/treap2.rs:401:17 [INFO] [stderr] | [INFO] [stderr] 401 | let mut count = 0; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: consider using `_count` instead [INFO] [stderr] [INFO] [stderr] warning: unused variable: `new_root` [INFO] [stderr] --> src/treap2.rs:700:22 [INFO] [stderr] | [INFO] [stderr] 700 | Some(new_root) => { [INFO] [stderr] | ^^^^^^^^ help: consider prefixing with an underscore: `_new_root` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/rb.rs:129:17 [INFO] [stderr] | [INFO] [stderr] 129 | let mut leaf_dummy = Node { [INFO] [stderr] | ----^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:400:13 [INFO] [stderr] | [INFO] [stderr] 400 | let mut x = self.clone(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:709:27 [INFO] [stderr] | [INFO] [stderr] 709 | pub fn union( & self, mut other: Self ) -> Self { [INFO] [stderr] | ----^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:781:31 [INFO] [stderr] | [INFO] [stderr] 781 | pub fn intersect( & self, mut other: Self ) -> Self { [INFO] [stderr] | ----^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:787:22 [INFO] [stderr] | [INFO] [stderr] 787 | let ( mut a, mut b ) = if self.prio() < other.prio() { [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable `Empty` should have a snake case name [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `empty` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning[E0170]: pattern binding `Empty` is named the same as one of the variants of the type `treap::SearchResult` [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: to match on the variant, qualify the path: `treap::SearchResult::Empty` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root` [INFO] [stderr] --> src/treap2.rs:204:21 [INFO] [stderr] | [INFO] [stderr] 204 | let root = x.fixup_priority(); [INFO] [stderr] | ^^^^ help: consider prefixing with an underscore: `_root` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root2` [INFO] [stderr] --> src/treap2.rs:207:21 [INFO] [stderr] | [INFO] [stderr] 207 | let root2 = x.fixdown_priority(); [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_root2` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `root` [INFO] [stderr] --> src/treap2.rs:230:21 [INFO] [stderr] | [INFO] [stderr] 230 | let root = child.as_ref().unwrap().fixup_priority(); [INFO] [stderr] | ^^^^ help: consider prefixing with an underscore: `_root` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `Empty` [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: consider prefixing with an underscore: `_Empty` [INFO] [stderr] [INFO] [stderr] warning: variable `count` is assigned to, but never used [INFO] [stderr] --> src/treap2.rs:401:17 [INFO] [stderr] | [INFO] [stderr] 401 | let mut count = 0; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: consider using `_count` instead [INFO] [stderr] [INFO] [stderr] warning: unused variable: `new_root` [INFO] [stderr] --> src/treap2.rs:700:22 [INFO] [stderr] | [INFO] [stderr] 700 | Some(new_root) => { [INFO] [stderr] | ^^^^^^^^ help: consider prefixing with an underscore: `_new_root` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/rb.rs:129:17 [INFO] [stderr] | [INFO] [stderr] 129 | let mut leaf_dummy = Node { [INFO] [stderr] | ----^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:400:13 [INFO] [stderr] | [INFO] [stderr] 400 | let mut x = self.clone(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:709:27 [INFO] [stderr] | [INFO] [stderr] 709 | pub fn union( & self, mut other: Self ) -> Self { [INFO] [stderr] | ----^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:781:31 [INFO] [stderr] | [INFO] [stderr] 781 | pub fn intersect( & self, mut other: Self ) -> Self { [INFO] [stderr] | ----^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:787:22 [INFO] [stderr] | [INFO] [stderr] 787 | let ( mut a, mut b ) = if self.prio() < other.prio() { [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:973:9 [INFO] [stderr] | [INFO] [stderr] 973 | let mut n2 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:982:9 [INFO] [stderr] | [INFO] [stderr] 982 | let mut n3 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:991:9 [INFO] [stderr] | [INFO] [stderr] 991 | let mut n4 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1014:9 [INFO] [stderr] | [INFO] [stderr] 1014 | let mut r0 = NodePtr(Rc::new( RefCell::new(n0) )); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1118:29 [INFO] [stderr] | [INFO] [stderr] 1118 | SearchResult::Exact(mut x) => { [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1174:9 [INFO] [stderr] | [INFO] [stderr] 1174 | let mut n2 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1183:9 [INFO] [stderr] | [INFO] [stderr] 1183 | let mut n3 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1192:9 [INFO] [stderr] | [INFO] [stderr] 1192 | let mut n4 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1215:9 [INFO] [stderr] | [INFO] [stderr] 1215 | let mut r0 = NodePtr(Rc::new( RefCell::new(n0) )); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1235:29 [INFO] [stderr] | [INFO] [stderr] 1235 | SearchResult::Exact(mut x) => { [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1268:9 [INFO] [stderr] | [INFO] [stderr] 1268 | let mut r0 = { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1288:13 [INFO] [stderr] | [INFO] [stderr] 1288 | let mut n2 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1297:13 [INFO] [stderr] | [INFO] [stderr] 1297 | let mut n3 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1306:13 [INFO] [stderr] | [INFO] [stderr] 1306 | let mut n4 = Node { [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1352:29 [INFO] [stderr] | [INFO] [stderr] 1352 | SearchResult::Exact(mut x) => { [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1400:9 [INFO] [stderr] | [INFO] [stderr] 1400 | let mut t = NodePtr::new(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1457:9 [INFO] [stderr] | [INFO] [stderr] 1457 | let mut t = NodePtr::new(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1514:9 [INFO] [stderr] | [INFO] [stderr] 1514 | let mut t = NodePtr::new(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1559:9 [INFO] [stderr] | [INFO] [stderr] 1559 | let mut t = NodePtr::new(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:1607:9 [INFO] [stderr] | [INFO] [stderr] 1607 | let mut t = NodePtr::new(); [INFO] [stderr] | ----^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2081:13 [INFO] [stderr] | [INFO] [stderr] 2081 | let mut t1 : NodePtr = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2082:13 [INFO] [stderr] | [INFO] [stderr] 2082 | let mut t2 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2093:13 [INFO] [stderr] | [INFO] [stderr] 2093 | let mut t2 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2117:13 [INFO] [stderr] | [INFO] [stderr] 2117 | let mut t1 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2223:13 [INFO] [stderr] | [INFO] [stderr] 2223 | let mut t1 : NodePtr = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2224:13 [INFO] [stderr] | [INFO] [stderr] 2224 | let mut t2 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2235:13 [INFO] [stderr] | [INFO] [stderr] 2235 | let mut t2 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/treap2.rs:2256:13 [INFO] [stderr] | [INFO] [stderr] 2256 | let mut t1 = NodePtr::new(); [INFO] [stderr] | ----^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: function is never used: `equal_f32` [INFO] [stderr] --> src/treap2.rs:2142:5 [INFO] [stderr] | [INFO] [stderr] 2142 | fn equal_f32( a: f32, b: f32 ) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: function is never used: `equal_f32` [INFO] [stderr] --> src/treap2.rs:2214:5 [INFO] [stderr] | [INFO] [stderr] 2214 | fn equal_f32( a: f32, b: f32 ) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `equal_f32` [INFO] [stderr] --> src/treap2.rs:2278:5 [INFO] [stderr] | [INFO] [stderr] 2278 | fn equal_f32( a: f32, b: f32 ) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `equal_f32` [INFO] [stderr] --> src/treap2.rs:2353:5 [INFO] [stderr] | [INFO] [stderr] 2353 | fn equal_f32( a: f32, b: f32 ) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variable `Empty` should have a snake case name [INFO] [stderr] --> src/treap2.rs:234:13 [INFO] [stderr] | [INFO] [stderr] 234 | Empty => { [INFO] [stderr] | ^^^^^ help: convert the identifier to snake case: `empty` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'test_rb::rand::distributions::IndependentSample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:8:33 [INFO] [stderr] | [INFO] [stderr] 8 | use self::rand::distributions::{IndependentSample, Range}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'rand::distributions::IndependentSample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:8:33 [INFO] [stderr] | [INFO] [stderr] 8 | use self::rand::distributions::{IndependentSample, Range}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:217:24 [INFO] [stderr] | [INFO] [stderr] 217 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:227:24 [INFO] [stderr] | [INFO] [stderr] 227 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:256:78 [INFO] [stderr] | [INFO] [stderr] 256 | let mut nums : Vec = (0..1000000).enumerate().map( |(_,_)| bounds.ind_sample( & mut rng ) ).collect(); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'test_rb::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:217:24 [INFO] [stderr] | [INFO] [stderr] 217 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'test_rb::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:227:24 [INFO] [stderr] | [INFO] [stderr] 227 | let r = bounds.ind_sample( & mut rng ); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'test_rb::rand::distributions::IndependentSample::ind_sample': use Distribution instead [INFO] [stderr] --> tests/test_rb.rs:256:78 [INFO] [stderr] | [INFO] [stderr] 256 | let mut nums : Vec = (0..1000000).enumerate().map( |(_,_)| bounds.ind_sample( & mut rng ) ).collect(); [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 12.07s [INFO] running `"docker" "inspect" "ccfdb5683ee6a1dab1447e036087489c26ac9255e14d2043dcd8276a4d3c2e22"` [INFO] running `"docker" "rm" "-f" "ccfdb5683ee6a1dab1447e036087489c26ac9255e14d2043dcd8276a4d3c2e22"` [INFO] [stdout] ccfdb5683ee6a1dab1447e036087489c26ac9255e14d2043dcd8276a4d3c2e22