[INFO] cloning repository https://github.com/rickmugridge/sicp
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rickmugridge/sicp" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frickmugridge%2Fsicp", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frickmugridge%2Fsicp'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a955f5e9f2a0159f17f1752911b0b5ea9e05828f
[INFO] checking rickmugridge/sicp against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frickmugridge%2Fsicp" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/rickmugridge/sicp
[INFO] finished tweaking git repo https://github.com/rickmugridge/sicp
[INFO] tweaked toml for git repo https://github.com/rickmugridge/sicp written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/rickmugridge/sicp on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/rickmugridge/sicp already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded cocoa-foundation v0.1.1
[INFO] [stderr]   Downloaded syn v2.0.10
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2dc00280972c938187e3ddf1db140d91cc0a1d09eb962ee1c4d4c91929d679e5
[INFO] running `Command { std: "docker" "start" "-a" "2dc00280972c938187e3ddf1db140d91cc0a1d09eb962ee1c4d4c91929d679e5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2dc00280972c938187e3ddf1db140d91cc0a1d09eb962ee1c4d4c91929d679e5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2dc00280972c938187e3ddf1db140d91cc0a1d09eb962ee1c4d4c91929d679e5", kill_on_drop: false }`
[INFO] [stdout] 2dc00280972c938187e3ddf1db140d91cc0a1d09eb962ee1c4d4c91929d679e5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] c63e3f6689f8c7126711c3eb66ff9e372be27f7d89f5961d96b03e22a476aea5
[INFO] running `Command { std: "docker" "start" "-a" "c63e3f6689f8c7126711c3eb66ff9e372be27f7d89f5961d96b03e22a476aea5", kill_on_drop: false }`
[INFO] [stderr]    Compiling xml-rs v0.8.4
[INFO] [stderr]    Compiling proc-macro2 v1.0.54
[INFO] [stderr]    Compiling quote v1.0.26
[INFO] [stderr]    Compiling memoffset v0.6.5
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]    Compiling wayland-sys v0.29.5
[INFO] [stderr]    Compiling memchr v2.5.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.15
[INFO] [stderr]     Checking dlib v0.5.0
[INFO] [stderr]    Compiling memoffset v0.8.0
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.14
[INFO] [stderr]     Checking nix v0.24.3
[INFO] [stderr]    Compiling num-traits v0.2.15
[INFO] [stderr]    Compiling rayon-core v1.11.0
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking crossbeam-channel v0.5.7
[INFO] [stderr]    Compiling parking_lot_core v0.8.6
[INFO] [stderr]     Checking nom v7.1.3
[INFO] [stderr]     Checking crossbeam-deque v0.8.3
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking nix v0.22.3
[INFO] [stderr]    Compiling wayland-scanner v0.29.5
[INFO] [stderr]    Compiling smithay-client-toolkit v0.15.4
[INFO] [stderr]     Checking instant v0.1.12
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]     Checking either v1.8.1
[INFO] [stderr]     Checking adler32 v1.2.0
[INFO] [stderr]    Compiling glutin_glx_sys v0.1.8
[INFO] [stderr]    Compiling glutin_egl_sys v0.1.6
[INFO] [stderr]     Checking rayon v1.7.0
[INFO] [stderr]     Checking wayland-commons v0.29.5
[INFO] [stderr]     Checking memmap2 v0.3.1
[INFO] [stderr]    Compiling num-rational v0.3.2
[INFO] [stderr]    Compiling num-iter v0.1.43
[INFO] [stderr]    Compiling winit v0.26.1
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]    Compiling cc v1.0.79
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]     Checking raw-window-handle v0.4.3
[INFO] [stderr]     Checking deflate v0.8.6
[INFO] [stderr]    Compiling wayland-client v0.29.5
[INFO] [stderr]    Compiling wayland-protocols v0.29.5
[INFO] [stderr]     Checking xcursor v0.3.4
[INFO] [stderr]     Checking parking_lot v0.11.2
[INFO] [stderr]     Checking miniz_oxide v0.3.7
[INFO] [stderr]    Compiling gl v0.14.0
[INFO] [stderr]    Compiling backtrace v0.3.67
[INFO] [stderr]     Checking mio v0.8.6
[INFO] [stderr]     Checking shared_library v0.1.9
[INFO] [stderr]     Checking getrandom v0.2.8
[INFO] [stderr]     Checking gimli v0.27.2
[INFO] [stderr]     Checking ttf-parser v0.15.2
[INFO] [stderr]     Checking gif v0.11.4
[INFO] [stderr]     Checking jpeg-decoder v0.1.22
[INFO] [stderr]     Checking calloop v0.9.3
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking tiff v0.6.1
[INFO] [stderr]     Checking osmesa-sys v0.1.2
[INFO] [stderr]     Checking png v0.16.8
[INFO] [stderr]     Checking object v0.30.3
[INFO] [stderr]     Checking wayland-cursor v0.29.5
[INFO] [stderr]     Checking wayland-egl v0.29.5
[INFO] [stderr]     Checking miniz_oxide v0.6.2
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.8
[INFO] [stderr]     Checking bytemuck v1.13.1
[INFO] [stderr]     Checking rustc-demangle v0.1.22
[INFO] [stderr]     Checking scoped_threadpool v0.1.9
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking image v0.23.14
[INFO] [stderr]     Checking earcutr v0.2.0
[INFO] [stderr]     Checking glow v0.7.2
[INFO] [stderr]     Checking owned_ttf_parser v0.15.2
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking rusttype v0.9.3
[INFO] [stderr]     Checking addr2line v0.19.0
[INFO] [stderr]     Checking glutin v0.28.0
[INFO] [stderr]     Checking speedy2d v1.12.0
[INFO] [stderr]     Checking sicp v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::f64::consts::PI`
[INFO] [stdout]  --> src/sine.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f64::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `say_hello` is never used
[INFO] [stdout]   --> src/main.rs:44:4
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn say_hello(s: &str) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_string` is never used
[INFO] [stdout]   --> src/main.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn change_string(s: &mut String) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sqrt` is never used
[INFO] [stdout]  --> src/sqrt.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn sqrt(guess: f32, x: f32) -> f32 {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `good_enough` is never used
[INFO] [stdout]  --> src/sqrt.rs:9:4
[INFO] [stdout]   |
[INFO] [stdout] 9 | fn good_enough(guess: f32, x: f32) -> bool {
[INFO] [stdout]   |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fib` is never used
[INFO] [stdout]  --> src/fibonacci.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn fib(n: usize) -> usize {
[INFO] [stdout]   |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fib_recurse` is never used
[INFO] [stdout]   --> src/fibonacci.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn fib_recurse(n: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_fib_recurse` is never used
[INFO] [stdout]   --> src/fibonacci.rs:23:4
[INFO] [stdout]    |
[INFO] [stdout] 23 | fn fast_fib_recurse(n: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_fib_recurse2` is never used
[INFO] [stdout]   --> src/fibonacci.rs:27:4
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn fast_fib_recurse2(a: usize, b: usize, p: usize, q: usize, count: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DENOMINATIONS` is never used
[INFO] [stdout]  --> src/counting_change.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | static DENOMINATIONS: [i32; 5] = [1, 5, 10, 25, 50];
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `counting_change` is never used
[INFO] [stdout]  --> src/counting_change.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn counting_change(amount: i32) -> usize {
[INFO] [stdout]   |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cc` is never used
[INFO] [stdout]  --> src/counting_change.rs:7:4
[INFO] [stdout]   |
[INFO] [stdout] 7 | fn cc(amount: i32, coin_kinds: usize) -> usize {
[INFO] [stdout]   |    ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `pascal_triangle` is never used
[INFO] [stdout]  --> src/pascal_triangle.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn pascal_triangle(n: usize) -> String {
[INFO] [stdout]   |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `triangle` is never used
[INFO] [stdout]   --> src/pascal_triangle.rs:18:4
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn triangle(n: usize) -> Vec<Vec<usize>> {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_row` is never used
[INFO] [stdout]   --> src/pascal_triangle.rs:31:4
[INFO] [stdout]    |
[INFO] [stdout] 31 | fn make_row(last_row: &Vec<usize>) -> Vec<usize> {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sine` is never used
[INFO] [stdout]  --> src/sine.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn sine(x: f64) -> f64 {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `poly` is never used
[INFO] [stdout]  --> src/sine.rs:7:4
[INFO] [stdout]   |
[INFO] [stdout] 7 | fn poly(x: f64) -> f64 {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rational` is never constructed
[INFO] [stdout]  --> src/rational.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | struct Rational {
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/rational.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Rational {
[INFO] [stdout]    | ------------- associated function in this implementation
[INFO] [stdout] 12 |     fn new(numerator: isize, denominator: isize) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `gcd` is never used
[INFO] [stdout]  --> src/gcd.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn gcd(a: isize, b: isize) -> isize {
[INFO] [stdout]   |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `List` is never used
[INFO] [stdout]  --> src/cons_clone.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | enum List<T> where T: Clone + Copy {
[INFO] [stdout]   |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/cons_clone.rs:12:8
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl<T> List<T> where T: Clone + Copy {
[INFO] [stdout]     | ------------------------------------- associated items in this implementation
[INFO] [stdout]  12 |     fn cons(t: T, tail: List<T>) -> Self {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  16 |     fn one(t: T) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout]  20 |     fn from_array(a: &[T]) -> Self {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  28 |     fn head(&self) -> Option<&T> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     fn tail(&self) -> Option<&List<T>> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  42 |     fn is_empty(&self) -> bool {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  49 |     fn map<U>(&self, f: &dyn Fn(T) -> U) -> List<U> where U: Clone + Copy {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout]  56 |     fn filter(&self, f: &dyn Fn(T) -> bool) -> Self {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn fold<U>(&self, base: U, op: &dyn Fn(T, U) -> U) -> U {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     fn nth(&self, i: isize) -> Option<&T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout]  86 |     fn length(&self) -> isize {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     fn length_iter(&self) -> isize {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn reverse(&self) -> Self {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn reverse_builder(&self, accum: List<T>) -> Self {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cons` is never constructed
[INFO] [stdout]    --> src/cons_clone.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | struct Cons<T> where T: Clone + Copy {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cons_clone.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl<T> Cons<T> where T: Clone + Copy {
[INFO] [stdout]     | ------------------------------------- associated function in this implementation
[INFO] [stdout] 122 |     fn new(car: T, cdr: List<T>) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `List` is never used
[INFO] [stdout]  --> src/cons.rs:5:6
[INFO] [stdout]   |
[INFO] [stdout] 5 | enum List<'a, T> {
[INFO] [stdout]   |      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/cons.rs:11:8
[INFO] [stdout]     |
[INFO] [stdout]  10 | impl<'a, T> List<'a, T> {
[INFO] [stdout]     | ----------------------- associated items in this implementation
[INFO] [stdout]  11 |     fn cons(t: &'a T, tail: Self) -> Self {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  15 |     fn one(t: &'a T) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout]  19 |     fn from_array<'b: 'a>(a: &'b [T]) -> Self {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  27 |     fn head(&self) -> Option<&'a T> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     fn tail(&self) -> Option<&List<'a, T>> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  41 |     fn is_empty(&self) -> bool {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  56 |     fn filter(&self, f: &dyn Fn(&'a T) -> bool) -> Self {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     fn fold<U>(&self, base: U, op: &dyn Fn(&'a T, U) -> U) -> U {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     fn nth(&self, i: isize) -> Option<&'a T> {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout]  86 |     fn length(&self) -> isize {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     fn length_iter(&self) -> isize {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 103 |     fn reverse(&self) -> Self {
[INFO] [stdout]     |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     fn reverse_builder(&self, accum: List<'a, T>) -> Self {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Cons` is never constructed
[INFO] [stdout]    --> src/cons.rs:116:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | struct Cons<'a, T> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/cons.rs:122:8
[INFO] [stdout]     |
[INFO] [stdout] 121 | impl<'a, T> Cons<'a, T> {
[INFO] [stdout]     | ----------------------- associated function in this implementation
[INFO] [stdout] 122 |     fn new(car: &'a T, cdr: List<'a, T>) -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `BinaryTree` is never constructed
[INFO] [stdout]  --> src/binary_tree_immutable.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | struct BinaryTree<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]   |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TreeNode` is never constructed
[INFO] [stdout]   --> src/binary_tree_immutable.rs:11:8
[INFO] [stdout]    |
[INFO] [stdout] 11 | struct TreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/binary_tree_immutable.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | / impl<T> BinaryTree<T>
[INFO] [stdout] 18 | |     where T: Clone + Copy + PartialEq + PartialOrd + Ord {
[INFO] [stdout]    | |________________________________________________________- associated items in this implementation
[INFO] [stdout] 19 |       fn new(tree: Option<Rc<TreeNode<T>>>) -> Self {
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |       fn count(&self) -> isize {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |       fn map<U: Copy>(&self, f: &dyn Fn(T) -> U) -> BinaryTree<U>
[INFO] [stdout]    |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |       fn contains(&self, x: T) -> bool {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |       fn immutably_add(&self, x: T) -> Self {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |       fn to_vec(&self) -> Vec<T> {
[INFO] [stdout]    |          ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 69 |       fn from_vec(elements: Vec<T>) -> Self {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 73 |       fn union(&self, other: Self) -> Self {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |       fn intersection(&self, other: &Self) -> Self {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:108:8
[INFO] [stdout]     |
[INFO] [stdout] 107 | impl<T> TreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     | ------------------------------------------------------------------ associated items in this implementation
[INFO] [stdout] 108 |     fn new(value: T,
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     fn empty(value: T) -> Self {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     fn count(&self) -> isize {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     fn map<U>(&self, f: &dyn Fn(T) -> U) -> TreeNode<U> where U: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 138 |     fn contains(&self, x: T) -> bool {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     fn to_vec(&self, elements: &mut Vec<T>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 164 |     fn from_vec(elements: &[T]) -> Option<Rc<TreeNode<T>>> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `immutably_add` is never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:175:4
[INFO] [stdout]     |
[INFO] [stdout] 175 | fn immutably_add<T>(node: Rc<TreeNode<T>>, x: T) -> Rc<TreeNode<T>> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cloned` is never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:208:4
[INFO] [stdout]     |
[INFO] [stdout] 208 | fn cloned<T>(node: &Option<Rc<TreeNode<T>>>) -> Option<Rc<TreeNode<T>>> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MutableBinaryTree` is never constructed
[INFO] [stdout]  --> src/binary_tree_mutable.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | struct MutableBinaryTree<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MutableTreeNode` is never constructed
[INFO] [stdout]   --> src/binary_tree_mutable.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | struct MutableTreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/binary_tree_mutable.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl<T> MutableBinaryTree<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]    | --------------------------------------------------------------------------- associated items in this implementation
[INFO] [stdout] 21 |     fn new(tree: Option<Box<MutableTreeNode<T>>>) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 25 |     fn count(&self) -> isize {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     fn map<U: Copy>(&self, f: &dyn Fn(T) -> U) -> MutableBinaryTree<U> where U: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     fn contains(&self, x: T) -> bool {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     fn insert(&mut self, x: T) -> bool {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn to_vec(&self) -> Vec<T> {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 77 |     fn from_vec(elements: Vec<T>) -> Self {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 81 |     fn find_by_key<K>(&self, key: K) -> Option<T>
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Record` is never used
[INFO] [stdout]   --> src/binary_tree_mutable.rs:91:7
[INFO] [stdout]    |
[INFO] [stdout] 91 | trait Record<K> {
[INFO] [stdout]    |       ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/binary_tree_mutable.rs:96:8
[INFO] [stdout]     |
[INFO] [stdout]  95 | impl<T> MutableTreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     | ------------------------------------------------------------------------- associated items in this implementation
[INFO] [stdout]  96 |     fn new(value: T,
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     fn empty(value: T) -> Self {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     fn count(&self) -> isize {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     fn map<U>(&self, f: &dyn Fn(T) -> U) -> MutableTreeNode<U> where U: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     fn contains(&self, x: T) -> bool {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 142 |     fn to_vec(&self, elements: &mut Vec<T>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 152 |     fn from_vec(elements: &[T]) -> Option<Box<MutableTreeNode<T>>> {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 162 |     fn find_by_key<K>(&self, key: K) -> Option<T> where
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `a` is never used
[INFO] [stdout]  --> src/ackermann.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn a(x: isize, y: isize) -> isize {
[INFO] [stdout]   |    ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `f` is never used
[INFO] [stdout]  --> src/ex1_11.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn f(n: usize) -> usize {
[INFO] [stdout]   |    ^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `f_iter` is never used
[INFO] [stdout]  --> src/ex1_11.rs:5:4
[INFO] [stdout]   |
[INFO] [stdout] 5 | fn f_iter(n: usize) -> usize {
[INFO] [stdout]   |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exponential` is never used
[INFO] [stdout]  --> src/exponential.rs:1:4
[INFO] [stdout]   |
[INFO] [stdout] 1 | fn exponential(base: usize, n: usize) -> usize {
[INFO] [stdout]   |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exponential_iter` is never used
[INFO] [stdout]  --> src/exponential.rs:5:4
[INFO] [stdout]   |
[INFO] [stdout] 5 | fn exponential_iter(base: usize, n: usize) -> usize {
[INFO] [stdout]   |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_exponentiation` is never used
[INFO] [stdout]   --> src/exponential.rs:15:4
[INFO] [stdout]    |
[INFO] [stdout] 15 | fn fast_exponentiation(base: usize, exponent: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_exponential_iter` is never used
[INFO] [stdout]   --> src/exponential.rs:26:4
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn fast_exponential_iter(base_given: usize, exponent_given: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `multiply` is never used
[INFO] [stdout]   --> src/exponential.rs:42:4
[INFO] [stdout]    |
[INFO] [stdout] 42 | fn multiply(a: usize, b: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `multiply_iter` is never used
[INFO] [stdout]   --> src/exponential.rs:46:4
[INFO] [stdout]    |
[INFO] [stdout] 46 | fn multiply_iter(a: usize, b: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_multiply_iter` is never used
[INFO] [stdout]   --> src/exponential.rs:52:4
[INFO] [stdout]    |
[INFO] [stdout] 52 | fn fast_multiply_iter(a: usize, b: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prime_naive` is never used
[INFO] [stdout]  --> src/prime.rs:4:4
[INFO] [stdout]   |
[INFO] [stdout] 4 | fn prime_naive(n: usize) -> bool {
[INFO] [stdout]   |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_divisor` is never used
[INFO] [stdout]  --> src/prime.rs:9:4
[INFO] [stdout]   |
[INFO] [stdout] 9 | fn find_divisor(n: usize, test_divisor: usize) -> usize {
[INFO] [stdout]   |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prime_naive_iter` is never used
[INFO] [stdout]   --> src/prime.rs:19:4
[INFO] [stdout]    |
[INFO] [stdout] 19 | fn prime_naive_iter(n: usize) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exp_mod` is never used
[INFO] [stdout]   --> src/prime.rs:29:4
[INFO] [stdout]    |
[INFO] [stdout] 29 | fn exp_mod(base: usize, exponent: usize, m: usize) -> usize {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fermat_test` is never used
[INFO] [stdout]   --> src/prime.rs:40:4
[INFO] [stdout]    |
[INFO] [stdout] 40 | fn fermat_test(n: usize) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fast_prime` is never used
[INFO] [stdout]   --> src/prime.rs:45:4
[INFO] [stdout]    |
[INFO] [stdout] 45 | fn fast_prime(n: usize, times: usize) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `time_search_for_primes` is never used
[INFO] [stdout]   --> src/prime.rs:54:4
[INFO] [stdout]    |
[INFO] [stdout] 54 | fn time_search_for_primes(from: usize, f: &dyn Fn(usize) -> bool, algorithm_name: &str) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_for_primes` is never used
[INFO] [stdout]   --> src/prime.rs:60:4
[INFO] [stdout]    |
[INFO] [stdout] 60 | fn search_for_primes(from: usize, f: &dyn Fn(usize) -> bool) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sum` is never used
[INFO] [stdout]  --> src/sum_higher_order.rs:4:4
[INFO] [stdout]   |
[INFO] [stdout] 4 | fn sum<S, T, Map, Next>(map: &Map, from: S, to: S, next: &Next) -> T
[INFO] [stdout]   |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sum_iter` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:18:4
[INFO] [stdout]    |
[INFO] [stdout] 18 | fn sum_iter<S, T, Map, Next>(map: &Map, from: S, to: S, next: &Next) -> T
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sum_range` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:35:4
[INFO] [stdout]    |
[INFO] [stdout] 35 | fn sum_range<S, T, Map, Next>(map: &Map, range: Range<S>, next: &Next) -> T
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `integral` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:51:4
[INFO] [stdout]    |
[INFO] [stdout] 51 | fn integral<Map>(map: &Map, from: f64, to: f64, dx: f64) -> f64 where Map: Fn(f64) -> f64 {
[INFO] [stdout]    |    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `product_range` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn product_range<Map, Next>(map: &Map, range: Range<f64>, next: &Next) -> f64
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `product_range_mul_one` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn product_range_mul_one<S, T, Map, Next>(map: &Map, range: Range<S>, next: &Next) -> T
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `product_range_mul_one_recursive` is never used
[INFO] [stdout]   --> src/sum_higher_order.rs:86:4
[INFO] [stdout]    |
[INFO] [stdout] 86 | fn product_range_mul_one_recursive<S, T, Map, Next>(map: &Map, range: Range<S>, next: &Next) -> T
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `accumulate` is never used
[INFO] [stdout]    --> src/sum_higher_order.rs:100:4
[INFO] [stdout]     |
[INFO] [stdout] 100 | fn accumulate<S, T, Map, Combine, Next>(initial: T, map: &Map, combine: &Combine, range: Range<S>, next: &Next) -> T
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `accumulate_iterator` is never used
[INFO] [stdout]    --> src/sum_higher_order.rs:116:4
[INFO] [stdout]     |
[INFO] [stdout] 116 | fn accumulate_iterator<T, Combine, Next>(initial: T, combine: &Combine, next: &mut Next) -> T
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search` is never used
[INFO] [stdout]  --> src/roots_of_equation.rs:3:4
[INFO] [stdout]   |
[INFO] [stdout] 3 | fn search<Function>(f: &Function, negative_point: f64, positive_point: f64) -> f64
[INFO] [stdout]   |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `average` is never used
[INFO] [stdout]   --> src/roots_of_equation.rs:20:4
[INFO] [stdout]    |
[INFO] [stdout] 20 | fn average(x: f64, y: f64) -> f64 {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `close_enough` is never used
[INFO] [stdout]   --> src/roots_of_equation.rs:24:4
[INFO] [stdout]    |
[INFO] [stdout] 24 | fn close_enough(x: f64, y: f64) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `half_interval` is never used
[INFO] [stdout]   --> src/roots_of_equation.rs:28:4
[INFO] [stdout]    |
[INFO] [stdout] 28 | fn half_interval<Function>(f: &Function, a: f64, b: f64) -> f64
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `fixed_point` is never used
[INFO] [stdout]  --> src/fixed_point.rs:1:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub fn fixed_point<Function>(f: &Function, first_guess: f64) -> f64
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `try_fixed_point` is never used
[INFO] [stdout]  --> src/fixed_point.rs:6:4
[INFO] [stdout]   |
[INFO] [stdout] 6 | fn try_fixed_point<Function>(f: &Function, guess: f64) -> f64
[INFO] [stdout]   |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `close_enough` is never used
[INFO] [stdout]   --> src/fixed_point.rs:12:4
[INFO] [stdout]    |
[INFO] [stdout] 12 | fn close_enough(x: f64, y: f64) -> bool {
[INFO] [stdout]    |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sqrt` is never used
[INFO] [stdout]   --> src/fixed_point.rs:16:4
[INFO] [stdout]    |
[INFO] [stdout] 16 | fn sqrt(x:f64) -> f64 {
[INFO] [stdout]    |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DX` is never used
[INFO] [stdout]  --> src/newton.rs:3:7
[INFO] [stdout]   |
[INFO] [stdout] 3 | const DX: f64 = 0.00001;
[INFO] [stdout]   |       ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `derive` is never used
[INFO] [stdout]  --> src/newton.rs:5:4
[INFO] [stdout]   |
[INFO] [stdout] 5 | fn derive(g: &dyn Fn(f64) -> f64) -> Box<dyn Fn(f64) -> f64 + '_> {
[INFO] [stdout]   |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cube` is never used
[INFO] [stdout]  --> src/newton.rs:9:4
[INFO] [stdout]   |
[INFO] [stdout] 9 | fn cube(x: f64) -> f64 {
[INFO] [stdout]   |    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Algebra` is never used
[INFO] [stdout]  --> src/derivative.rs:4:6
[INFO] [stdout]   |
[INFO] [stdout] 4 | enum Algebra {
[INFO] [stdout]   |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new_sum`, `new_product`, `new_power`, and `derive` are never used
[INFO] [stdout]   --> src/derivative.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Algebra {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 13 |     fn new_sum(addend: Algebra, augend: Algebra) -> Algebra {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     fn new_product(multiplier: Algebra, multiplicand: Algebra) -> Algebra {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 32 |     fn new_power(base: Algebra, exponent: Algebra) -> Algebra {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     fn derive(&self, variable: &str) -> Algebra {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `x_max`, `y_max`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/frame.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Frame {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn x_max(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn y_max(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_window` is never used
[INFO] [stdout]   --> src/picture_language/window.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn run_window() {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyWindowHandler` is never constructed
[INFO] [stdout]   --> src/picture_language/window.rs:20:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct MyWindowHandler {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_vec2` is never used
[INFO] [stdout]   --> src/picture_language/window.rs:27:4
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn to_vec2(vec: &Vector) -> Vec2 {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add` is never used
[INFO] [stdout]   --> src/picture_language/window_handler.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl PictureWindowHandler {
[INFO] [stdout]    | ------------------------- method in this implementation
[INFO] [stdout] 45 |     pub fn add(&mut self, shape: Shape) {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `PolyLine` is never constructed
[INFO] [stdout]  --> src/picture_language/shape.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub enum Shape {
[INFO] [stdout]   |          ----- variant in this enum
[INFO] [stdout] 7 |     Line(Segment, f32, Color),
[INFO] [stdout] 8 |     PolyLine(Vec<(Vector, Vector)>, f32, Color),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Shape` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_poly_line` is never used
[INFO] [stdout]   --> src/picture_language/shape.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Shape {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn new_poly_line(s: Vec<Segment>, thickness: f32, colour: Color) -> Shape {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tessellate_to_right`, `tessellate_to_down`, `tessellate`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/painter.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Painter {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn tessellate_to_right(&self, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn tessellate_to_down(&self, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn tessellate(&self, _translate_initial: Vector, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_right`, `to_below`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/composite_painter.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl CompositePainter {
[INFO] [stdout]    | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn to_right(&self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn to_below(&self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Huffman` is never used
[INFO] [stdout]  --> src/huffman.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | enum Huffman {
[INFO] [stdout]   |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/huffman.rs:12:8
[INFO] [stdout]     |
[INFO] [stdout]  11 | impl Huffman {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout]  12 |     fn new_leaf(ch: char, weight: usize) -> Self {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  16 |     fn new_non_leaf(left: Huffman, right: Huffman, chars: HashSet<char>, weight: usize) -> Self {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  21 |     fn contains(&self, ch: char) -> bool {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  29 |     fn encode(&self, s: &str) -> String {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  35 |     fn encode_char(&self, ch: char) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  51 |     fn decode(&self, s: &str) -> String {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  64 |     fn decode_with<'a>(&self, bits: &'a [char]) -> (char, &'a [char]) {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     fn make(leaves: Vec<(char, usize)>) -> Self {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  93 |     fn build(given_leaves: Vec<Huffman>) -> Self {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 108 |     fn build_from_pair(left: &Huffman, right: &Huffman) -> Huffman {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     fn weight(&self) -> usize {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 122 |     fn chars(&self) -> HashSet<char> {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Complex` is never used
[INFO] [stdout]  --> src/complex.rs:2:6
[INFO] [stdout]   |
[INFO] [stdout] 2 | enum Complex {
[INFO] [stdout]   |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/complex.rs:8:8
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl Complex {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout]  8 |     fn new_rectangular(real: f32, imaginary: f32) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 12 |     fn new_polar(magnitude: f32, angle: f32) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 16 |     fn real(&self) -> f32 {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     fn imaginary(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     fn magnitude(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     fn angle(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn plus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn minus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     fn times(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     fn divided_by(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `magnitude` and `angle` are never used
[INFO] [stdout]  --> src/complex_trait.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 1 | trait Complex {
[INFO] [stdout]   |       ------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 4 |     fn magnitude(&self) -> f32;
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 5 |     fn angle(&self) -> f32;
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `RectangularComplex` is never constructed
[INFO] [stdout]  --> src/complex_trait.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | struct RectangularComplex {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PolarComplex` is never constructed
[INFO] [stdout]   --> src/complex_trait.rs:33:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | struct PolarComplex {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add` is never used
[INFO] [stdout]   --> src/complex_trait.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | impl dyn Complex {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] 57 |     pub fn add(&self, other: &Self) -> Box<dyn Complex> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add` is never used
[INFO] [stdout]   --> src/complex_trait.rs:71:4
[INFO] [stdout]    |
[INFO] [stdout] 71 | fn add(a: &impl Complex, b: &impl Complex) -> Box<dyn Complex> {
[INFO] [stdout]    |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Complex` is never used
[INFO] [stdout]  --> src/complex_messaging.rs:2:6
[INFO] [stdout]   |
[INFO] [stdout] 2 | enum Complex {
[INFO] [stdout]   |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Field` is never used
[INFO] [stdout]  --> src/complex_messaging.rs:7:6
[INFO] [stdout]   |
[INFO] [stdout] 7 | enum Field {
[INFO] [stdout]   |      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]   --> src/complex_messaging.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Complex {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 15 |     fn new_rectangular(real: f32, imaginary: f32) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 19 |     fn new_polar(magnitude: f32, angle: f32) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 23 |     fn dispatch(&self, field: Field) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     fn real(&self) -> f32 {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn imaginary(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     fn magnitude(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     fn angle(&self) -> f32 {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 61 |     fn plus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn minus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     fn times(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     fn divided_by(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `say_hello` is never used
[INFO] [stdout]   --> src/main.rs:44:4
[INFO] [stdout]    |
[INFO] [stdout] 44 | fn say_hello(s: &str) {
[INFO] [stdout]    |    ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `change_string` is never used
[INFO] [stdout]   --> src/main.rs:48:4
[INFO] [stdout]    |
[INFO] [stdout] 48 | fn change_string(s: &mut String) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `immutably_add` is never used
[INFO] [stdout]   --> src/binary_tree_immutable.rs:51:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | / impl<T> BinaryTree<T>
[INFO] [stdout] 18 | |     where T: Clone + Copy + PartialEq + PartialOrd + Ord {
[INFO] [stdout]    | |________________________________________________________- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 51 |       fn immutably_add(&self, x: T) -> Self {
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:114:8
[INFO] [stdout]     |
[INFO] [stdout] 107 | impl<T> TreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     | ------------------------------------------------------------------ associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 114 |     fn empty(value: T) -> Self {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `immutably_add` is never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:175:4
[INFO] [stdout]     |
[INFO] [stdout] 175 | fn immutably_add<T>(node: Rc<TreeNode<T>>, x: T) -> Rc<TreeNode<T>> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cloned` is never used
[INFO] [stdout]    --> src/binary_tree_immutable.rs:208:4
[INFO] [stdout]     |
[INFO] [stdout] 208 | fn cloned<T>(node: &Option<Rc<TreeNode<T>>>) -> Option<Rc<TreeNode<T>>> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     |    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]    --> src/binary_tree_mutable.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout]  95 | impl<T> MutableTreeNode<T> where T: Clone + Copy + PartialEq + PartialOrd {
[INFO] [stdout]     | ------------------------------------------------------------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 102 |     fn empty(value: T) -> Self {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `x_max`, `y_max`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/frame.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | impl Frame {
[INFO] [stdout]    | ---------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn x_max(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 38 |     pub fn y_max(&self) -> f32 {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run_window` is never used
[INFO] [stdout]   --> src/picture_language/window.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub fn run_window() {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MyWindowHandler` is never constructed
[INFO] [stdout]   --> src/picture_language/window.rs:20:8
[INFO] [stdout]    |
[INFO] [stdout] 20 | struct MyWindowHandler {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_vec2` is never used
[INFO] [stdout]   --> src/picture_language/window.rs:27:4
[INFO] [stdout]    |
[INFO] [stdout] 27 | fn to_vec2(vec: &Vector) -> Vec2 {
[INFO] [stdout]    |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add` is never used
[INFO] [stdout]   --> src/picture_language/window_handler.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | impl PictureWindowHandler {
[INFO] [stdout]    | ------------------------- method in this implementation
[INFO] [stdout] 45 |     pub fn add(&mut self, shape: Shape) {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `PolyLine` is never constructed
[INFO] [stdout]  --> src/picture_language/shape.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub enum Shape {
[INFO] [stdout]   |          ----- variant in this enum
[INFO] [stdout] 7 |     Line(Segment, f32, Color),
[INFO] [stdout] 8 |     PolyLine(Vec<(Vector, Vector)>, f32, Color),
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Shape` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new_poly_line` is never used
[INFO] [stdout]   --> src/picture_language/shape.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl Shape {
[INFO] [stdout]    | ---------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn new_poly_line(s: Vec<Segment>, thickness: f32, colour: Color) -> Shape {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `tessellate_to_right`, `tessellate_to_down`, `tessellate`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/painter.rs:45:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Painter {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn tessellate_to_right(&self, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn tessellate_to_down(&self, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn tessellate(&self, _translate_initial: Vector, count: usize) -> CompositePainter {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_right`, `to_below`, and `transform` are never used
[INFO] [stdout]   --> src/picture_language/composite_painter.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl CompositePainter {
[INFO] [stdout]    | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn to_right(&self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn to_below(&self) -> Self {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     fn transform(&self, v: Vector) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `minus`, `times`, and `divided_by` are never used
[INFO] [stdout]   --> src/complex.rs:49:8
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl Complex {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 49 |     fn minus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     fn times(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     fn divided_by(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `add` is never used
[INFO] [stdout]   --> src/complex_trait.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 56 | impl dyn Complex {
[INFO] [stdout]    | ---------------- method in this implementation
[INFO] [stdout] 57 |     pub fn add(&self, other: &Self) -> Box<dyn Complex> {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `minus`, `times`, and `divided_by` are never used
[INFO] [stdout]   --> src/complex_messaging.rs:66:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Complex {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn minus(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 71 |     fn times(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     fn divided_by(&self, other: &Self) -> Self {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: call to `.clone()` on a reference in this situation does nothing
[INFO] [stdout]    --> src/binary_tree_mutable.rs:248:45
[INFO] [stdout]     |
[INFO] [stdout] 248 |                 Self::new(self.id, self.name.clone())
[INFO] [stdout]     |                                             ^^^^^^^^ help: remove this redundant call
[INFO] [stdout]     |
[INFO] [stdout]     = note: the type `str` does not implement `Clone`, so calling `clone` on `&str` copies the reference, which does not do anything and can be removed
[INFO] [stdout]     = note: `#[warn(noop_method_call)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 13s
[INFO] running `Command { std: "docker" "inspect" "c63e3f6689f8c7126711c3eb66ff9e372be27f7d89f5961d96b03e22a476aea5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c63e3f6689f8c7126711c3eb66ff9e372be27f7d89f5961d96b03e22a476aea5", kill_on_drop: false }`
[INFO] [stdout] c63e3f6689f8c7126711c3eb66ff9e372be27f7d89f5961d96b03e22a476aea5
