[INFO] updating cached repository TileHalo/Kisalaskuri [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/TileHalo/Kisalaskuri [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/TileHalo/Kisalaskuri" "work/ex/clippy-test-run/sources/stable/gh/TileHalo/Kisalaskuri"` [INFO] [stderr] Cloning into 'work/ex/clippy-test-run/sources/stable/gh/TileHalo/Kisalaskuri'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/TileHalo/Kisalaskuri" "work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/gh/TileHalo/Kisalaskuri"` [INFO] [stderr] Cloning into 'work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/gh/TileHalo/Kisalaskuri'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] dc8eada055232c9d79a405ca35b14456aa45669e [INFO] sha for GitHub repo TileHalo/Kisalaskuri: dc8eada055232c9d79a405ca35b14456aa45669e [INFO] validating manifest of TileHalo/Kisalaskuri on toolchain stable [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of TileHalo/Kisalaskuri on toolchain stable+rustflags=-Dclippy::into_iter_on_array [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing TileHalo/Kisalaskuri [INFO] finished frobbing TileHalo/Kisalaskuri [INFO] frobbed toml for TileHalo/Kisalaskuri written to work/ex/clippy-test-run/sources/stable/gh/TileHalo/Kisalaskuri/Cargo.toml [INFO] started frobbing TileHalo/Kisalaskuri [INFO] finished frobbing TileHalo/Kisalaskuri [INFO] frobbed toml for TileHalo/Kisalaskuri written to work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/gh/TileHalo/Kisalaskuri/Cargo.toml [INFO] crate TileHalo/Kisalaskuri has a lockfile. skipping [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+stable" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] linting TileHalo/Kisalaskuri against stable+rustflags=-Dclippy::into_iter_on_array for clippy-test-run [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/clippy-test-run/worker-7/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/clippy-test-run/sources/stable+rustflags=-Dclippy%3A%3Ainto_iter_on_array/gh/TileHalo/Kisalaskuri:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Dclippy::into_iter_on_array" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+stable" "clippy" "--frozen" "--all" "--all-targets"` [INFO] [stdout] e63a9d966cc8184eb9517f5004db8159fc2fa6df8ca149306bfb014cc013c16c [INFO] running `"docker" "start" "-a" "e63a9d966cc8184eb9517f5004db8159fc2fa6df8ca149306bfb014cc013c16c"` [INFO] [stderr] Compiling cc v1.0.4 [INFO] [stderr] Compiling unicode-xid v0.0.4 [INFO] [stderr] Compiling quote v0.3.15 [INFO] [stderr] Compiling pest v1.0.3 [INFO] [stderr] Checking cast v0.2.2 [INFO] [stderr] Checking kilac v0.2.0 (/opt/crater/workdir) [INFO] [stderr] Checking isatty v0.1.6 [INFO] [stderr] error[E0602]: unknown lint: `clippy::into_iter_on_array` [INFO] [stderr] | [INFO] [stderr] = note: requested on the command line with `-D clippy::into_iter_on_array` [INFO] [stderr] [INFO] [stderr] error[E0602]: unknown lint: `clippy::into_iter_on_array` [INFO] [stderr] | [INFO] [stderr] = note: requested on the command line with `-D clippy::into_iter_on_array` [INFO] [stderr] [INFO] [stderr] warning: 5th binding whose name is just one char [INFO] [stderr] --> src/calc/parser/applicators.rs:69:28 [INFO] [stderr] | [INFO] [stderr] 69 | Ok(l) => l, [INFO] [stderr] | ^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::many_single_char_names)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#many_single_char_names [INFO] [stderr] [INFO] [stderr] error[E0602]: unknown lint: `clippy::into_iter_on_array` [INFO] [stderr] | [INFO] [stderr] = note: requested on the command line with `-D clippy::into_iter_on_array` [INFO] [stderr] [INFO] [stderr] error[E0602]: unknown lint: `clippy::into_iter_on_array` [INFO] [stderr] | [INFO] [stderr] = note: requested on the command line with `-D clippy::into_iter_on_array` [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] For more information about this error, try `rustc --explain E0602`. [INFO] [stderr] error: Could not compile `unicode-xid`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] For more information about this error, try `rustc --explain E0602`. [INFO] [stderr] error: Could not compile `quote`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] For more information about this error, try `rustc --explain E0602`. [INFO] [stderr] error: Could not compile `cc`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/kipac/mod.rs:129:9 [INFO] [stderr] | [INFO] [stderr] 129 | return (a[(ln / 2)] + a[(ln / 2) - 1]) / 2.0; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `(a[(ln / 2)] + a[(ln / 2) - 1]) / 2.0` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::needless_return)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/applicators.rs:18:24 [INFO] [stderr] | [INFO] [stderr] 18 | Ast::Get(_) => return true, [INFO] [stderr] | ^^^^^^^^^^^ help: remove `return` as shown: `true` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/applicators.rs:26:5 [INFO] [stderr] | [INFO] [stderr] 26 | / return match eval(Ast::Node(nodes.clone(), fun), c) { [INFO] [stderr] 27 | | Ok(Value::Num(n)) => Ast::Leaf(n), [INFO] [stderr] 28 | | _ => Ast::Node(nodes, fun), [INFO] [stderr] 29 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 26 | match eval(Ast::Node(nodes.clone(), fun), c) { [INFO] [stderr] 27 | Ok(Value::Num(n)) => Ast::Leaf(n), [INFO] [stderr] 28 | _ => Ast::Node(nodes, fun), [INFO] [stderr] 29 | } [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/applicators.rs:35:5 [INFO] [stderr] | [INFO] [stderr] 35 | / return if fun == Fun::Mul && has_get(nodes.clone()) { [INFO] [stderr] 36 | | let a = nodes.pop()?; [INFO] [stderr] 37 | | let b = nodes.pop()?; [INFO] [stderr] 38 | | if a == Ast::Get("muk".into()) && is_get(b.clone()) || [INFO] [stderr] ... | [INFO] [stderr] 52 | | None [INFO] [stderr] 53 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 35 | if fun == Fun::Mul && has_get(nodes.clone()) { [INFO] [stderr] 36 | let a = nodes.pop()?; [INFO] [stderr] 37 | let b = nodes.pop()?; [INFO] [stderr] 38 | if a == Ast::Get("muk".into()) && is_get(b.clone()) || [INFO] [stderr] 39 | b == Ast::Get("muk".into()) && is_get(a.clone()) [INFO] [stderr] 40 | { [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/applicators.rs:64:5 [INFO] [stderr] | [INFO] [stderr] 64 | / return match t { [INFO] [stderr] 65 | | Some(n) => { [INFO] [stderr] 66 | | match n { [INFO] [stderr] 67 | | Ast::Get(s) => { [INFO] [stderr] ... | [INFO] [stderr] 78 | | } [INFO] [stderr] 79 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 64 | match t { [INFO] [stderr] 65 | Some(n) => { [INFO] [stderr] 66 | match n { [INFO] [stderr] 67 | Ast::Get(s) => { [INFO] [stderr] 68 | match c.get(s.clone()) { [INFO] [stderr] 69 | Ok(l) => l, [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/mod.rs:94:9 [INFO] [stderr] | [INFO] [stderr] 94 | / return match token { [INFO] [stderr] 95 | | Token::Abs => Fun::Abs, [INFO] [stderr] 96 | | Token::Add => Fun::Add, [INFO] [stderr] 97 | | Token::Aikainterp => Fun::Aikainterp, [INFO] [stderr] ... | [INFO] [stderr] 133 | | _ => Fun::Empty, [INFO] [stderr] 134 | | }; [INFO] [stderr] | |__________^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 94 | match token { [INFO] [stderr] 95 | Token::Abs => Fun::Abs, [INFO] [stderr] 96 | Token::Add => Fun::Add, [INFO] [stderr] 97 | Token::Aikainterp => Fun::Aikainterp, [INFO] [stderr] 98 | Token::Aikavali => Fun::Aikavali, [INFO] [stderr] 99 | Token::Arccos => Fun::Arccos, [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/parser/mod.rs:267:5 [INFO] [stderr] | [INFO] [stderr] 267 | return Ok(node.pop().unwrap()); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove `return` as shown: `Ok(node.pop().unwrap())` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/mod.rs:68:5 [INFO] [stderr] | [INFO] [stderr] 68 | / return match eval(parsed, c) { [INFO] [stderr] 69 | | Ok(p) => { [INFO] [stderr] 70 | | match p { [INFO] [stderr] 71 | | Value::Num(n) => Ok(n), [INFO] [stderr] ... | [INFO] [stderr] 75 | | Err(p) => Err(p), [INFO] [stderr] 76 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 68 | match eval(parsed, c) { [INFO] [stderr] 69 | Ok(p) => { [INFO] [stderr] 70 | match p { [INFO] [stderr] 71 | Value::Num(n) => Ok(n), [INFO] [stderr] 72 | Value::Vec(n) => Err(format!("Got Vector instead of number: {:#?}", n)), [INFO] [stderr] 73 | } [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/mod.rs:82:5 [INFO] [stderr] | [INFO] [stderr] 82 | / return match eval(parsed, self::ctx::EmptyCtx).ok().unwrap() { [INFO] [stderr] 83 | | Value::Num(n) => n, [INFO] [stderr] 84 | | Value::Vec(n) => panic!("Got Vector instead of number: {:#?}", n), [INFO] [stderr] 85 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 82 | match eval(parsed, self::ctx::EmptyCtx).ok().unwrap() { [INFO] [stderr] 83 | Value::Num(n) => n, [INFO] [stderr] 84 | Value::Vec(n) => panic!("Got Vector instead of number: {:#?}", n), [INFO] [stderr] 85 | } [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unneeded return statement [INFO] [stderr] --> src/calc/mod.rs:93:5 [INFO] [stderr] | [INFO] [stderr] 93 | / return match ast { [INFO] [stderr] 94 | | Ast::Empty => panic!("Met empty abstract syntax tree node {:?}", ast), [INFO] [stderr] 95 | | Ast::Leaf(num) => value!(Num, num), [INFO] [stderr] 96 | | Ast::Node(vec, fun) => { [INFO] [stderr] ... | [INFO] [stderr] 157 | | }, [INFO] [stderr] 158 | | }; [INFO] [stderr] | |______^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stderr] help: remove `return` as shown [INFO] [stderr] | [INFO] [stderr] 93 | match ast { [INFO] [stderr] 94 | Ast::Empty => panic!("Met empty abstract syntax tree node {:?}", ast), [INFO] [stderr] 95 | Ast::Leaf(num) => value!(Num, num), [INFO] [stderr] 96 | Ast::Node(vec, fun) => { [INFO] [stderr] 97 | let mut res: Vec = Vec::new(); [INFO] [stderr] 98 | for i in vec { [INFO] [stderr] ... [INFO] [stderr] [INFO] [stderr] error: aborting due to previous error [INFO] [stderr] [INFO] [stderr] For more information about this error, try `rustc --explain E0602`. [INFO] [stderr] error: Could not compile `pest`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: equal expressions as operands to `/` [INFO] [stderr] --> src/kipac/mod.rs:108:28 [INFO] [stderr] | [INFO] [stderr] 108 | x.iter().cloned().fold(0. / 0., f64::min) [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[deny(clippy::eq_op)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#eq_op [INFO] [stderr] [INFO] [stderr] warning: constant division of 0.0 with 0.0 will always result in NaN [INFO] [stderr] --> src/kipac/mod.rs:108:28 [INFO] [stderr] | [INFO] [stderr] 108 | x.iter().cloned().fold(0. / 0., f64::min) [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::zero_divided_by_zero)] on by default [INFO] [stderr] = help: Consider using `std::f64::NAN` if you would like a constant representing NaN [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#zero_divided_by_zero [INFO] [stderr] [INFO] [stderr] error: equal expressions as operands to `/` [INFO] [stderr] --> src/kipac/mod.rs:112:28 [INFO] [stderr] | [INFO] [stderr] 112 | x.iter().cloned().fold(0. / 0., f64::max) [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#eq_op [INFO] [stderr] [INFO] [stderr] warning: constant division of 0.0 with 0.0 will always result in NaN [INFO] [stderr] --> src/kipac/mod.rs:112:28 [INFO] [stderr] | [INFO] [stderr] 112 | x.iter().cloned().fold(0. / 0., f64::max) [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = help: Consider using `std::f64::NAN` if you would like a constant representing NaN [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#zero_divided_by_zero [INFO] [stderr] [INFO] [stderr] warning: you seem to be trying to use match for destructuring a single pattern. Consider using `if let` [INFO] [stderr] --> src/calc/parser/applicators.rs:8:9 [INFO] [stderr] | [INFO] [stderr] 8 | / match t { [INFO] [stderr] 9 | | Ast::Get(_) => return true, [INFO] [stderr] 10 | | _ => (), [INFO] [stderr] 11 | | } [INFO] [stderr] | |_________^ help: try this: `if let Ast::Get(_) = t { return true }` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::single_match)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stderr] [INFO] [stderr] warning: the function has a cyclomatic complexity of 41 [INFO] [stderr] --> src/calc/parser/mod.rs:93:5 [INFO] [stderr] | [INFO] [stderr] 93 | / fn from(token: Token) -> Self { [INFO] [stderr] 94 | | return match token { [INFO] [stderr] 95 | | Token::Abs => Fun::Abs, [INFO] [stderr] 96 | | Token::Add => Fun::Add, [INFO] [stderr] ... | [INFO] [stderr] 134 | | }; [INFO] [stderr] 135 | | } [INFO] [stderr] | |_____^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::cyclomatic_complexity)] on by default [INFO] [stderr] = help: you could split it up into multiple smaller functions [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cyclomatic_complexity [INFO] [stderr] [INFO] [stderr] warning: this loop could be written as a `for` loop [INFO] [stderr] --> src/calc/parser/mod.rs:157:25 [INFO] [stderr] | [INFO] [stderr] 157 | while let Some(t) = iter.next() { [INFO] [stderr] | ^^^^^^^^^^^ help: try: `for t in iter { .. }` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::while_let_on_iterator)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#while_let_on_iterator [INFO] [stderr] [INFO] [stderr] warning: useless use of `format!` [INFO] [stderr] --> src/calc/parser/mod.rs:161:40 [INFO] [stderr] | [INFO] [stderr] 161 | Token::Empty => return Err(format!("Got empty")), [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ help: consider using .to_string(): `"Got empty".to_string()` [INFO] [stderr] | [INFO] [stderr] = note: #[warn(clippy::useless_format)] on by default [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_format [INFO] [stderr] [INFO] [stderr] warning: useless use of `format!` [INFO] [stderr] --> src/calc/parser/mod.rs:219:53 [INFO] [stderr] | [INFO] [stderr] 219 | _ => return Err(format!("Shouldn't happen. Unary operator")), [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider using .to_string(): `"Shouldn't happen. Unary operator".to_string()` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_format [INFO] [stderr] [INFO] [stderr] warning: useless use of `format!` [INFO] [stderr] --> src/calc/parser/mod.rs:228:45 [INFO] [stderr] | [INFO] [stderr] 228 | _ => return Err(format!("Shouldn't happen. Unary operator")), [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider using .to_string(): `"Shouldn't happen. Unary operator".to_string()` [INFO] [stderr] | [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_format [INFO] [stderr] [INFO] [stderr] warning: the function has a cyclomatic complexity of 51 [INFO] [stderr] --> src/calc/mod.rs:92:1 [INFO] [stderr] | [INFO] [stderr] 92 | / pub fn eval(ast: Ast, c: C) -> Result { [INFO] [stderr] 93 | | return match ast { [INFO] [stderr] 94 | | Ast::Empty => panic!("Met empty abstract syntax tree node {:?}", ast), [INFO] [stderr] 95 | | Ast::Leaf(num) => value!(Num, num), [INFO] [stderr] ... | [INFO] [stderr] 158 | | }; [INFO] [stderr] 159 | | } [INFO] [stderr] | |_^ [INFO] [stderr] | [INFO] [stderr] = help: you could split it up into multiple smaller functions [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#cyclomatic_complexity [INFO] [stderr] [INFO] [stderr] error: strict comparison of f32 or f64 [INFO] [stderr] --> src/calc/mod.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | Fun::Eq => value!(Num, cond!(res[0] == res[1])), [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: consider comparing them within some error: `(res[0] - res[1]).abs() < error` [INFO] [stderr] | [INFO] [stderr] = note: #[deny(clippy::float_cmp)] on by default [INFO] [stderr] note: std::f32::EPSILON and std::f64::EPSILON are available. [INFO] [stderr] --> src/calc/mod.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | Fun::Eq => value!(Num, cond!(res[0] == res[1])), [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#float_cmp [INFO] [stderr] [INFO] [stderr] error: strict comparison of f32 or f64 [INFO] [stderr] --> src/calc/mod.rs:139:47 [INFO] [stderr] | [INFO] [stderr] 139 | Fun::Neq => value!(Num, cond!(res[0] != res[1])), [INFO] [stderr] | ^^^^^^^^^^^^^^^^ help: consider comparing them within some error: `(res[0] - res[1]).abs() < error` [INFO] [stderr] | [INFO] [stderr] note: std::f32::EPSILON and std::f64::EPSILON are available. [INFO] [stderr] --> src/calc/mod.rs:139:47 [INFO] [stderr] | [INFO] [stderr] 139 | Fun::Neq => value!(Num, cond!(res[0] != res[1])), [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#float_cmp [INFO] [stderr] [INFO] [stderr] error: aborting due to 4 previous errors [INFO] [stderr] [INFO] [stderr] error: Could not compile `kilac`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "e63a9d966cc8184eb9517f5004db8159fc2fa6df8ca149306bfb014cc013c16c"` [INFO] running `"docker" "rm" "-f" "e63a9d966cc8184eb9517f5004db8159fc2fa6df8ca149306bfb014cc013c16c"` [INFO] [stdout] e63a9d966cc8184eb9517f5004db8159fc2fa6df8ca149306bfb014cc013c16c