[INFO] updating cached repository https://github.com/AttilaOrs/_tempBug [INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"` [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 7d087eed8cecac718445cba03999bbeedc5c1585 [INFO] testing AttilaOrs/_tempBug against try#41997647ba6a77908f6ef64401414feb00bccf16 for pr-71274 [INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAttilaOrs%2F_tempBug" "/workspace/builds/worker-7/source"` [INFO] [stderr] Cloning into '/workspace/builds/worker-7/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/AttilaOrs/_tempBug on toolchain 41997647ba6a77908f6ef64401414feb00bccf16 [INFO] running `"/workspace/cargo-home/bin/cargo" "+41997647ba6a77908f6ef64401414feb00bccf16" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking git repo https://github.com/AttilaOrs/_tempBug [INFO] finished tweaking git repo https://github.com/AttilaOrs/_tempBug [INFO] tweaked toml for git repo https://github.com/AttilaOrs/_tempBug written to /workspace/builds/worker-7/source/Cargo.toml [INFO] crate git repo https://github.com/AttilaOrs/_tempBug already has a lockfile, it will not be regenerated [INFO] running `"/workspace/cargo-home/bin/cargo" "+41997647ba6a77908f6ef64401414feb00bccf16" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+41997647ba6a77908f6ef64401414feb00bccf16" "build" "--frozen"` [INFO] [stdout] 62296ff6efe3066ab03a700ad71cd09c8abb7f55d760bafd35807a84725497d2 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `"docker" "start" "-a" "62296ff6efe3066ab03a700ad71cd09c8abb7f55d760bafd35807a84725497d2"` [INFO] [stderr] Compiling libc v0.2.51 [INFO] [stderr] Compiling smallvec v0.6.9 [INFO] [stderr] Compiling stable_deref_trait v1.1.1 [INFO] [stderr] Compiling fnv v1.0.2 [INFO] [stderr] Compiling crossbeam-utils v0.6.5 [INFO] [stderr] Compiling owning_ref v0.3.3 [INFO] [stderr] Compiling crossbeam-epoch v0.7.1 [INFO] [stderr] Compiling crossbeam-deque v0.7.1 [INFO] [stderr] Compiling rand v0.4.6 [INFO] [stderr] Compiling rand v0.3.14 [INFO] [stderr] Compiling parking_lot_core v0.2.14 [INFO] [stderr] Compiling parking_lot v0.4.8 [INFO] [stderr] Compiling chashmap v2.2.2 [INFO] [stderr] Compiling genetic v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/prisoner.rs:166:23 [INFO] [stderr] | [INFO] [stderr] 166 | impl Prisoner for Box { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:26:23 [INFO] [stderr] | [INFO] [stderr] 26 | oponents: Vec>, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::hash::BuildHasherDefault` [INFO] [stderr] --> src/genetic_algo.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use std::hash::BuildHasherDefault; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::fnv::FnvHasher` [INFO] [stderr] --> src/genetic_algo.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | use self::fnv::FnvHasher; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:82:15 [INFO] [stderr] | [INFO] [stderr] 82 | pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:83:19 [INFO] [stderr] | [INFO] [stderr] 83 | selector: Box, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:91:39 [INFO] [stderr] | [INFO] [stderr] 91 | pub fn new_with_default(pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:92:41 [INFO] [stderr] | [INFO] [stderr] 92 | ... select: Box) [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:173:27 [INFO] [stderr] | [INFO] [stderr] 173 | pub mutators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:174:29 [INFO] [stderr] | [INFO] [stderr] 174 | pub generators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:175:27 [INFO] [stderr] | [INFO] [stderr] 175 | pub breeders: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:176:27 [INFO] [stderr] | [INFO] [stderr] 176 | pub fitneses: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:267:28 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn new(my_mut: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:268:25 [INFO] [stderr] | [INFO] [stderr] 268 | gen: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:269:24 [INFO] [stderr] | [INFO] [stderr] 269 | br: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:270:24 [INFO] [stderr] | [INFO] [stderr] 270 | ft: Box>) [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:36 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:48 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:35 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:47 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:35 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:47 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:34 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:46 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:349:32 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Operators` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:387:27 [INFO] [stderr] | [INFO] [stderr] 387 | let muts: Vec>> = self.mutator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:391:27 [INFO] [stderr] | [INFO] [stderr] 391 | let gens: Vec>> = self.generator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:395:29 [INFO] [stderr] | [INFO] [stderr] 395 | let breeds: Vec>> = self.breeder_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:399:27 [INFO] [stderr] | [INFO] [stderr] 399 | let fits: Vec>> = self.fitnes_factories [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:595:9 [INFO] [stderr] | [INFO] [stderr] 595 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::PopulationManager` [INFO] [stderr] --> src/genetic_algo.rs:597:9 [INFO] [stderr] | [INFO] [stderr] 597 | use super::PopulationManager; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:677:36 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:728:44 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:784:17 [INFO] [stderr] | [INFO] [stderr] 784 | my_rng: Box, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:788:28 [INFO] [stderr] | [INFO] [stderr] 788 | pub fn new(my_rng: Box) -> RoulteWheelWithDuplicates { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:828:9 [INFO] [stderr] | [INFO] [stderr] 828 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicUsize`, `Ordering` [INFO] [stderr] --> src/concurentMap_divider.rs:5:25 [INFO] [stderr] | [INFO] [stderr] 5 | use std::sync::atomic::{AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `core::borrow::Borrow` [INFO] [stderr] --> src/concurentMap_divider.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use core::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:198:23 [INFO] [stderr] | [INFO] [stderr] 198 | leaf_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:199:23 [INFO] [stderr] | [INFO] [stderr] 199 | node_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:286:1 [INFO] [stderr] | [INFO] [stderr] 286 | / macro_rules! slisp { [INFO] [stderr] 287 | | [INFO] [stderr] 288 | | {$e:tt} =>{{ [INFO] [stderr] 289 | | [INFO] [stderr] ... | [INFO] [stderr] 292 | | }}; [INFO] [stderr] 293 | | } [INFO] [stderr] | |_^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_macros)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:295:1 [INFO] [stderr] | [INFO] [stderr] 295 | / macro_rules! tslisp { [INFO] [stderr] 296 | | [INFO] [stderr] 297 | | {$nodeT:ty; $leafT:ty; $e:tt} => {{ [INFO] [stderr] 298 | | let to_ret :BiTree<$nodeT, $leafT> = BiTree::from_slisp((stringify!($e)).to_string()); [INFO] [stderr] ... | [INFO] [stderr] 301 | | [INFO] [stderr] 302 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:304:1 [INFO] [stderr] | [INFO] [stderr] 304 | / macro_rules! b { [INFO] [stderr] 305 | | ($e:expr) => { [INFO] [stderr] 306 | | Box::new($e) [INFO] [stderr] 307 | | } [INFO] [stderr] 308 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::*` [INFO] [stderr] --> src/genetic_programming.rs:346:9 [INFO] [stderr] | [INFO] [stderr] 346 | use super::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AND`, `NAND`, `OR`, `XOR` [INFO] [stderr] --> src/genetic_programming.rs:347:34 [INFO] [stderr] | [INFO] [stderr] 347 | use super::BooleanLogicOps::{NAND, AND, XOR, OR}; [INFO] [stderr] | ^^^^ ^^^ ^^^ ^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_programming.rs:348:9 [INFO] [stderr] | [INFO] [stderr] 348 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/genetic_programming.rs:411:9 [INFO] [stderr] | [INFO] [stderr] 411 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ops` [INFO] [stderr] --> src/genetic_algo.rs:422:13 [INFO] [stderr] | [INFO] [stderr] 422 | let ops = self.make_operators(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_ops` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ini_id` [INFO] [stderr] --> src/genetic_algo.rs:451:27 [INFO] [stderr] | [INFO] [stderr] 451 | Task::Survive{ini_id} => {} // has to be resolved inline [INFO] [stderr] | ^^^^^^ help: try ignoring the field: `ini_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id` [INFO] [stderr] --> src/genetic_algo.rs:452:33 [INFO] [stderr] | [INFO] [stderr] 452 | Task::Mutate{op_id, indi_id} => { [INFO] [stderr] | ^^^^^^^ help: try ignoring the field: `indi_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id1` [INFO] [stderr] --> src/genetic_algo.rs:459:32 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id1: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id2` [INFO] [stderr] --> src/genetic_algo.rs:459:42 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id2: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:544:43 [INFO] [stderr] | [INFO] [stderr] 544 | Task::Mutate{indi_id, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:547:53 [INFO] [stderr] | [INFO] [stderr] 547 | Task::Breed{indi_id1, indi_id2, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `i` [INFO] [stderr] --> src/concurentMap_divider.rs:198:13 [INFO] [stderr] | [INFO] [stderr] 198 | for i in 0..self.join_handles.len() { [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `first_child` [INFO] [stderr] --> src/genetic_programming.rs:44:39 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try ignoring the field: `first_child: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `second_child` [INFO] [stderr] --> src/genetic_programming.rs:44:56 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: try ignoring the field: `second_child: _` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/genetic_algo.rs:541:29 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:541:50 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `OperatorFactoty` [INFO] [stderr] --> src/genetic_algo.rs:349:1 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `channel_preview` [INFO] [stderr] --> src/genetic_algo.rs:482:5 [INFO] [stderr] | [INFO] [stderr] 482 | channel_preview: Vec<(Task, Vec)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `make_test_builder` [INFO] [stderr] --> src/genetic_algo.rs:668:8 [INFO] [stderr] | [INFO] [stderr] 668 | fn make_test_builder() -> PoolBuilder { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_pool` [INFO] [stderr] --> src/genetic_algo.rs:677:8 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `complex_pool_test` [INFO] [stderr] --> src/genetic_algo.rs:728:8 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `example_hashmap` [INFO] [stderr] --> src/genetic_algo.rs:831:8 [INFO] [stderr] | [INFO] [stderr] 831 | fn example_hashmap() -> FitnesResult { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `results` [INFO] [stderr] --> src/task_devider.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | results: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/task_devider.rs:72:5 [INFO] [stderr] | [INFO] [stderr] 72 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `depth` [INFO] [stderr] --> src/genetic_programming.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | fn depth(&self) -> (u8, u8) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_node` [INFO] [stderr] --> src/genetic_programming.rs:41:5 [INFO] [stderr] | [INFO] [stderr] 41 | fn is_node(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `random_node` [INFO] [stderr] --> src/genetic_programming.rs:49:5 [INFO] [stderr] | [INFO] [stderr] 49 | fn random_node(&self) -> &BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `to_slisp` [INFO] [stderr] --> src/genetic_programming.rs:100:5 [INFO] [stderr] | [INFO] [stderr] 100 | fn to_slisp(&self) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `from_slisp` [INFO] [stderr] --> src/genetic_programming.rs:115:5 [INFO] [stderr] | [INFO] [stderr] 115 | fn from_slisp(from: String) -> BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: module `concurentMap_divider` should have a snake case name [INFO] [stderr] --> src/lib.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub mod concurentMap_divider; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `concurent_map_divider` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/task_devider.rs:148:13 [INFO] [stderr] | [INFO] [stderr] 148 | self.work_senders[i].send(None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 75 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 14.46s [INFO] running `"docker" "inspect" "62296ff6efe3066ab03a700ad71cd09c8abb7f55d760bafd35807a84725497d2"` [INFO] running `"docker" "rm" "-f" "62296ff6efe3066ab03a700ad71cd09c8abb7f55d760bafd35807a84725497d2"` [INFO] [stdout] 62296ff6efe3066ab03a700ad71cd09c8abb7f55d760bafd35807a84725497d2 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+41997647ba6a77908f6ef64401414feb00bccf16" "test" "--frozen" "--no-run"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 38c185fa10d2bd3acb078ed5c7d886623dfbad782c132a1960402015236bfe03 [INFO] running `"docker" "start" "-a" "38c185fa10d2bd3acb078ed5c7d886623dfbad782c132a1960402015236bfe03"` [INFO] [stderr] Compiling genetic v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/prisoner.rs:166:23 [INFO] [stderr] | [INFO] [stderr] 166 | impl Prisoner for Box { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:26:23 [INFO] [stderr] | [INFO] [stderr] 26 | oponents: Vec>, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::hash::BuildHasherDefault` [INFO] [stderr] --> src/genetic_algo.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use std::hash::BuildHasherDefault; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::fnv::FnvHasher` [INFO] [stderr] --> src/genetic_algo.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | use self::fnv::FnvHasher; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:82:15 [INFO] [stderr] | [INFO] [stderr] 82 | pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:83:19 [INFO] [stderr] | [INFO] [stderr] 83 | selector: Box, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:91:39 [INFO] [stderr] | [INFO] [stderr] 91 | pub fn new_with_default(pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:92:41 [INFO] [stderr] | [INFO] [stderr] 92 | ... select: Box) [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:173:27 [INFO] [stderr] | [INFO] [stderr] 173 | pub mutators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:174:29 [INFO] [stderr] | [INFO] [stderr] 174 | pub generators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:175:27 [INFO] [stderr] | [INFO] [stderr] 175 | pub breeders: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:176:27 [INFO] [stderr] | [INFO] [stderr] 176 | pub fitneses: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:267:28 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn new(my_mut: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:268:25 [INFO] [stderr] | [INFO] [stderr] 268 | gen: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:269:24 [INFO] [stderr] | [INFO] [stderr] 269 | br: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:270:24 [INFO] [stderr] | [INFO] [stderr] 270 | ft: Box>) [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:36 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:48 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:35 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:47 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:35 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:47 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:34 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:46 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:349:32 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Operators` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:387:27 [INFO] [stderr] | [INFO] [stderr] 387 | let muts: Vec>> = self.mutator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:391:27 [INFO] [stderr] | [INFO] [stderr] 391 | let gens: Vec>> = self.generator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:395:29 [INFO] [stderr] | [INFO] [stderr] 395 | let breeds: Vec>> = self.breeder_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:399:27 [INFO] [stderr] | [INFO] [stderr] 399 | let fits: Vec>> = self.fitnes_factories [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:595:9 [INFO] [stderr] | [INFO] [stderr] 595 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::PopulationManager` [INFO] [stderr] --> src/genetic_algo.rs:597:9 [INFO] [stderr] | [INFO] [stderr] 597 | use super::PopulationManager; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:677:36 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:728:44 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:784:17 [INFO] [stderr] | [INFO] [stderr] 784 | my_rng: Box, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:788:28 [INFO] [stderr] | [INFO] [stderr] 788 | pub fn new(my_rng: Box) -> RoulteWheelWithDuplicates { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:828:9 [INFO] [stderr] | [INFO] [stderr] 828 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicUsize`, `Ordering` [INFO] [stderr] --> src/concurentMap_divider.rs:5:25 [INFO] [stderr] | [INFO] [stderr] 5 | use std::sync::atomic::{AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `core::borrow::Borrow` [INFO] [stderr] --> src/concurentMap_divider.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use core::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:198:23 [INFO] [stderr] | [INFO] [stderr] 198 | leaf_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:199:23 [INFO] [stderr] | [INFO] [stderr] 199 | node_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:286:1 [INFO] [stderr] | [INFO] [stderr] 286 | / macro_rules! slisp { [INFO] [stderr] 287 | | [INFO] [stderr] 288 | | {$e:tt} =>{{ [INFO] [stderr] 289 | | [INFO] [stderr] ... | [INFO] [stderr] 292 | | }}; [INFO] [stderr] 293 | | } [INFO] [stderr] | |_^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_macros)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:295:1 [INFO] [stderr] | [INFO] [stderr] 295 | / macro_rules! tslisp { [INFO] [stderr] 296 | | [INFO] [stderr] 297 | | {$nodeT:ty; $leafT:ty; $e:tt} => {{ [INFO] [stderr] 298 | | let to_ret :BiTree<$nodeT, $leafT> = BiTree::from_slisp((stringify!($e)).to_string()); [INFO] [stderr] ... | [INFO] [stderr] 301 | | [INFO] [stderr] 302 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:304:1 [INFO] [stderr] | [INFO] [stderr] 304 | / macro_rules! b { [INFO] [stderr] 305 | | ($e:expr) => { [INFO] [stderr] 306 | | Box::new($e) [INFO] [stderr] 307 | | } [INFO] [stderr] 308 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::*` [INFO] [stderr] --> src/genetic_programming.rs:346:9 [INFO] [stderr] | [INFO] [stderr] 346 | use super::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AND`, `NAND`, `OR`, `XOR` [INFO] [stderr] --> src/genetic_programming.rs:347:34 [INFO] [stderr] | [INFO] [stderr] 347 | use super::BooleanLogicOps::{NAND, AND, XOR, OR}; [INFO] [stderr] | ^^^^ ^^^ ^^^ ^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_programming.rs:348:9 [INFO] [stderr] | [INFO] [stderr] 348 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/genetic_programming.rs:411:9 [INFO] [stderr] | [INFO] [stderr] 411 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ops` [INFO] [stderr] --> src/genetic_algo.rs:422:13 [INFO] [stderr] | [INFO] [stderr] 422 | let ops = self.make_operators(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_ops` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ini_id` [INFO] [stderr] --> src/genetic_algo.rs:451:27 [INFO] [stderr] | [INFO] [stderr] 451 | Task::Survive{ini_id} => {} // has to be resolved inline [INFO] [stderr] | ^^^^^^ help: try ignoring the field: `ini_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id` [INFO] [stderr] --> src/genetic_algo.rs:452:33 [INFO] [stderr] | [INFO] [stderr] 452 | Task::Mutate{op_id, indi_id} => { [INFO] [stderr] | ^^^^^^^ help: try ignoring the field: `indi_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id1` [INFO] [stderr] --> src/genetic_algo.rs:459:32 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id1: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id2` [INFO] [stderr] --> src/genetic_algo.rs:459:42 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id2: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:544:43 [INFO] [stderr] | [INFO] [stderr] 544 | Task::Mutate{indi_id, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:547:53 [INFO] [stderr] | [INFO] [stderr] 547 | Task::Breed{indi_id1, indi_id2, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `i` [INFO] [stderr] --> src/concurentMap_divider.rs:198:13 [INFO] [stderr] | [INFO] [stderr] 198 | for i in 0..self.join_handles.len() { [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `first_child` [INFO] [stderr] --> src/genetic_programming.rs:44:39 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try ignoring the field: `first_child: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `second_child` [INFO] [stderr] --> src/genetic_programming.rs:44:56 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: try ignoring the field: `second_child: _` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/genetic_algo.rs:541:29 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:541:50 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `OperatorFactoty` [INFO] [stderr] --> src/genetic_algo.rs:349:1 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `channel_preview` [INFO] [stderr] --> src/genetic_algo.rs:482:5 [INFO] [stderr] | [INFO] [stderr] 482 | channel_preview: Vec<(Task, Vec)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `make_test_builder` [INFO] [stderr] --> src/genetic_algo.rs:668:8 [INFO] [stderr] | [INFO] [stderr] 668 | fn make_test_builder() -> PoolBuilder { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_pool` [INFO] [stderr] --> src/genetic_algo.rs:677:8 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `complex_pool_test` [INFO] [stderr] --> src/genetic_algo.rs:728:8 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `example_hashmap` [INFO] [stderr] --> src/genetic_algo.rs:831:8 [INFO] [stderr] | [INFO] [stderr] 831 | fn example_hashmap() -> FitnesResult { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `results` [INFO] [stderr] --> src/task_devider.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | results: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/task_devider.rs:72:5 [INFO] [stderr] | [INFO] [stderr] 72 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `depth` [INFO] [stderr] --> src/genetic_programming.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | fn depth(&self) -> (u8, u8) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_node` [INFO] [stderr] --> src/genetic_programming.rs:41:5 [INFO] [stderr] | [INFO] [stderr] 41 | fn is_node(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `random_node` [INFO] [stderr] --> src/genetic_programming.rs:49:5 [INFO] [stderr] | [INFO] [stderr] 49 | fn random_node(&self) -> &BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `to_slisp` [INFO] [stderr] --> src/genetic_programming.rs:100:5 [INFO] [stderr] | [INFO] [stderr] 100 | fn to_slisp(&self) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `from_slisp` [INFO] [stderr] --> src/genetic_programming.rs:115:5 [INFO] [stderr] | [INFO] [stderr] 115 | fn from_slisp(from: String) -> BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: module `concurentMap_divider` should have a snake case name [INFO] [stderr] --> src/lib.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub mod concurentMap_divider; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `concurent_map_divider` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/task_devider.rs:148:13 [INFO] [stderr] | [INFO] [stderr] 148 | self.work_senders[i].send(None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 75 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/prisoner.rs:166:23 [INFO] [stderr] | [INFO] [stderr] 166 | impl Prisoner for Box { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:26:23 [INFO] [stderr] | [INFO] [stderr] 26 | oponents: Vec>, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `prisoner::*` [INFO] [stderr] --> src/genetic_prisoner.rs:62:9 [INFO] [stderr] | [INFO] [stderr] 62 | use prisoner::*; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_prisoner.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:83:30 [INFO] [stderr] | [INFO] [stderr] 83 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_prisoner::rand::thread_rng` [INFO] [stderr] --> src/genetic_prisoner.rs:108:9 [INFO] [stderr] | [INFO] [stderr] 108 | use genetic_prisoner::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::hash::BuildHasherDefault` [INFO] [stderr] --> src/genetic_algo.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use std::hash::BuildHasherDefault; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::fnv::FnvHasher` [INFO] [stderr] --> src/genetic_algo.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | use self::fnv::FnvHasher; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:82:15 [INFO] [stderr] | [INFO] [stderr] 82 | pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:83:19 [INFO] [stderr] | [INFO] [stderr] 83 | selector: Box, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:91:39 [INFO] [stderr] | [INFO] [stderr] 91 | pub fn new_with_default(pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:92:41 [INFO] [stderr] | [INFO] [stderr] 92 | ... select: Box) [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:173:27 [INFO] [stderr] | [INFO] [stderr] 173 | pub mutators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:174:29 [INFO] [stderr] | [INFO] [stderr] 174 | pub generators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:175:27 [INFO] [stderr] | [INFO] [stderr] 175 | pub breeders: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:176:27 [INFO] [stderr] | [INFO] [stderr] 176 | pub fitneses: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:267:28 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn new(my_mut: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:268:25 [INFO] [stderr] | [INFO] [stderr] 268 | gen: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:269:24 [INFO] [stderr] | [INFO] [stderr] 269 | br: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:270:24 [INFO] [stderr] | [INFO] [stderr] 270 | ft: Box>) [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:36 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:48 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:35 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:47 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:35 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:47 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:34 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:46 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:349:32 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Operators` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:387:27 [INFO] [stderr] | [INFO] [stderr] 387 | let muts: Vec>> = self.mutator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:391:27 [INFO] [stderr] | [INFO] [stderr] 391 | let gens: Vec>> = self.generator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:395:29 [INFO] [stderr] | [INFO] [stderr] 395 | let breeds: Vec>> = self.breeder_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:399:27 [INFO] [stderr] | [INFO] [stderr] 399 | let fits: Vec>> = self.fitnes_factories [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:595:9 [INFO] [stderr] | [INFO] [stderr] 595 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:677:36 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:728:44 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:784:17 [INFO] [stderr] | [INFO] [stderr] 784 | my_rng: Box, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:788:28 [INFO] [stderr] | [INFO] [stderr] 788 | pub fn new(my_rng: Box) -> RoulteWheelWithDuplicates { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicUsize`, `Ordering` [INFO] [stderr] --> src/concurentMap_divider.rs:5:25 [INFO] [stderr] | [INFO] [stderr] 5 | use std::sync::atomic::{AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `core::borrow::Borrow` [INFO] [stderr] --> src/concurentMap_divider.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use core::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:198:23 [INFO] [stderr] | [INFO] [stderr] 198 | leaf_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:199:23 [INFO] [stderr] | [INFO] [stderr] 199 | node_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_programming.rs:348:9 [INFO] [stderr] | [INFO] [stderr] 348 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `for` iterator expression [INFO] [stderr] --> src/genetic_programming.rs:421:18 [INFO] [stderr] | [INFO] [stderr] 421 | for _ in (0..20) { [INFO] [stderr] | ^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ops` [INFO] [stderr] --> src/genetic_algo.rs:422:13 [INFO] [stderr] | [INFO] [stderr] 422 | let ops = self.make_operators(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_ops` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ini_id` [INFO] [stderr] --> src/genetic_algo.rs:451:27 [INFO] [stderr] | [INFO] [stderr] 451 | Task::Survive{ini_id} => {} // has to be resolved inline [INFO] [stderr] | ^^^^^^ help: try ignoring the field: `ini_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id` [INFO] [stderr] --> src/genetic_algo.rs:452:33 [INFO] [stderr] | [INFO] [stderr] 452 | Task::Mutate{op_id, indi_id} => { [INFO] [stderr] | ^^^^^^^ help: try ignoring the field: `indi_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id1` [INFO] [stderr] --> src/genetic_algo.rs:459:32 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id1: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id2` [INFO] [stderr] --> src/genetic_algo.rs:459:42 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id2: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:544:43 [INFO] [stderr] | [INFO] [stderr] 544 | Task::Mutate{indi_id, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:547:53 [INFO] [stderr] | [INFO] [stderr] 547 | Task::Breed{indi_id1, indi_id2, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cntr` [INFO] [stderr] --> src/task_devider.rs:185:13 [INFO] [stderr] | [INFO] [stderr] 185 | let mut cntr = 0; [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cntr` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `i` [INFO] [stderr] --> src/concurentMap_divider.rs:198:13 [INFO] [stderr] | [INFO] [stderr] 198 | for i in 0..self.join_handles.len() { [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `first_child` [INFO] [stderr] --> src/genetic_programming.rs:44:39 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try ignoring the field: `first_child: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `second_child` [INFO] [stderr] --> src/genetic_programming.rs:44:56 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: try ignoring the field: `second_child: _` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/genetic_algo.rs:541:29 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:541:50 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:602:13 [INFO] [stderr] | [INFO] [stderr] 602 | let mut builder = make_test_builder(); [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/genetic_algo.rs:609:13 [INFO] [stderr] | [INFO] [stderr] 609 | let mut builder = make_test_builder(); [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/task_devider.rs:185:13 [INFO] [stderr] | [INFO] [stderr] 185 | let mut cntr = 0; [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `OperatorFactoty` [INFO] [stderr] --> src/genetic_algo.rs:349:1 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `channel_preview` [INFO] [stderr] --> src/genetic_algo.rs:482:5 [INFO] [stderr] | [INFO] [stderr] 482 | channel_preview: Vec<(Task, Vec)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `results` [INFO] [stderr] --> src/task_devider.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | results: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/task_devider.rs:72:5 [INFO] [stderr] | [INFO] [stderr] 72 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: module `concurentMap_divider` should have a snake case name [INFO] [stderr] --> src/lib.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub mod concurentMap_divider; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `concurent_map_divider` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/task_devider.rs:148:13 [INFO] [stderr] | [INFO] [stderr] 148 | self.work_senders[i].send(None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 67 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 6.74s [INFO] running `"docker" "inspect" "38c185fa10d2bd3acb078ed5c7d886623dfbad782c132a1960402015236bfe03"` [INFO] running `"docker" "rm" "-f" "38c185fa10d2bd3acb078ed5c7d886623dfbad782c132a1960402015236bfe03"` [INFO] [stdout] 38c185fa10d2bd3acb078ed5c7d886623dfbad782c132a1960402015236bfe03 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+41997647ba6a77908f6ef64401414feb00bccf16" "test" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 5b80807f6680235ec651fe7c29a37e8b05e1e9cbee6c2e338f46c6eb3be0e51e [INFO] running `"docker" "start" "-a" "5b80807f6680235ec651fe7c29a37e8b05e1e9cbee6c2e338f46c6eb3be0e51e"` [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/prisoner.rs:166:23 [INFO] [stderr] | [INFO] [stderr] 166 | impl Prisoner for Box { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:26:23 [INFO] [stderr] | [INFO] [stderr] 26 | oponents: Vec>, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `prisoner::*` [INFO] [stderr] --> src/genetic_prisoner.rs:62:9 [INFO] [stderr] | [INFO] [stderr] 62 | use prisoner::*; [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_prisoner.rs:63:9 [INFO] [stderr] | [INFO] [stderr] 63 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:83:30 [INFO] [stderr] | [INFO] [stderr] 83 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_prisoner::rand::thread_rng` [INFO] [stderr] --> src/genetic_prisoner.rs:108:9 [INFO] [stderr] | [INFO] [stderr] 108 | use genetic_prisoner::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::hash::BuildHasherDefault` [INFO] [stderr] --> src/genetic_algo.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use std::hash::BuildHasherDefault; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::fnv::FnvHasher` [INFO] [stderr] --> src/genetic_algo.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | use self::fnv::FnvHasher; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:82:15 [INFO] [stderr] | [INFO] [stderr] 82 | pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:83:19 [INFO] [stderr] | [INFO] [stderr] 83 | selector: Box, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:91:39 [INFO] [stderr] | [INFO] [stderr] 91 | pub fn new_with_default(pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:92:41 [INFO] [stderr] | [INFO] [stderr] 92 | ... select: Box) [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:173:27 [INFO] [stderr] | [INFO] [stderr] 173 | pub mutators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:174:29 [INFO] [stderr] | [INFO] [stderr] 174 | pub generators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:175:27 [INFO] [stderr] | [INFO] [stderr] 175 | pub breeders: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:176:27 [INFO] [stderr] | [INFO] [stderr] 176 | pub fitneses: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:267:28 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn new(my_mut: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:268:25 [INFO] [stderr] | [INFO] [stderr] 268 | gen: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:269:24 [INFO] [stderr] | [INFO] [stderr] 269 | br: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:270:24 [INFO] [stderr] | [INFO] [stderr] 270 | ft: Box>) [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:36 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:48 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:35 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:47 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:35 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:47 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:34 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:46 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:349:32 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Operators` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:387:27 [INFO] [stderr] | [INFO] [stderr] 387 | let muts: Vec>> = self.mutator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:391:27 [INFO] [stderr] | [INFO] [stderr] 391 | let gens: Vec>> = self.generator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:395:29 [INFO] [stderr] | [INFO] [stderr] 395 | let breeds: Vec>> = self.breeder_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:399:27 [INFO] [stderr] | [INFO] [stderr] 399 | let fits: Vec>> = self.fitnes_factories [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:595:9 [INFO] [stderr] | [INFO] [stderr] 595 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:677:36 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:728:44 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:784:17 [INFO] [stderr] | [INFO] [stderr] 784 | my_rng: Box, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:788:28 [INFO] [stderr] | [INFO] [stderr] 788 | pub fn new(my_rng: Box) -> RoulteWheelWithDuplicates { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicUsize`, `Ordering` [INFO] [stderr] --> src/concurentMap_divider.rs:5:25 [INFO] [stderr] | [INFO] [stderr] 5 | use std::sync::atomic::{AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `core::borrow::Borrow` [INFO] [stderr] --> src/concurentMap_divider.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use core::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:198:23 [INFO] [stderr] | [INFO] [stderr] 198 | leaf_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:199:23 [INFO] [stderr] | [INFO] [stderr] 199 | node_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_programming.rs:348:9 [INFO] [stderr] | [INFO] [stderr] 348 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unnecessary parentheses around `for` iterator expression [INFO] [stderr] --> src/genetic_programming.rs:421:18 [INFO] [stderr] | [INFO] [stderr] 421 | for _ in (0..20) { [INFO] [stderr] | ^^^^^^^ help: remove these parentheses [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_parens)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ops` [INFO] [stderr] --> src/genetic_algo.rs:422:13 [INFO] [stderr] | [INFO] [stderr] 422 | let ops = self.make_operators(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_ops` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ini_id` [INFO] [stderr] --> src/genetic_algo.rs:451:27 [INFO] [stderr] | [INFO] [stderr] 451 | Task::Survive{ini_id} => {} // has to be resolved inline [INFO] [stderr] | ^^^^^^ help: try ignoring the field: `ini_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id` [INFO] [stderr] --> src/genetic_algo.rs:452:33 [INFO] [stderr] | [INFO] [stderr] 452 | Task::Mutate{op_id, indi_id} => { [INFO] [stderr] | ^^^^^^^ help: try ignoring the field: `indi_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id1` [INFO] [stderr] --> src/genetic_algo.rs:459:32 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id1: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id2` [INFO] [stderr] --> src/genetic_algo.rs:459:42 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id2: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:544:43 [INFO] [stderr] | [INFO] [stderr] 544 | Task::Mutate{indi_id, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:547:53 [INFO] [stderr] | [INFO] [stderr] 547 | Task::Breed{indi_id1, indi_id2, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `cntr` [INFO] [stderr] --> src/task_devider.rs:185:13 [INFO] [stderr] | [INFO] [stderr] 185 | let mut cntr = 0; [INFO] [stderr] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_cntr` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `i` [INFO] [stderr] --> src/concurentMap_divider.rs:198:13 [INFO] [stderr] | [INFO] [stderr] 198 | for i in 0..self.join_handles.len() { [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `first_child` [INFO] [stderr] --> src/genetic_programming.rs:44:39 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try ignoring the field: `first_child: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `second_child` [INFO] [stderr] --> src/genetic_programming.rs:44:56 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: try ignoring the field: `second_child: _` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/genetic_algo.rs:541:29 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:541:50 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:602:13 [INFO] [stderr] | [INFO] [stderr] 602 | let mut builder = make_test_builder(); [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/genetic_algo.rs:609:13 [INFO] [stderr] | [INFO] [stderr] 609 | let mut builder = make_test_builder(); [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/task_devider.rs:185:13 [INFO] [stderr] | [INFO] [stderr] 185 | let mut cntr = 0; [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `OperatorFactoty` [INFO] [stderr] --> src/genetic_algo.rs:349:1 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `channel_preview` [INFO] [stderr] --> src/genetic_algo.rs:482:5 [INFO] [stderr] | [INFO] [stderr] 482 | channel_preview: Vec<(Task, Vec)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `results` [INFO] [stderr] --> src/task_devider.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | results: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/task_devider.rs:72:5 [INFO] [stderr] | [INFO] [stderr] 72 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: module `concurentMap_divider` should have a snake case name [INFO] [stderr] --> src/lib.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub mod concurentMap_divider; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `concurent_map_divider` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/task_devider.rs:148:13 [INFO] [stderr] | [INFO] [stderr] 148 | self.work_senders[i].send(None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 67 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/prisoner.rs:166:23 [INFO] [stderr] | [INFO] [stderr] 166 | impl Prisoner for Box { [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:26:23 [INFO] [stderr] | [INFO] [stderr] 26 | oponents: Vec>, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_prisoner.rs:32:30 [INFO] [stderr] | [INFO] [stderr] 32 | let mut ops: Vec> = Vec::with_capacity(3); [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Prisoner` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::hash::BuildHasherDefault` [INFO] [stderr] --> src/genetic_algo.rs:37:5 [INFO] [stderr] | [INFO] [stderr] 37 | use std::hash::BuildHasherDefault; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::fnv::FnvHasher` [INFO] [stderr] --> src/genetic_algo.rs:38:5 [INFO] [stderr] | [INFO] [stderr] 38 | use self::fnv::FnvHasher; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:82:15 [INFO] [stderr] | [INFO] [stderr] 82 | pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:83:19 [INFO] [stderr] | [INFO] [stderr] 83 | selector: Box, [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:91:39 [INFO] [stderr] | [INFO] [stderr] 91 | pub fn new_with_default(pool: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:92:41 [INFO] [stderr] | [INFO] [stderr] 92 | ... select: Box) [INFO] [stderr] | ^^^^^^^^ help: use `dyn`: `dyn Selector` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:173:27 [INFO] [stderr] | [INFO] [stderr] 173 | pub mutators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:174:29 [INFO] [stderr] | [INFO] [stderr] 174 | pub generators: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:175:27 [INFO] [stderr] | [INFO] [stderr] 175 | pub breeders: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:176:27 [INFO] [stderr] | [INFO] [stderr] 176 | pub fitneses: Vec>>, [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:267:28 [INFO] [stderr] | [INFO] [stderr] 267 | pub fn new(my_mut: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:268:25 [INFO] [stderr] | [INFO] [stderr] 268 | gen: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:269:24 [INFO] [stderr] | [INFO] [stderr] 269 | br: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:270:24 [INFO] [stderr] | [INFO] [stderr] 270 | ft: Box>) [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:36 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:345:48 [INFO] [stderr] | [INFO] [stderr] 345 | pub type GeneratoFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:35 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:346:47 [INFO] [stderr] | [INFO] [stderr] 346 | pub type MutatorFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:35 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:347:47 [INFO] [stderr] | [INFO] [stderr] 347 | pub type BreederFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:34 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Box>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:348:46 [INFO] [stderr] | [INFO] [stderr] 348 | pub type FitnesFactory = Box Box>>; [INFO] [stderr] | ^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:349:32 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Fn() -> Operators` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:387:27 [INFO] [stderr] | [INFO] [stderr] 387 | let muts: Vec>> = self.mutator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Mutator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:391:27 [INFO] [stderr] | [INFO] [stderr] 391 | let gens: Vec>> = self.generator_factories [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:395:29 [INFO] [stderr] | [INFO] [stderr] 395 | let breeds: Vec>> = self.breeder_factories [INFO] [stderr] | ^^^^^^^^^^^^^^ help: use `dyn`: `dyn Breeder` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:399:27 [INFO] [stderr] | [INFO] [stderr] 399 | let fits: Vec>> = self.fitnes_factories [INFO] [stderr] | ^^^^^^^^^^^^^ help: use `dyn`: `dyn Fintes` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:595:9 [INFO] [stderr] | [INFO] [stderr] 595 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::PopulationManager` [INFO] [stderr] --> src/genetic_algo.rs:597:9 [INFO] [stderr] | [INFO] [stderr] 597 | use super::PopulationManager; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:677:36 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:728:44 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualPool` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:784:17 [INFO] [stderr] | [INFO] [stderr] 784 | my_rng: Box, [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_algo.rs:788:28 [INFO] [stderr] | [INFO] [stderr] 788 | pub fn new(my_rng: Box) -> RoulteWheelWithDuplicates { [INFO] [stderr] | ^^^ help: use `dyn`: `dyn Rng` [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::rand::thread_rng` [INFO] [stderr] --> src/genetic_algo.rs:828:9 [INFO] [stderr] | [INFO] [stderr] 828 | use genetic_algo::rand::thread_rng; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AtomicUsize`, `Ordering` [INFO] [stderr] --> src/concurentMap_divider.rs:5:25 [INFO] [stderr] | [INFO] [stderr] 5 | use std::sync::atomic::{AtomicUsize, Ordering}; [INFO] [stderr] | ^^^^^^^^^^^ ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `core::borrow::Borrow` [INFO] [stderr] --> src/concurentMap_divider.rs:14:5 [INFO] [stderr] | [INFO] [stderr] 14 | use core::borrow::Borrow; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:198:23 [INFO] [stderr] | [INFO] [stderr] 198 | leaf_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/genetic_programming.rs:199:23 [INFO] [stderr] | [INFO] [stderr] 199 | node_factory: Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn IndividualGenerator` [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:286:1 [INFO] [stderr] | [INFO] [stderr] 286 | / macro_rules! slisp { [INFO] [stderr] 287 | | [INFO] [stderr] 288 | | {$e:tt} =>{{ [INFO] [stderr] 289 | | [INFO] [stderr] ... | [INFO] [stderr] 292 | | }}; [INFO] [stderr] 293 | | } [INFO] [stderr] | |_^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_macros)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:295:1 [INFO] [stderr] | [INFO] [stderr] 295 | / macro_rules! tslisp { [INFO] [stderr] 296 | | [INFO] [stderr] 297 | | {$nodeT:ty; $leafT:ty; $e:tt} => {{ [INFO] [stderr] 298 | | let to_ret :BiTree<$nodeT, $leafT> = BiTree::from_slisp((stringify!($e)).to_string()); [INFO] [stderr] ... | [INFO] [stderr] 301 | | [INFO] [stderr] 302 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused macro definition [INFO] [stderr] --> src/genetic_programming.rs:304:1 [INFO] [stderr] | [INFO] [stderr] 304 | / macro_rules! b { [INFO] [stderr] 305 | | ($e:expr) => { [INFO] [stderr] 306 | | Box::new($e) [INFO] [stderr] 307 | | } [INFO] [stderr] 308 | | } [INFO] [stderr] | |_^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `super::*` [INFO] [stderr] --> src/genetic_programming.rs:346:9 [INFO] [stderr] | [INFO] [stderr] 346 | use super::*; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `AND`, `NAND`, `OR`, `XOR` [INFO] [stderr] --> src/genetic_programming.rs:347:34 [INFO] [stderr] | [INFO] [stderr] 347 | use super::BooleanLogicOps::{NAND, AND, XOR, OR}; [INFO] [stderr] | ^^^^ ^^^ ^^^ ^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `genetic_algo::*` [INFO] [stderr] --> src/genetic_programming.rs:348:9 [INFO] [stderr] | [INFO] [stderr] 348 | use genetic_algo::*; [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/genetic_programming.rs:411:9 [INFO] [stderr] | [INFO] [stderr] 411 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ops` [INFO] [stderr] --> src/genetic_algo.rs:422:13 [INFO] [stderr] | [INFO] [stderr] 422 | let ops = self.make_operators(); [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_ops` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `ini_id` [INFO] [stderr] --> src/genetic_algo.rs:451:27 [INFO] [stderr] | [INFO] [stderr] 451 | Task::Survive{ini_id} => {} // has to be resolved inline [INFO] [stderr] | ^^^^^^ help: try ignoring the field: `ini_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id` [INFO] [stderr] --> src/genetic_algo.rs:452:33 [INFO] [stderr] | [INFO] [stderr] 452 | Task::Mutate{op_id, indi_id} => { [INFO] [stderr] | ^^^^^^^ help: try ignoring the field: `indi_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id1` [INFO] [stderr] --> src/genetic_algo.rs:459:32 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id1: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `indi_id2` [INFO] [stderr] --> src/genetic_algo.rs:459:42 [INFO] [stderr] | [INFO] [stderr] 459 | Task::Breed{op_id, indi_id1, indi_id2} => { [INFO] [stderr] | ^^^^^^^^ help: try ignoring the field: `indi_id2: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:544:43 [INFO] [stderr] | [INFO] [stderr] 544 | Task::Mutate{indi_id, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `op_id` [INFO] [stderr] --> src/genetic_algo.rs:547:53 [INFO] [stderr] | [INFO] [stderr] 547 | Task::Breed{indi_id1, indi_id2, op_id} => { [INFO] [stderr] | ^^^^^ help: try ignoring the field: `op_id: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `i` [INFO] [stderr] --> src/concurentMap_divider.rs:198:13 [INFO] [stderr] | [INFO] [stderr] 198 | for i in 0..self.join_handles.len() { [INFO] [stderr] | ^ help: if this is intentional, prefix it with an underscore: `_i` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `first_child` [INFO] [stderr] --> src/genetic_programming.rs:44:39 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^ help: try ignoring the field: `first_child: _` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `second_child` [INFO] [stderr] --> src/genetic_programming.rs:44:56 [INFO] [stderr] | [INFO] [stderr] 44 | BiTree::InnerNode{data:_, ref first_child, ref second_child} => true, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: try ignoring the field: `second_child: _` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/genetic_algo.rs:541:29 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [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/genetic_algo.rs:541:50 [INFO] [stderr] | [INFO] [stderr] 541 | while let Some((mut tt, mut old_ind, mut res)) = res.pop() { [INFO] [stderr] | ----^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `OperatorFactoty` [INFO] [stderr] --> src/genetic_algo.rs:349:1 [INFO] [stderr] | [INFO] [stderr] 349 | type OperatorFactoty = Box Operators>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never read: `channel_preview` [INFO] [stderr] --> src/genetic_algo.rs:482:5 [INFO] [stderr] | [INFO] [stderr] 482 | channel_preview: Vec<(Task, Vec)>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `make_test_builder` [INFO] [stderr] --> src/genetic_algo.rs:668:8 [INFO] [stderr] | [INFO] [stderr] 668 | fn make_test_builder() -> PoolBuilder { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `test_pool` [INFO] [stderr] --> src/genetic_algo.rs:677:8 [INFO] [stderr] | [INFO] [stderr] 677 | fn test_pool(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `complex_pool_test` [INFO] [stderr] --> src/genetic_algo.rs:728:8 [INFO] [stderr] | [INFO] [stderr] 728 | fn complex_pool_test(pool: &mut IndividualPool) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `example_hashmap` [INFO] [stderr] --> src/genetic_algo.rs:831:8 [INFO] [stderr] | [INFO] [stderr] 831 | fn example_hashmap() -> FitnesResult { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `results` [INFO] [stderr] --> src/task_devider.rs:23:5 [INFO] [stderr] | [INFO] [stderr] 23 | results: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `workers` [INFO] [stderr] --> src/task_devider.rs:72:5 [INFO] [stderr] | [INFO] [stderr] 72 | workers: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `depth` [INFO] [stderr] --> src/genetic_programming.rs:20:5 [INFO] [stderr] | [INFO] [stderr] 20 | fn depth(&self) -> (u8, u8) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_node` [INFO] [stderr] --> src/genetic_programming.rs:41:5 [INFO] [stderr] | [INFO] [stderr] 41 | fn is_node(&self) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `random_node` [INFO] [stderr] --> src/genetic_programming.rs:49:5 [INFO] [stderr] | [INFO] [stderr] 49 | fn random_node(&self) -> &BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `to_slisp` [INFO] [stderr] --> src/genetic_programming.rs:100:5 [INFO] [stderr] | [INFO] [stderr] 100 | fn to_slisp(&self) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `from_slisp` [INFO] [stderr] --> src/genetic_programming.rs:115:5 [INFO] [stderr] | [INFO] [stderr] 115 | fn from_slisp(from: String) -> BiTree { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: module `concurentMap_divider` should have a snake case name [INFO] [stderr] --> src/lib.rs:7:9 [INFO] [stderr] | [INFO] [stderr] 7 | pub mod concurentMap_divider; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `concurent_map_divider` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/task_devider.rs:148:13 [INFO] [stderr] | [INFO] [stderr] 148 | self.work_senders[i].send(None); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 75 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.19s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/genetic-7a615905730d6a6c [INFO] [stdout] [INFO] [stdout] running 31 tests [INFO] [stdout] test genetic_algo::selector_tests::RoulteWheelWithDuplicates_single_test ... ok [INFO] [stdout] test genetic_algo::pool_test::SingleThreadedPool_test ... ok [INFO] [stdout] test genetic_prisoner::tests::fitnes_for_prisoner ... ok [INFO] [stdout] test genetic_prisoner::tests::fitnes_for_prisoner_default_vals_does_somthing ... ok [INFO] [stdout] test genetic_algo::pool_test::population_test ... ok [INFO] [stdout] test genetic_algo::pool_test::PoolBuilder_can_add_factories ... ok [INFO] [stdout] test genetic_algo::selector_tests::RoulteWheelWithDuplicates_double_test ... ok [INFO] [stdout] test genetic_prisoner::tests::ok_vector_length ... ok [INFO] [stdout] test genetic_programming::test::BiTree_creaton ... ok [INFO] [stdout] test genetic_prisoner::tests::general_generator_test ... ok [INFO] [stdout] test genetic_prisoner::tests::general_mutator_test ... ok [INFO] [stdout] test genetic_programming::test::Inp_from_string_test ... ok [INFO] [stdout] test prisoner::tests::simuate ... ok [INFO] [stdout] test prisoner::tests::denail ... ok [INFO] [stdout] test genetic_programming::test::BooleanLogicOps_from_string_test ... ok [INFO] [stdout] test genetic_prisoner::tests::general_breeder_test ... ok [INFO] [stdout] test prisoner::tests::oposite ... ok [INFO] [stdout] test prisoner::tests::tit_for_tet ... ok [INFO] [stdout] test prisoner::tests::tree_prisoner_merged_history ... ok [INFO] [stdout] test prisoner::tests::value_table ... ok [INFO] [stdout] test prisoner::tests::tree_prisoner_behaviour ... ok [INFO] [stdout] test task_devider::tasker_test::simple_tasker ... ok [INFO] [stdout] test prisoner::tests::tree_prisoner_behaviour_more_history ... ok [INFO] [stdout] test genetic_programming::test::BiTree_random_generation ... ok [INFO] [stdout] test genetic_algo::pool_test::ConcuretPool_test_simple ... ok [INFO] [stdout] test task_devider::tasker_test::multi_tasker ... ok [INFO] [stdout] test genetic_programming::test::BiTree_parsing ... FAILED [INFO] [stdout] test genetic_prisoner::tests::wrong_vector_length ... ok [INFO] [stdout] test prisoner::tests::new_tree_prisoner ... ok [INFO] [stdout] test genetic_programming::test::BiTree_random_node ... FAILED [INFO] [stdout] test genetic_algo::pool_test::ConcuretPool_test_complex ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- genetic_programming::test::BiTree_parsing stdout ---- [INFO] [stdout] thread 'genetic_programming::test::BiTree_parsing' panicked at 'not a BooleanLogicOp:: and(xor', src/genetic_programming.rs:267:18 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x556cca3885c4 - backtrace::backtrace::libunwind::trace::h61666fa4b9834a45 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/libunwind.rs:86 [INFO] [stdout] 1: 0x556cca3885c4 - backtrace::backtrace::trace_unsynchronized::h01d3725fb5da8653 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/mod.rs:66 [INFO] [stdout] 2: 0x556cca3885c4 - std::sys_common::backtrace::_print_fmt::h5c7c4751bc296f90 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:78 [INFO] [stdout] 3: 0x556cca3885c4 - ::fmt::h7729313ad2d729c7 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:59 [INFO] [stdout] 4: 0x556cca3b268c - core::fmt::write::hb0049f6c12bdaffc [INFO] [stdout] at src/libcore/fmt/mod.rs:1069 [INFO] [stdout] 5: 0x556cca31f195 - std::io::Write::write_fmt::h5d052af13df32ea6 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/io/mod.rs:1504 [INFO] [stdout] 6: 0x556cca382be1 - std::io::impls::>::write_fmt::h8fe8a9bdc421b4b6 [INFO] [stdout] at src/libstd/io/impls.rs:156 [INFO] [stdout] 7: 0x556cca38ae95 - std::sys_common::backtrace::_print::ha087cac92e84a414 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:62 [INFO] [stdout] 8: 0x556cca38ae95 - std::sys_common::backtrace::print::h6b013d3bfe6cbcb8 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:49 [INFO] [stdout] 9: 0x556cca38ae95 - std::panicking::default_hook::{{closure}}::h016d7de02def2736 [INFO] [stdout] at src/libstd/panicking.rs:198 [INFO] [stdout] 10: 0x556cca38ab7b - std::panicking::default_hook::h9386f7e484840463 [INFO] [stdout] at src/libstd/panicking.rs:215 [INFO] [stdout] 11: 0x556cca38b4f2 - std::panicking::rust_panic_with_hook::h3846eb1b2e5a9312 [INFO] [stdout] at src/libstd/panicking.rs:511 [INFO] [stdout] 12: 0x556cca38b0db - rust_begin_unwind [INFO] [stdout] at src/libstd/panicking.rs:419 [INFO] [stdout] 13: 0x556cca38b04b - std::panicking::begin_panic_fmt::h2fa40d03719daab1 [INFO] [stdout] at src/libstd/panicking.rs:373 [INFO] [stdout] 14: 0x556cca2fc7e1 - ::from_string::h9d19c12ceb7a3408 [INFO] [stdout] at src/genetic_programming.rs:267 [INFO] [stdout] 15: 0x556cca2fbc70 - genetic::genetic_programming::BiTree::from_slisp::h7929698628d70b11 [INFO] [stdout] at src/genetic_programming.rs:187 [INFO] [stdout] 16: 0x556cca2a3a66 - genetic::genetic_programming::test::BiTree_parsing::hd2d44e37972031bf [INFO] [stdout] at src/genetic_programming.rs:385 [INFO] [stdout] 17: 0x556cca2a34fa - genetic::genetic_programming::test::BiTree_parsing::{{closure}}::h81ed46cb2cfccfd8 [INFO] [stdout] at src/genetic_programming.rs:374 [INFO] [stdout] 18: 0x556cca30509e - core::ops::function::FnOnce::call_once::hf91ed667028c18a4 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libcore/ops/function.rs:232 [INFO] [stdout] 19: 0x556cca32b08f - as core::ops::function::FnOnce>::call_once::h1f6ee40732e80908 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 20: 0x556cca34668e - as core::ops::function::FnOnce<()>>::call_once::h85dff111be9c2dc6 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:318 [INFO] [stdout] 21: 0x556cca34668e - std::panicking::try::do_call::hee6f5a4bef67c840 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:331 [INFO] [stdout] 22: 0x556cca34668e - std::panicking::try::h3384d3b948e84dbc [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:274 [INFO] [stdout] 23: 0x556cca34668e - std::panic::catch_unwind::h5ae91218e578066d [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:394 [INFO] [stdout] 24: 0x556cca34668e - test::run_test_in_process::he37a49587889b910 [INFO] [stdout] at src/libtest/lib.rs:541 [INFO] [stdout] 25: 0x556cca34668e - test::run_test::run_test_inner::{{closure}}::h4f0d25136ca480c2 [INFO] [stdout] at src/libtest/lib.rs:450 [INFO] [stdout] 26: 0x556cca31e646 - std::sys_common::backtrace::__rust_begin_short_backtrace::h969eceda34247af3 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/sys_common/backtrace.rs:130 [INFO] [stdout] 27: 0x556cca3239d5 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::h912007997cb04e92 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/thread/mod.rs:475 [INFO] [stdout] 28: 0x556cca3239d5 - as core::ops::function::FnOnce<()>>::call_once::h8795d8b7bd223988 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:318 [INFO] [stdout] 29: 0x556cca3239d5 - std::panicking::try::do_call::hb29b86f86d4d722e [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:331 [INFO] [stdout] 30: 0x556cca3239d5 - std::panicking::try::h4bfefb3eddc0d900 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:274 [INFO] [stdout] 31: 0x556cca3239d5 - std::panic::catch_unwind::h774c24d4b38d5828 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:394 [INFO] [stdout] 32: 0x556cca3239d5 - std::thread::Builder::spawn_unchecked::{{closure}}::ha50a32fa99413dde [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/thread/mod.rs:474 [INFO] [stdout] 33: 0x556cca3239d5 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9dacb8f28d699f86 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libcore/ops/function.rs:232 [INFO] [stdout] 34: 0x556cca37edbf - as core::ops::function::FnOnce>::call_once::h7deaeeba480c6ce2 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 35: 0x556cca391d03 - as core::ops::function::FnOnce>::call_once::h968b1dfb87756523 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 36: 0x556cca391d03 - std::sys::unix::thread::Thread::new::thread_start::h2399addeb6370595 [INFO] [stdout] at src/libstd/sys/unix/thread.rs:87 [INFO] [stdout] 37: 0x7f383ac126db - start_thread [INFO] [stdout] 38: 0x7f383a72388f - __clone [INFO] [stdout] 39: 0x0 - [INFO] [stdout] [INFO] [stdout] ---- genetic_programming::test::BiTree_random_node stdout ---- [INFO] [stdout] thread 'genetic_programming::test::BiTree_random_node' panicked at 'not a BooleanLogicOp:: and(or', src/genetic_programming.rs:267:18 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x556cca3885c4 - backtrace::backtrace::libunwind::trace::h61666fa4b9834a45 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/libunwind.rs:86 [INFO] [stdout] 1: 0x556cca3885c4 - backtrace::backtrace::trace_unsynchronized::h01d3725fb5da8653 [INFO] [stdout] at /cargo/registry/src/github.com-1ecc6299db9ec823/backtrace-0.3.46/src/backtrace/mod.rs:66 [INFO] [stdout] 2: 0x556cca3885c4 - std::sys_common::backtrace::_print_fmt::h5c7c4751bc296f90 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:78 [INFO] [stdout] 3: 0x556cca3885c4 - ::fmt::h7729313ad2d729c7 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:59 [INFO] [stdout] 4: 0x556cca3b268c - core::fmt::write::hb0049f6c12bdaffc [INFO] [stdout] at src/libcore/fmt/mod.rs:1069 [INFO] [stdout] 5: 0x556cca31f195 - std::io::Write::write_fmt::h5d052af13df32ea6 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/io/mod.rs:1504 [INFO] [stdout] 6: 0x556cca382be1 - std::io::impls::>::write_fmt::h8fe8a9bdc421b4b6 [INFO] [stdout] at src/libstd/io/impls.rs:156 [INFO] [stdout] 7: 0x556cca38ae95 - std::sys_common::backtrace::_print::ha087cac92e84a414 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:62 [INFO] [stdout] 8: 0x556cca38ae95 - std::sys_common::backtrace::print::h6b013d3bfe6cbcb8 [INFO] [stdout] at src/libstd/sys_common/backtrace.rs:49 [INFO] [stdout] 9: 0x556cca38ae95 - std::panicking::default_hook::{{closure}}::h016d7de02def2736 [INFO] [stdout] at src/libstd/panicking.rs:198 [INFO] [stdout] 10: 0x556cca38ab7b - std::panicking::default_hook::h9386f7e484840463 [INFO] [stdout] at src/libstd/panicking.rs:215 [INFO] [stdout] 11: 0x556cca38b4f2 - std::panicking::rust_panic_with_hook::h3846eb1b2e5a9312 [INFO] [stdout] at src/libstd/panicking.rs:511 [INFO] [stdout] 12: 0x556cca38b0db - rust_begin_unwind [INFO] [stdout] at src/libstd/panicking.rs:419 [INFO] [stdout] 13: 0x556cca38b04b - std::panicking::begin_panic_fmt::h2fa40d03719daab1 [INFO] [stdout] at src/libstd/panicking.rs:373 [INFO] [stdout] 14: 0x556cca2fc7e1 - ::from_string::h9d19c12ceb7a3408 [INFO] [stdout] at src/genetic_programming.rs:267 [INFO] [stdout] 15: 0x556cca2fbc70 - genetic::genetic_programming::BiTree::from_slisp::h7929698628d70b11 [INFO] [stdout] at src/genetic_programming.rs:187 [INFO] [stdout] 16: 0x556cca2a444a - genetic::genetic_programming::test::BiTree_random_node::hcbb6bd32559e645d [INFO] [stdout] at src/genetic_programming.rs:418 [INFO] [stdout] 17: 0x556cca2a41ca - genetic::genetic_programming::test::BiTree_random_node::{{closure}}::h495765759c9e9223 [INFO] [stdout] at src/genetic_programming.rs:414 [INFO] [stdout] 18: 0x556cca30481e - core::ops::function::FnOnce::call_once::h16bd6bfabd9843e9 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libcore/ops/function.rs:232 [INFO] [stdout] 19: 0x556cca32b08f - as core::ops::function::FnOnce>::call_once::h1f6ee40732e80908 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 20: 0x556cca34668e - as core::ops::function::FnOnce<()>>::call_once::h85dff111be9c2dc6 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:318 [INFO] [stdout] 21: 0x556cca34668e - std::panicking::try::do_call::hee6f5a4bef67c840 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:331 [INFO] [stdout] 22: 0x556cca34668e - std::panicking::try::h3384d3b948e84dbc [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:274 [INFO] [stdout] 23: 0x556cca34668e - std::panic::catch_unwind::h5ae91218e578066d [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:394 [INFO] [stdout] 24: 0x556cca34668e - test::run_test_in_process::he37a49587889b910 [INFO] [stdout] at src/libtest/lib.rs:541 [INFO] [stdout] 25: 0x556cca34668e - test::run_test::run_test_inner::{{closure}}::h4f0d25136ca480c2 [INFO] [stdout] at src/libtest/lib.rs:450 [INFO] [stdout] 26: 0x556cca31e646 - std::sys_common::backtrace::__rust_begin_short_backtrace::h969eceda34247af3 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/sys_common/backtrace.rs:130 [INFO] [stdout] 27: 0x556cca3239d5 - std::thread::Builder::spawn_unchecked::{{closure}}::{{closure}}::h912007997cb04e92 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/thread/mod.rs:475 [INFO] [stdout] 28: 0x556cca3239d5 - as core::ops::function::FnOnce<()>>::call_once::h8795d8b7bd223988 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:318 [INFO] [stdout] 29: 0x556cca3239d5 - std::panicking::try::do_call::hb29b86f86d4d722e [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:331 [INFO] [stdout] 30: 0x556cca3239d5 - std::panicking::try::h4bfefb3eddc0d900 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panicking.rs:274 [INFO] [stdout] 31: 0x556cca3239d5 - std::panic::catch_unwind::h774c24d4b38d5828 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/panic.rs:394 [INFO] [stdout] 32: 0x556cca3239d5 - std::thread::Builder::spawn_unchecked::{{closure}}::ha50a32fa99413dde [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libstd/thread/mod.rs:474 [INFO] [stdout] 33: 0x556cca3239d5 - core::ops::function::FnOnce::call_once{{vtable.shim}}::h9dacb8f28d699f86 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/libcore/ops/function.rs:232 [INFO] [stdout] 34: 0x556cca37edbf - as core::ops::function::FnOnce>::call_once::h7deaeeba480c6ce2 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 35: 0x556cca391d03 - as core::ops::function::FnOnce>::call_once::h968b1dfb87756523 [INFO] [stdout] at /rustc/41997647ba6a77908f6ef64401414feb00bccf16/src/liballoc/boxed.rs:1008 [INFO] [stdout] 36: 0x556cca391d03 - std::sys::unix::thread::Thread::new::thread_start::h2399addeb6370595 [INFO] [stdout] at src/libstd/sys/unix/thread.rs:87 [INFO] [stdout] 37: 0x7f383ac126db - start_thread [INFO] [stdout] 38: 0x7f383a72388f - __clone [INFO] [stdout] 39: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] genetic_programming::test::BiTree_parsing [INFO] [stdout] genetic_programming::test::BiTree_random_node [INFO] [stdout] [INFO] [stdout] test result: FAILED. 29 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass '--lib' [INFO] running `"docker" "inspect" "5b80807f6680235ec651fe7c29a37e8b05e1e9cbee6c2e338f46c6eb3be0e51e"` [INFO] running `"docker" "rm" "-f" "5b80807f6680235ec651fe7c29a37e8b05e1e9cbee6c2e338f46c6eb3be0e51e"` [INFO] [stdout] 5b80807f6680235ec651fe7c29a37e8b05e1e9cbee6c2e338f46c6eb3be0e51e