[INFO] cloning repository https://github.com/sidharthsunilkumar/ocpt [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/sidharthsunilkumar/ocpt" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 671b20062db0ebe4393e40caf01b7ed1186e034e [INFO] checking sidharthsunilkumar/ocpt against try#5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db for pr-143717 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/sidharthsunilkumar/ocpt [INFO] finished tweaking git repo https://github.com/sidharthsunilkumar/ocpt [INFO] tweaked toml for git repo https://github.com/sidharthsunilkumar/ocpt written to /workspace/builds/worker-1-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/sidharthsunilkumar/ocpt on toolchain 5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/sidharthsunilkumar/ocpt 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" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded rayon-cond v0.3.0 [INFO] [stderr] Downloaded priority-queue v1.4.0 [INFO] [stderr] Downloaded hyper-util v0.1.12 [INFO] [stderr] Downloaded rustworkx-core v0.14.2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e [INFO] running `Command { std: "docker" "start" "-a" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }` [INFO] [stdout] 0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f [INFO] running `Command { std: "docker" "start" "-a" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }` [INFO] [stderr] Checking pin-project-lite v0.2.16 [INFO] [stderr] Checking futures-core v0.3.31 [INFO] [stderr] Checking either v1.15.0 [INFO] [stderr] Checking http v1.3.1 [INFO] [stderr] Compiling syn v2.0.101 [INFO] [stderr] Checking smallvec v1.15.0 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Checking futures-task v0.3.31 [INFO] [stderr] Checking pin-utils v0.1.0 [INFO] [stderr] Checking mio v1.0.4 [INFO] [stderr] Checking socket2 v0.5.9 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Checking parking_lot_core v0.9.10 [INFO] [stderr] Checking rayon v1.10.0 [INFO] [stderr] Checking signal-hook-registry v1.4.5 [INFO] [stderr] Checking log v0.4.27 [INFO] [stderr] Compiling httparse v1.10.1 [INFO] [stderr] Checking tower-service v0.3.3 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Compiling ahash v0.8.12 [INFO] [stderr] Checking parking_lot v0.12.3 [INFO] [stderr] Checking tracing-core v0.1.33 [INFO] [stderr] Compiling indexmap v1.9.3 [INFO] [stderr] Compiling rustversion v1.0.21 [INFO] [stderr] Checking tower-layer v0.3.3 [INFO] [stderr] Checking tracing v0.1.41 [INFO] [stderr] Checking futures-channel v0.3.31 [INFO] [stderr] Compiling priority-queue v1.4.0 [INFO] [stderr] Checking sync_wrapper v1.0.2 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling num-conv v0.1.0 [INFO] [stderr] Checking hashbrown v0.12.3 [INFO] [stderr] Checking httpdate v1.0.3 [INFO] [stderr] Checking powerfmt v0.2.0 [INFO] [stderr] Compiling time-core v0.1.4 [INFO] [stderr] Checking http-body v1.0.1 [INFO] [stderr] Checking http-body-util v0.1.3 [INFO] [stderr] Checking hashbrown v0.15.3 [INFO] [stderr] Checking form_urlencoded v1.2.1 [INFO] [stderr] Compiling time-macros v0.2.22 [INFO] [stderr] Checking deranged v0.4.0 [INFO] [stderr] Checking itertools v0.11.0 [INFO] [stderr] Checking mime v0.3.17 [INFO] [stderr] Checking num_threads v0.1.7 [INFO] [stderr] Checking indexmap v2.9.0 [INFO] [stderr] Checking fixedbitset v0.4.2 [INFO] [stderr] Checking hashbrown v0.14.5 [INFO] [stderr] Checking rand_pcg v0.3.1 [INFO] [stderr] Checking matchit v0.7.3 [INFO] [stderr] Checking bitflags v2.9.1 [INFO] [stderr] Checking termcolor v1.4.1 [INFO] [stderr] Checking chrono v0.4.41 [INFO] [stderr] Checking tower-http v0.5.2 [INFO] [stderr] Checking itertools v0.14.0 [INFO] [stderr] Checking petgraph v0.6.5 [INFO] [stderr] Checking time v0.3.41 [INFO] [stderr] Checking rayon-cond v0.3.0 [INFO] [stderr] Checking simplelog v0.12.2 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Checking rustworkx-core v0.14.2 [INFO] [stderr] Checking tokio v1.45.1 [INFO] [stderr] Checking axum-core v0.4.5 [INFO] [stderr] Checking serde_path_to_error v0.1.17 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking hyper v1.6.0 [INFO] [stderr] Checking tower v0.5.2 [INFO] [stderr] Checking hyper-util v0.1.12 [INFO] [stderr] Checking axum v0.7.9 [INFO] [stderr] Checking dfg_visualizer v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::env` [INFO] [stdout] --> src/main.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::env; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Event` and `Object` [INFO] [stdout] --> src/main.rs:8:30 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::types::{OcelJson, Event, Object, ProcessForest, TreeNode}; [INFO] [stdout] | ^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> src/build_relations_fns.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HashSet` [INFO] [stdout] --> src/build_relations_fns.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HashSet` [INFO] [stdout] --> src/types.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::NaiveDateTime` [INFO] [stdout] --> src/divergence_free_dfg.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::NaiveDateTime; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/divergence_free_dfg.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::BufReader` [INFO] [stdout] --> src/divergence_free_dfg.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::io::BufReader; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/divergence_free_dfg.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_redo_cuts::best_redo_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::best_redo_cuts::best_redo_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::good_cuts::best_possible_sequence_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::good_cuts::best_possible_sequence_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_exclusive_cut::best_exclusive_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use crate::best_exclusive_cut::best_exclusive_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ProcessForest` and `TreeNode` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:10:20 [INFO] [stdout] | [INFO] [stdout] 10 | use crate::types::{ProcessForest, TreeNode}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_sequence_cut_v2` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::best_sequence_cut_v2; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:39:7 [INFO] [stdout] | [INFO] [stdout] 39 | if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 39 - if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) { [INFO] [stdout] 39 + if !excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:47:7 [INFO] [stdout] | [INFO] [stdout] 47 | if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 47 - if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) { [INFO] [stdout] 47 + if !set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:57:7 [INFO] [stdout] | [INFO] [stdout] 57 | if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 57 - if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities)) { [INFO] [stdout] 57 + if is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:65:8 [INFO] [stdout] | [INFO] [stdout] 65 | ...if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 65 - if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) { [INFO] [stdout] 65 + if is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:86:7 [INFO] [stdout] | [INFO] [stdout] 86 | if(!is_sequence) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 86 - if(!is_sequence) { [INFO] [stdout] 86 + if !is_sequence { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:261:16 [INFO] [stdout] | [INFO] [stdout] 261 | if (r1 || r2) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 261 - if (r1 || r2) { [INFO] [stdout] 261 + if r1 || r2 { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:587:19 [INFO] [stdout] | [INFO] [stdout] 587 | } else if (!is_s1_redo && is_s2_redo) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 587 - } else if (!is_s1_redo && is_s2_redo) { [INFO] [stdout] 587 + } else if !is_s1_redo && is_s2_redo { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/format_conversion.rs:2:18 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::{json, Value}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/cost_to_cut.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cmp::min` [INFO] [stdout] --> src/cost_to_cut.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::cmp::min; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/cost_to_add.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/cost_to_add.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BTreeMap` [INFO] [stdout] --> src/good_cuts.rs:2:52 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet, VecDeque, BTreeMap}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::graphmap::DiGraphMap` [INFO] [stdout] --> src/good_cuts.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use petgraph::graphmap::DiGraphMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Graph` and `NodeIndex` [INFO] [stdout] --> src/good_cuts.rs:6:23 [INFO] [stdout] | [INFO] [stdout] 6 | use petgraph::graph::{Graph, NodeIndex}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::algo::ford_fulkerson` [INFO] [stdout] --> src/good_cuts.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use petgraph::algo::ford_fulkerson; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::visit::EdgeRef` [INFO] [stdout] --> src/good_cuts.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use petgraph::visit::EdgeRef; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::Direction` [INFO] [stdout] --> src/good_cuts.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use petgraph::Direction; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_sequence_cut.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_exclusive_cut.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_parallel_cut.rs:217:23 [INFO] [stdout] | [INFO] [stdout] 217 | } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 217 - } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) { [INFO] [stdout] 217 + } else if new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len()) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ptr::null` [INFO] [stdout] --> src/best_redo_cuts.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ptr::null; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/best_redo_cuts.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_redo_cuts.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_redo_cuts.rs:77:19 [INFO] [stdout] | [INFO] [stdout] 77 | } else if (!btw_start_and_end && btw_end_and_start) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 77 - } else if (!btw_start_and_end && btw_end_and_start) { [INFO] [stdout] 77 + } else if !btw_start_and_end && btw_end_and_start { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_redo_cuts.rs:79:18 [INFO] [stdout] | [INFO] [stdout] 79 | } else if(btw_start_and_end && btw_end_and_start) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 79 - } else if(btw_start_and_end && btw_end_and_start) { [INFO] [stdout] 79 + } else if btw_start_and_end && btw_end_and_start { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `response::Html` [INFO] [stdout] --> src/main.rs:37:34 [INFO] [stdout] | [INFO] [stdout] 37 | use axum::{Router, routing::get, response::Html}; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> src/main.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::env` [INFO] [stdout] --> src/main.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use std::env; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::Write` [INFO] [stdout] --> src/main.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::io::Write; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Event` and `Object` [INFO] [stdout] --> src/main.rs:8:30 [INFO] [stdout] | [INFO] [stdout] 8 | use crate::types::{OcelJson, Event, Object, ProcessForest, TreeNode}; [INFO] [stdout] | ^^^^^ ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde::Deserialize` [INFO] [stdout] --> src/build_relations_fns.rs:1:5 [INFO] [stdout] | [INFO] [stdout] 1 | use serde::Deserialize; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HashSet` [INFO] [stdout] --> src/build_relations_fns.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `HashSet` [INFO] [stdout] --> src/types.rs:2:33 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet}; [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `chrono::NaiveDateTime` [INFO] [stdout] --> src/divergence_free_dfg.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use chrono::NaiveDateTime; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `DateTime` and `Utc` [INFO] [stdout] --> src/divergence_free_dfg.rs:3:14 [INFO] [stdout] | [INFO] [stdout] 3 | use chrono::{DateTime, Utc}; [INFO] [stdout] | ^^^^^^^^ ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::io::BufReader` [INFO] [stdout] --> src/divergence_free_dfg.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use std::io::BufReader; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `serde_json::Value` [INFO] [stdout] --> src/divergence_free_dfg.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use serde_json::Value; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_redo_cuts::best_redo_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use crate::best_redo_cuts::best_redo_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::good_cuts::best_possible_sequence_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use crate::good_cuts::best_possible_sequence_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_exclusive_cut::best_exclusive_cut` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use crate::best_exclusive_cut::best_exclusive_cut; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ProcessForest` and `TreeNode` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:10:20 [INFO] [stdout] | [INFO] [stdout] 10 | use crate::types::{ProcessForest, TreeNode}; [INFO] [stdout] | ^^^^^^^^^^^^^ ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::best_sequence_cut_v2` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:14:5 [INFO] [stdout] | [INFO] [stdout] 14 | use crate::best_sequence_cut_v2; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:39:7 [INFO] [stdout] | [INFO] [stdout] 39 | if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_parens)]` on by default [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 39 - if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) { [INFO] [stdout] 39 + if !excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:47:7 [INFO] [stdout] | [INFO] [stdout] 47 | if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 47 - if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) { [INFO] [stdout] 47 + if !set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:57:7 [INFO] [stdout] | [INFO] [stdout] 57 | if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 57 - if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities)) { [INFO] [stdout] 57 + if is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(¶_set1, ¶_set2, &start_activities, &end_activities) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:65:8 [INFO] [stdout] | [INFO] [stdout] 65 | ...if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 65 - if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) { [INFO] [stdout] 65 + if is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:86:7 [INFO] [stdout] | [INFO] [stdout] 86 | if(!is_sequence) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 86 - if(!is_sequence) { [INFO] [stdout] 86 + if !is_sequence { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:261:16 [INFO] [stdout] | [INFO] [stdout] 261 | if (r1 || r2) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 261 - if (r1 || r2) { [INFO] [stdout] 261 + if r1 || r2 { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/start_cuts_opti_v2.rs:587:19 [INFO] [stdout] | [INFO] [stdout] 587 | } else if (!is_s1_redo && is_s2_redo) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 587 - } else if (!is_s1_redo && is_s2_redo) { [INFO] [stdout] 587 + } else if !is_s1_redo && is_s2_redo { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `json` [INFO] [stdout] --> src/format_conversion.rs:2:18 [INFO] [stdout] | [INFO] [stdout] 2 | use serde_json::{json, Value}; [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/cost_to_cut.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::cmp::min` [INFO] [stdout] --> src/cost_to_cut.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::cmp::min; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `VecDeque` [INFO] [stdout] --> src/cost_to_add.rs:1:42 [INFO] [stdout] | [INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/cost_to_add.rs:3:5 [INFO] [stdout] | [INFO] [stdout] 3 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `BTreeMap` [INFO] [stdout] --> src/good_cuts.rs:2:52 [INFO] [stdout] | [INFO] [stdout] 2 | use std::collections::{HashMap, HashSet, VecDeque, BTreeMap}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::graphmap::DiGraphMap` [INFO] [stdout] --> src/good_cuts.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use petgraph::graphmap::DiGraphMap; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Graph` and `NodeIndex` [INFO] [stdout] --> src/good_cuts.rs:6:23 [INFO] [stdout] | [INFO] [stdout] 6 | use petgraph::graph::{Graph, NodeIndex}; [INFO] [stdout] | ^^^^^ ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::algo::ford_fulkerson` [INFO] [stdout] --> src/good_cuts.rs:7:5 [INFO] [stdout] | [INFO] [stdout] 7 | use petgraph::algo::ford_fulkerson; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::visit::EdgeRef` [INFO] [stdout] --> src/good_cuts.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | use petgraph::visit::EdgeRef; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `petgraph::Direction` [INFO] [stdout] --> src/good_cuts.rs:9:5 [INFO] [stdout] | [INFO] [stdout] 9 | use petgraph::Direction; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_sequence_cut.rs:5:5 [INFO] [stdout] | [INFO] [stdout] 5 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_exclusive_cut.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_parallel_cut.rs:217:23 [INFO] [stdout] | [INFO] [stdout] 217 | } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 217 - } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) { [INFO] [stdout] 217 + } else if new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len()) { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `std::ptr::null` [INFO] [stdout] --> src/best_redo_cuts.rs:2:5 [INFO] [stdout] | [INFO] [stdout] 2 | use std::ptr::null; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable` [INFO] [stdout] --> src/best_redo_cuts.rs:4:5 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `log::info` [INFO] [stdout] --> src/best_redo_cuts.rs:6:5 [INFO] [stdout] | [INFO] [stdout] 6 | use log::info; [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_redo_cuts.rs:77:19 [INFO] [stdout] | [INFO] [stdout] 77 | } else if (!btw_start_and_end && btw_end_and_start) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 77 - } else if (!btw_start_and_end && btw_end_and_start) { [INFO] [stdout] 77 + } else if !btw_start_and_end && btw_end_and_start { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary parentheses around `if` condition [INFO] [stdout] --> src/best_redo_cuts.rs:79:18 [INFO] [stdout] | [INFO] [stdout] 79 | } else if(btw_start_and_end && btw_end_and_start) { [INFO] [stdout] | ^ ^ [INFO] [stdout] | [INFO] [stdout] help: remove these parentheses [INFO] [stdout] | [INFO] [stdout] 79 - } else if(btw_start_and_end && btw_end_and_start) { [INFO] [stdout] 79 + } else if btw_start_and_end && btw_end_and_start { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `response::Html` [INFO] [stdout] --> src/main.rs:37:34 [INFO] [stdout] | [INFO] [stdout] 37 | use axum::{Router, routing::get, response::Html}; [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `itertools::Itertools` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use itertools::Itertools; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ocel` [INFO] [stdout] --> src/interaction_patterns.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | ocel: &OcelJson, [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_ocel` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `next_otype` [INFO] [stdout] --> src/divergence_free_dfg.rs:82:17 [INFO] [stdout] | [INFO] [stdout] 82 | let next_otype = &next_relation.4; [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_otype` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | filtered_dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `itertools::Itertools` [INFO] [stdout] --> src/start_cuts_opti_v2.rs:11:5 [INFO] [stdout] | [INFO] [stdout] 11 | use itertools::Itertools; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `idx` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:285:10 [INFO] [stdout] | [INFO] [stdout] 285 | for (idx, candidate_scc) in sccs.iter().enumerate() { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_idx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:666:17 [INFO] [stdout] | [INFO] [stdout] 666 | let filtered_dfg = filter_keep_dfg(&dfg, &combined_activites); [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_start_activites` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:668:18 [INFO] [stdout] | [INFO] [stdout] 668 | ... let (filtered_start_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_start_activites` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_end_activites` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:668:43 [INFO] [stdout] | [INFO] [stdout] 668 | ...rt_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, end_activities); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_end_activites` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:637:5 [INFO] [stdout] | [INFO] [stdout] 637 | filtered_dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `ocel` [INFO] [stdout] --> src/interaction_patterns.rs:18:5 [INFO] [stdout] | [INFO] [stdout] 18 | ocel: &OcelJson, [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_ocel` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `next_otype` [INFO] [stdout] --> src/divergence_free_dfg.rs:82:17 [INFO] [stdout] | [INFO] [stdout] 82 | let next_otype = &next_relation.4; [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_otype` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | filtered_dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/start_cuts_opti_v2.rs:422:9 [INFO] [stdout] | [INFO] [stdout] 422 | let mut common_activities = intersection.clone(); [INFO] [stdout] | ----^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `idx` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:285:10 [INFO] [stdout] | [INFO] [stdout] 285 | for (idx, candidate_scc) in sccs.iter().enumerate() { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_idx` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:666:17 [INFO] [stdout] | [INFO] [stdout] 666 | let filtered_dfg = filter_keep_dfg(&dfg, &combined_activites); [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `flow` is assigned to, but never used [INFO] [stdout] --> src/cost_to_cut.rs:95:13 [INFO] [stdout] | [INFO] [stdout] 95 | let mut flow = 0; [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_flow` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_start_activites` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:668:18 [INFO] [stdout] | [INFO] [stdout] 668 | ... let (filtered_start_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, ... [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_start_activites` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_end_activites` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:668:43 [INFO] [stdout] | [INFO] [stdout] 668 | ...rt_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, end_activities); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_end_activites` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `filtered_dfg` [INFO] [stdout] --> src/start_cuts_opti_v1.rs:637:5 [INFO] [stdout] | [INFO] [stdout] 637 | filtered_dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `dfg` [INFO] [stdout] --> src/cost_to_cut.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 218 | dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/start_cuts_opti_v2.rs:422:9 [INFO] [stdout] | [INFO] [stdout] 422 | let mut common_activities = intersection.clone(); [INFO] [stdout] | ----^^^^^^^^^^^^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_mut)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `max_flow_value` [INFO] [stdout] --> src/best_exclusive_cut.rs:191:17 [INFO] [stdout] | [INFO] [stdout] 191 | let max_flow_value = graph.max_flow(&source, &sink); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_flow_value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `flow` is assigned to, but never used [INFO] [stdout] --> src/cost_to_cut.rs:95:13 [INFO] [stdout] | [INFO] [stdout] 95 | let mut flow = 0; [INFO] [stdout] | ^^^^ [INFO] [stdout] | [INFO] [stdout] = note: consider using `_flow` instead [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `from` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:11 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `to` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:17 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_to` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cap` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:22 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_cap` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `from` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:11 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `to` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:17 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_to` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `flow` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:22 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_flow` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `dfg` [INFO] [stdout] --> src/cost_to_cut.rs:218:5 [INFO] [stdout] | [INFO] [stdout] 218 | dfg: &HashMap<(String, String), usize>, [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_dfg` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `max_flow_value` [INFO] [stdout] --> src/best_exclusive_cut.rs:191:17 [INFO] [stdout] | [INFO] [stdout] 191 | let max_flow_value = graph.max_flow(&source, &sink); [INFO] [stdout] | ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_flow_value` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `from` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:11 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `to` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:17 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_to` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `cap` [INFO] [stdout] --> src/best_exclusive_cut.rs:297:22 [INFO] [stdout] | [INFO] [stdout] 297 | for ((from, to), cap) in &graph.capacity { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_cap` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `from` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:11 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_from` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `to` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:17 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_to` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `flow` [INFO] [stdout] --> src/best_exclusive_cut.rs:301:22 [INFO] [stdout] | [INFO] [stdout] 301 | for ((from, to), flow) in &graph.flow { [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_flow` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `con` [INFO] [stdout] --> src/main.rs:96:15 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_con` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rel` [INFO] [stdout] --> src/main.rs:96:20 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_rel` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `defi` [INFO] [stdout] --> src/main.rs:96:25 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_defi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `all_object_types` [INFO] [stdout] --> src/main.rs:96:47 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_all_object_types` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `start_acts` [INFO] [stdout] --> src/main.rs:108:15 [INFO] [stdout] | [INFO] [stdout] 108 | let (dfg, start_acts, end_acts) = [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_acts` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `end_acts` [INFO] [stdout] --> src/main.rs:108:27 [INFO] [stdout] | [INFO] [stdout] 108 | let (dfg, start_acts, end_acts) = [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_acts` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `con` [INFO] [stdout] --> src/main.rs:96:15 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_con` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `rel` [INFO] [stdout] --> src/main.rs:96:20 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_rel` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `defi` [INFO] [stdout] --> src/main.rs:96:25 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^^ help: if this is intentional, prefix it with an underscore: `_defi` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `all_object_types` [INFO] [stdout] --> src/main.rs:96:47 [INFO] [stdout] | [INFO] [stdout] 96 | let (div, con, rel, defi, all_activities, all_object_types) = [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_all_object_types` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `start_acts` [INFO] [stdout] --> src/main.rs:108:15 [INFO] [stdout] | [INFO] [stdout] 108 | let (dfg, start_acts, end_acts) = [INFO] [stdout] | ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_acts` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `end_acts` [INFO] [stdout] --> src/main.rs:108:27 [INFO] [stdout] | [INFO] [stdout] 108 | let (dfg, start_acts, end_acts) = [INFO] [stdout] | ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_acts` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `hello` is never used [INFO] [stdout] --> src/main.rs:44:10 [INFO] [stdout] | [INFO] [stdout] 44 | async fn hello() -> Json { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main1` is never used [INFO] [stdout] --> src/main.rs:56:10 [INFO] [stdout] | [INFO] [stdout] 56 | async fn main1() { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `log_sorted_map` is never used [INFO] [stdout] --> src/main.rs:162:4 [INFO] [stdout] | [INFO] [stdout] 162 | fn log_sorted_map( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_process_tree` is never used [INFO] [stdout] --> src/main.rs:189:4 [INFO] [stdout] | [INFO] [stdout] 189 | fn print_process_tree(tree: &TreeNode, depth: usize) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_process_forest` is never used [INFO] [stdout] --> src/main.rs:197:4 [INFO] [stdout] | [INFO] [stdout] 197 | fn print_process_forest(forest: &ProcessForest) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_from_dfg` is never used [INFO] [stdout] --> src/main.rs:226:4 [INFO] [stdout] | [INFO] [stdout] 226 | fn get_start_and_end_activities_from_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `mainkoi` is never used [INFO] [stdout] --> src/main.rs:251:4 [INFO] [stdout] | [INFO] [stdout] 251 | fn mainkoi() { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `global_log` is never read [INFO] [stdout] --> src/types.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct OcelJson { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 7 | #[serde(rename = "ocel:global-log")] [INFO] [stdout] 8 | pub global_log: serde_json::Value, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `OcelJson` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `TreeNode` is never constructed [INFO] [stdout] --> src/types.rs:33:12 [INFO] [stdout] | [INFO] [stdout] 33 | pub struct TreeNode { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `ProcessForest` is never used [INFO] [stdout] --> src/types.rs:38:10 [INFO] [stdout] | [INFO] [stdout] 38 | pub type ProcessForest = Vec; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Node` is never constructed [INFO] [stdout] --> src/types.rs:43:12 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct Node { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Edge` is never constructed [INFO] [stdout] --> src/types.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | pub struct Edge { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/types.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 57 | pub struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts` is never used [INFO] [stdout] --> src/start_cuts.rs:6:8 [INFO] [stdout] | [INFO] [stdout] 6 | pub fn find_cuts( [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/start_cuts.rs:109:4 [INFO] [stdout] | [INFO] [stdout] 109 | fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts.rs:135:4 [INFO] [stdout] | [INFO] [stdout] 135 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_sequence_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:148:8 [INFO] [stdout] | [INFO] [stdout] 148 | pub fn is_sequence_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:175:8 [INFO] [stdout] | [INFO] [stdout] 175 | pub fn is_exclusive_choice_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_parallel_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:190:4 [INFO] [stdout] | [INFO] [stdout] 190 | fn is_parallel_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_redo_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:233:4 [INFO] [stdout] | [INFO] [stdout] 233 | fn is_redo_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts.rs:329:4 [INFO] [stdout] | [INFO] [stdout] 329 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used [INFO] [stdout] --> src/start_cuts.rs:359:4 [INFO] [stdout] | [INFO] [stdout] 359 | fn get_start_and_end_activities_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:8:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub fn strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_scc_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:102:8 [INFO] [stdout] | [INFO] [stdout] 102 | pub fn build_scc_dag( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `partition_scc_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:126:8 [INFO] [stdout] | [INFO] [stdout] 126 | pub fn partition_scc_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:165:8 [INFO] [stdout] | [INFO] [stdout] 165 | pub fn print_strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_sequence_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:265:8 [INFO] [stdout] | [INFO] [stdout] 265 | pub fn find_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_subgraph` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:344:4 [INFO] [stdout] | [INFO] [stdout] 344 | fn build_subgraph( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:360:4 [INFO] [stdout] | [INFO] [stdout] 360 | fn dfs(node: &String, graph: &HashMap>, visited: &mut HashSet) { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `compute_sccs` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:374:4 [INFO] [stdout] | [INFO] [stdout] 374 | fn compute_sccs( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs_postorder` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:403:4 [INFO] [stdout] | [INFO] [stdout] 403 | fn dfs_postorder( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs_collect` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:421:4 [INFO] [stdout] | [INFO] [stdout] 421 | fn dfs_collect( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts_start` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:440:8 [INFO] [stdout] | [INFO] [stdout] 440 | pub fn find_cuts_start( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_best_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:598:4 [INFO] [stdout] | [INFO] [stdout] 598 | fn find_best_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:635:8 [INFO] [stdout] | [INFO] [stdout] 635 | pub fn find_cuts( [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:738:4 [INFO] [stdout] | [INFO] [stdout] 738 | fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:764:4 [INFO] [stdout] | [INFO] [stdout] 764 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_sequence_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:777:4 [INFO] [stdout] | [INFO] [stdout] 777 | fn is_sequence_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:804:4 [INFO] [stdout] | [INFO] [stdout] 804 | fn is_exclusive_choice_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_parallel_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:819:4 [INFO] [stdout] | [INFO] [stdout] 819 | fn is_parallel_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_redo_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:862:4 [INFO] [stdout] | [INFO] [stdout] 862 | fn is_redo_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:958:4 [INFO] [stdout] | [INFO] [stdout] 958 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:988:4 [INFO] [stdout] | [INFO] [stdout] 988 | fn get_start_and_end_activities_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts_start` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:19:8 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn find_cuts_start( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_exclusive_choice_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:187:4 [INFO] [stdout] | [INFO] [stdout] 187 | fn find_exclusive_choice_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `exclusive_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:251:4 [INFO] [stdout] | [INFO] [stdout] 251 | fn exclusive_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_sequence_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:270:4 [INFO] [stdout] | [INFO] [stdout] 270 | fn find_sequence_cut(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:295:4 [INFO] [stdout] | [INFO] [stdout] 295 | fn strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_scc_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:382:8 [INFO] [stdout] | [INFO] [stdout] 382 | pub fn build_scc_dag( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `partition_scc_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:406:8 [INFO] [stdout] | [INFO] [stdout] 406 | pub fn partition_scc_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable_in_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:467:8 [INFO] [stdout] | [INFO] [stdout] 467 | pub fn is_reachable_in_dag( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `sequence_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:490:4 [INFO] [stdout] | [INFO] [stdout] 490 | fn sequence_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_parallel_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:510:4 [INFO] [stdout] | [INFO] [stdout] 510 | fn find_parallel_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parallel_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:549:4 [INFO] [stdout] | [INFO] [stdout] 549 | fn parallel_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_redo_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:564:4 [INFO] [stdout] | [INFO] [stdout] 564 | fn find_redo_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `redo_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:597:4 [INFO] [stdout] | [INFO] [stdout] 597 | fn redo_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:676:4 [INFO] [stdout] | [INFO] [stdout] 676 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `check_bi_direction_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:688:4 [INFO] [stdout] | [INFO] [stdout] 688 | fn check_bi_direction_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:703:4 [INFO] [stdout] | [INFO] [stdout] 703 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable_before_end_activity` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:740:8 [INFO] [stdout] | [INFO] [stdout] 740 | pub fn is_reachable_before_end_activity( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfg_to_json` is never used [INFO] [stdout] --> src/format_conversion.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | pub fn dfg_to_json(dfg: &HashMap<(String, String), usize>) -> Value { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `to_be_non_reachable` is never used [INFO] [stdout] --> src/cost_to_cut.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | pub fn to_be_non_reachable( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_all_paths` is never used [INFO] [stdout] --> src/cost_to_cut.rs:26:4 [INFO] [stdout] | [INFO] [stdout] 26 | fn find_all_paths( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_paths_dfs` is never used [INFO] [stdout] --> src/cost_to_cut.rs:39:4 [INFO] [stdout] | [INFO] [stdout] 39 | fn find_paths_dfs( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_min_edge_cut` is never used [INFO] [stdout] --> src/cost_to_cut.rs:69:4 [INFO] [stdout] | [INFO] [stdout] 69 | fn find_min_edge_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_min_edge_cut_old` is never used [INFO] [stdout] --> src/cost_to_cut.rs:164:4 [INFO] [stdout] | [INFO] [stdout] 164 | fn find_min_edge_cut_old( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_disconnected` is never used [INFO] [stdout] --> src/cost_to_cut.rs:217:4 [INFO] [stdout] | [INFO] [stdout] 217 | fn is_disconnected( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/cost_to_cut.rs:243:8 [INFO] [stdout] | [INFO] [stdout] 243 | pub fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `add_edge_to_dfg` is never used [INFO] [stdout] --> src/cost_to_add.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | pub fn add_edge_to_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CutResult` is never constructed [INFO] [stdout] --> src/good_cuts.rs:107:12 [INFO] [stdout] | [INFO] [stdout] 107 | pub struct CutResult { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ActivityPartitioner` is never constructed [INFO] [stdout] --> src/good_cuts.rs:114:12 [INFO] [stdout] | [INFO] [stdout] 114 | pub struct ActivityPartitioner { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/good_cuts.rs:123:12 [INFO] [stdout] | [INFO] [stdout] 122 | impl ActivityPartitioner { [INFO] [stdout] | ------------------------ associated items in this implementation [INFO] [stdout] 123 | pub fn new(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 153 | pub fn solve(&self) -> Option { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 178 | fn try_source_sink(&self, source: usize, sink: usize) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 228 | fn edmonds_karp(&self, source: usize, sink: usize, mut capacity: Vec>) [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 288 | fn find_reachable(&self, source: usize, residual: &[Vec]) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 307 | fn validate_partition(&self, set1: &[String], set2: &[String]) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 333 | fn get_reachable_nodes(&self, start: usize) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `perform_cut` is never used [INFO] [stdout] --> src/good_cuts.rs:354:8 [INFO] [stdout] | [INFO] [stdout] 354 | pub fn perform_cut( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_possible_sequence_cut` is never used [INFO] [stdout] --> src/good_cuts.rs:391:8 [INFO] [stdout] | [INFO] [stdout] 391 | pub fn best_possible_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_sequence_cut` is never used [INFO] [stdout] --> src/best_sequence_cut.rs:7:8 [INFO] [stdout] | [INFO] [stdout] 7 | pub fn best_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/best_exclusive_cut.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/best_exclusive_cut.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | impl Graph { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] 12 | fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 20 | fn add_edge(&mut self, from: String, to: String, cap: usize) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | fn get_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 37 | fn get_flow(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 41 | fn get_residual_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 45 | fn push_flow(&mut self, from: &str, to: &str, amount: usize) { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 55 | fn bfs_find_path(&self, source: &str, sink: &str) -> Option> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 92 | fn max_flow(&mut self, source: &str, sink: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 116 | fn find_reachable_from_source(&self, source: &str) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_exclusive_cut` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:136:8 [INFO] [stdout] | [INFO] [stdout] 136 | pub fn best_exclusive_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_example` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:256:8 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn test_example() { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_graph` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:293:4 [INFO] [stdout] | [INFO] [stdout] 293 | fn print_graph( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Solution` is never constructed [INFO] [stdout] --> src/best_parallel_cut.rs:15:8 [INFO] [stdout] | [INFO] [stdout] 15 | struct Solution { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:22:8 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn best_parallel_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `hello` is never used [INFO] [stdout] --> src/main.rs:44:10 [INFO] [stdout] | [INFO] [stdout] 44 | async fn hello() -> Json { [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `main1` is never used [INFO] [stdout] --> src/main.rs:56:10 [INFO] [stdout] | [INFO] [stdout] 56 | async fn main1() { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `generate_initial_partition` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn generate_initial_partition( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `local_search_improvement` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:103:4 [INFO] [stdout] | [INFO] [stdout] 103 | fn local_search_improvement( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `log_sorted_map` is never used [INFO] [stdout] --> src/main.rs:162:4 [INFO] [stdout] | [INFO] [stdout] 162 | fn log_sorted_map( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `final_optimization` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:184:4 [INFO] [stdout] | [INFO] [stdout] 184 | fn final_optimization( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_cost` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:231:4 [INFO] [stdout] | [INFO] [stdout] 231 | fn calculate_cost( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_edges_to_add` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:254:4 [INFO] [stdout] | [INFO] [stdout] 254 | fn get_edges_to_add( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_process_tree` is never used [INFO] [stdout] --> src/main.rs:189:4 [INFO] [stdout] | [INFO] [stdout] 189 | fn print_process_tree(tree: &TreeNode, depth: usize) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_partition_result` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:277:4 [INFO] [stdout] | [INFO] [stdout] 277 | fn create_partition_result( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:4:16 [INFO] [stdout] | [INFO] [stdout] 4 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | pub fn best_parallel_cut_exhaustive( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_partition_cost` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:104:8 [INFO] [stdout] | [INFO] [stdout] 104 | fn calculate_partition_cost( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive_optimized` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:134:12 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn best_parallel_cut_exhaustive_optimized( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_cost_optimized` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:228:8 [INFO] [stdout] | [INFO] [stdout] 228 | fn calculate_cost_optimized(mask: u64, n: usize, edge_matrix: &[Vec]) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive_memory_efficient` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:251:12 [INFO] [stdout] | [INFO] [stdout] 251 | pub fn best_parallel_cut_exhaustive_memory_efficient( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `search_combinations` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:307:8 [INFO] [stdout] | [INFO] [stdout] 307 | fn search_combinations( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_redo_cut` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:8:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub fn best_redo_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `remove_edges_dfg` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:161:4 [INFO] [stdout] | [INFO] [stdout] 161 | fn remove_edges_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `remove_activity_from_dfg` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:190:4 [INFO] [stdout] | [INFO] [stdout] 190 | fn remove_activity_from_dfg(dfg: &mut HashMap<(String, String), usize>, activity: &String) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/best_sequence_cut_v2.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_process_forest` is never used [INFO] [stdout] --> src/main.rs:197:4 [INFO] [stdout] | [INFO] [stdout] 197 | fn print_process_forest(forest: &ProcessForest) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/best_sequence_cut_v2.rs:11:8 [INFO] [stdout] | [INFO] [stdout] 10 | impl Graph { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] 11 | fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 19 | fn add_edge(&mut self, from: String, to: String, cap: usize) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 27 | fn get_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 31 | fn get_flow(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 35 | fn get_residual_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 39 | fn push_flow(&mut self, from: &str, to: &str, amount: usize) { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 52 | fn bfs_find_path(&self, source: &str, sink: &str) -> Option> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | fn max_flow(&mut self, source: &str, sink: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 113 | fn find_reachable_from_source(&self, source: &str) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_exclusive_cut` is never used [INFO] [stdout] --> src/best_sequence_cut_v2.rs:133:8 [INFO] [stdout] | [INFO] [stdout] 133 | pub fn best_exclusive_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut_v2.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `bfs` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:25:4 [INFO] [stdout] | [INFO] [stdout] 25 | fn bfs( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_s_t_min_cut` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:66:4 [INFO] [stdout] | [INFO] [stdout] 66 | fn find_s_t_min_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_v2` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:126:8 [INFO] [stdout] | [INFO] [stdout] 126 | pub fn best_parallel_cut_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_from_dfg` is never used [INFO] [stdout] --> src/main.rs:226:4 [INFO] [stdout] | [INFO] [stdout] 226 | fn get_start_and_end_activities_from_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `mainkoi` is never used [INFO] [stdout] --> src/main.rs:251:4 [INFO] [stdout] | [INFO] [stdout] 251 | fn mainkoi() { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `global_log` is never read [INFO] [stdout] --> src/types.rs:8:9 [INFO] [stdout] | [INFO] [stdout] 6 | pub struct OcelJson { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] 7 | #[serde(rename = "ocel:global-log")] [INFO] [stdout] 8 | pub global_log: serde_json::Value, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `OcelJson` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `TreeNode` is never constructed [INFO] [stdout] --> src/types.rs:33:12 [INFO] [stdout] | [INFO] [stdout] 33 | pub struct TreeNode { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias `ProcessForest` is never used [INFO] [stdout] --> src/types.rs:38:10 [INFO] [stdout] | [INFO] [stdout] 38 | pub type ProcessForest = Vec; [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Node` is never constructed [INFO] [stdout] --> src/types.rs:43:12 [INFO] [stdout] | [INFO] [stdout] 43 | pub struct Node { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Edge` is never constructed [INFO] [stdout] --> src/types.rs:49:12 [INFO] [stdout] | [INFO] [stdout] 49 | pub struct Edge { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/types.rs:57:12 [INFO] [stdout] | [INFO] [stdout] 57 | pub struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts` is never used [INFO] [stdout] --> src/start_cuts.rs:6:8 [INFO] [stdout] | [INFO] [stdout] 6 | pub fn find_cuts( [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/start_cuts.rs:109:4 [INFO] [stdout] | [INFO] [stdout] 109 | fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts.rs:135:4 [INFO] [stdout] | [INFO] [stdout] 135 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_sequence_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:148:8 [INFO] [stdout] | [INFO] [stdout] 148 | pub fn is_sequence_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:175:8 [INFO] [stdout] | [INFO] [stdout] 175 | pub fn is_exclusive_choice_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_parallel_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:190:4 [INFO] [stdout] | [INFO] [stdout] 190 | fn is_parallel_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_redo_cut_possible` is never used [INFO] [stdout] --> src/start_cuts.rs:233:4 [INFO] [stdout] | [INFO] [stdout] 233 | fn is_redo_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts.rs:329:4 [INFO] [stdout] | [INFO] [stdout] 329 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used [INFO] [stdout] --> src/start_cuts.rs:359:4 [INFO] [stdout] | [INFO] [stdout] 359 | fn get_start_and_end_activities_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:8:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub fn strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_scc_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:102:8 [INFO] [stdout] | [INFO] [stdout] 102 | pub fn build_scc_dag( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `partition_scc_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:126:8 [INFO] [stdout] | [INFO] [stdout] 126 | pub fn partition_scc_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:165:8 [INFO] [stdout] | [INFO] [stdout] 165 | pub fn print_strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_sequence_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:265:8 [INFO] [stdout] | [INFO] [stdout] 265 | pub fn find_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_subgraph` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:344:4 [INFO] [stdout] | [INFO] [stdout] 344 | fn build_subgraph( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:360:4 [INFO] [stdout] | [INFO] [stdout] 360 | fn dfs(node: &String, graph: &HashMap>, visited: &mut HashSet) { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `compute_sccs` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:374:4 [INFO] [stdout] | [INFO] [stdout] 374 | fn compute_sccs( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs_postorder` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:403:4 [INFO] [stdout] | [INFO] [stdout] 403 | fn dfs_postorder( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfs_collect` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:421:4 [INFO] [stdout] | [INFO] [stdout] 421 | fn dfs_collect( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts_start` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:440:8 [INFO] [stdout] | [INFO] [stdout] 440 | pub fn find_cuts_start( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_best_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:598:4 [INFO] [stdout] | [INFO] [stdout] 598 | fn find_best_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:635:8 [INFO] [stdout] | [INFO] [stdout] 635 | pub fn find_cuts( [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:738:4 [INFO] [stdout] | [INFO] [stdout] 738 | fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:764:4 [INFO] [stdout] | [INFO] [stdout] 764 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_sequence_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:777:4 [INFO] [stdout] | [INFO] [stdout] 777 | fn is_sequence_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:804:4 [INFO] [stdout] | [INFO] [stdout] 804 | fn is_exclusive_choice_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_parallel_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:819:4 [INFO] [stdout] | [INFO] [stdout] 819 | fn is_parallel_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_redo_cut_possible` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:862:4 [INFO] [stdout] | [INFO] [stdout] 862 | fn is_redo_cut_possible( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:958:4 [INFO] [stdout] | [INFO] [stdout] 958 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used [INFO] [stdout] --> src/start_cuts_opti_v1.rs:988:4 [INFO] [stdout] | [INFO] [stdout] 988 | fn get_start_and_end_activities_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_cuts_start` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:19:8 [INFO] [stdout] | [INFO] [stdout] 19 | pub fn find_cuts_start( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_exclusive_choice_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:187:4 [INFO] [stdout] | [INFO] [stdout] 187 | fn find_exclusive_choice_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `exclusive_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:251:4 [INFO] [stdout] | [INFO] [stdout] 251 | fn exclusive_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_sequence_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:270:4 [INFO] [stdout] | [INFO] [stdout] 270 | fn find_sequence_cut(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `strongly_connected_components` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:295:4 [INFO] [stdout] | [INFO] [stdout] 295 | fn strongly_connected_components( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `build_scc_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:382:8 [INFO] [stdout] | [INFO] [stdout] 382 | pub fn build_scc_dag( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `partition_scc_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:406:8 [INFO] [stdout] | [INFO] [stdout] 406 | pub fn partition_scc_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable_in_dag` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:467:8 [INFO] [stdout] | [INFO] [stdout] 467 | pub fn is_reachable_in_dag( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `sequence_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:490:4 [INFO] [stdout] | [INFO] [stdout] 490 | fn sequence_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_parallel_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:510:4 [INFO] [stdout] | [INFO] [stdout] 510 | fn find_parallel_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `totalCost` should have a snake case name [INFO] [stdout] --> src/cost_to_add.rs:12:13 [INFO] [stdout] | [INFO] [stdout] 12 | let mut totalCost = 0; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `total_cost` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parallel_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:549:4 [INFO] [stdout] | [INFO] [stdout] 549 | fn parallel_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_redo_cut` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:564:4 [INFO] [stdout] | [INFO] [stdout] 564 | fn find_redo_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `redo_cut_condition_check` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:597:4 [INFO] [stdout] | [INFO] [stdout] 597 | fn redo_cut_condition_check( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `filter_keep_dfg` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:676:4 [INFO] [stdout] | [INFO] [stdout] 676 | fn filter_keep_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `check_bi_direction_sets` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:688:4 [INFO] [stdout] | [INFO] [stdout] 688 | fn check_bi_direction_sets( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_start_and_end_activities` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:703:4 [INFO] [stdout] | [INFO] [stdout] 703 | fn get_start_and_end_activities( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable_before_end_activity` is never used [INFO] [stdout] --> src/start_cuts_opti_v2.rs:740:8 [INFO] [stdout] | [INFO] [stdout] 740 | pub fn is_reachable_before_end_activity( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `dfg_to_json` is never used [INFO] [stdout] --> src/format_conversion.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | pub fn dfg_to_json(dfg: &HashMap<(String, String), usize>) -> Value { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `to_be_non_reachable` is never used [INFO] [stdout] --> src/cost_to_cut.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | pub fn to_be_non_reachable( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_all_paths` is never used [INFO] [stdout] --> src/cost_to_cut.rs:26:4 [INFO] [stdout] | [INFO] [stdout] 26 | fn find_all_paths( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_paths_dfs` is never used [INFO] [stdout] --> src/cost_to_cut.rs:39:4 [INFO] [stdout] | [INFO] [stdout] 39 | fn find_paths_dfs( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_min_edge_cut` is never used [INFO] [stdout] --> src/cost_to_cut.rs:69:4 [INFO] [stdout] | [INFO] [stdout] 69 | fn find_min_edge_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_min_edge_cut_old` is never used [INFO] [stdout] --> src/cost_to_cut.rs:164:4 [INFO] [stdout] | [INFO] [stdout] 164 | fn find_min_edge_cut_old( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_disconnected` is never used [INFO] [stdout] --> src/cost_to_cut.rs:217:4 [INFO] [stdout] | [INFO] [stdout] 217 | fn is_disconnected( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `is_reachable` is never used [INFO] [stdout] --> src/cost_to_cut.rs:243:8 [INFO] [stdout] | [INFO] [stdout] 243 | pub fn is_reachable( [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `add_edge_to_dfg` is never used [INFO] [stdout] --> src/cost_to_add.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | pub fn add_edge_to_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `CutResult` is never constructed [INFO] [stdout] --> src/good_cuts.rs:107:12 [INFO] [stdout] | [INFO] [stdout] 107 | pub struct CutResult { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `ActivityPartitioner` is never constructed [INFO] [stdout] --> src/good_cuts.rs:114:12 [INFO] [stdout] | [INFO] [stdout] 114 | pub struct ActivityPartitioner { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/good_cuts.rs:123:12 [INFO] [stdout] | [INFO] [stdout] 122 | impl ActivityPartitioner { [INFO] [stdout] | ------------------------ associated items in this implementation [INFO] [stdout] 123 | pub fn new(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 153 | pub fn solve(&self) -> Option { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 178 | fn try_source_sink(&self, source: usize, sink: usize) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 228 | fn edmonds_karp(&self, source: usize, sink: usize, mut capacity: Vec>) [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 288 | fn find_reachable(&self, source: usize, residual: &[Vec]) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 307 | fn validate_partition(&self, set1: &[String], set2: &[String]) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 333 | fn get_reachable_nodes(&self, start: usize) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `perform_cut` is never used [INFO] [stdout] --> src/good_cuts.rs:354:8 [INFO] [stdout] | [INFO] [stdout] 354 | pub fn perform_cut( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_possible_sequence_cut` is never used [INFO] [stdout] --> src/good_cuts.rs:391:8 [INFO] [stdout] | [INFO] [stdout] 391 | pub fn best_possible_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_sequence_cut` is never used [INFO] [stdout] --> src/best_sequence_cut.rs:7:8 [INFO] [stdout] | [INFO] [stdout] 7 | pub fn best_sequence_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/best_exclusive_cut.rs:5:8 [INFO] [stdout] | [INFO] [stdout] 5 | struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/best_exclusive_cut.rs:12:8 [INFO] [stdout] | [INFO] [stdout] 11 | impl Graph { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] 12 | fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 20 | fn add_edge(&mut self, from: String, to: String, cap: usize) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 33 | fn get_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 37 | fn get_flow(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 41 | fn get_residual_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 45 | fn push_flow(&mut self, from: &str, to: &str, amount: usize) { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 55 | fn bfs_find_path(&self, source: &str, sink: &str) -> Option> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 92 | fn max_flow(&mut self, source: &str, sink: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 116 | fn find_reachable_from_source(&self, source: &str) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_exclusive_cut` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:136:8 [INFO] [stdout] | [INFO] [stdout] 136 | pub fn best_exclusive_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `test_example` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:256:8 [INFO] [stdout] | [INFO] [stdout] 256 | pub fn test_example() { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `print_graph` is never used [INFO] [stdout] --> src/best_exclusive_cut.rs:293:4 [INFO] [stdout] | [INFO] [stdout] 293 | fn print_graph( [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Solution` is never constructed [INFO] [stdout] --> src/best_parallel_cut.rs:15:8 [INFO] [stdout] | [INFO] [stdout] 15 | struct Solution { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:22:8 [INFO] [stdout] | [INFO] [stdout] 22 | pub fn best_parallel_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `generate_initial_partition` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:73:4 [INFO] [stdout] | [INFO] [stdout] 73 | fn generate_initial_partition( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `local_search_improvement` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:103:4 [INFO] [stdout] | [INFO] [stdout] 103 | fn local_search_improvement( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `final_optimization` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:184:4 [INFO] [stdout] | [INFO] [stdout] 184 | fn final_optimization( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_cost` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:231:4 [INFO] [stdout] | [INFO] [stdout] 231 | fn calculate_cost( [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `get_edges_to_add` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:254:4 [INFO] [stdout] | [INFO] [stdout] 254 | fn get_edges_to_add( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `create_partition_result` is never used [INFO] [stdout] --> src/best_parallel_cut.rs:277:4 [INFO] [stdout] | [INFO] [stdout] 277 | fn create_partition_result( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:4:16 [INFO] [stdout] | [INFO] [stdout] 4 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:15:12 [INFO] [stdout] | [INFO] [stdout] 15 | pub fn best_parallel_cut_exhaustive( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_partition_cost` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:104:8 [INFO] [stdout] | [INFO] [stdout] 104 | fn calculate_partition_cost( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive_optimized` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:134:12 [INFO] [stdout] | [INFO] [stdout] 134 | pub fn best_parallel_cut_exhaustive_optimized( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `calculate_cost_optimized` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:228:8 [INFO] [stdout] | [INFO] [stdout] 228 | fn calculate_cost_optimized(mask: u64, n: usize, edge_matrix: &[Vec]) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_exhaustive_memory_efficient` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:251:12 [INFO] [stdout] | [INFO] [stdout] 251 | pub fn best_parallel_cut_exhaustive_memory_efficient( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `search_combinations` is never used [INFO] [stdout] --> src/best_parallel_cut_exhaustive.rs:307:8 [INFO] [stdout] | [INFO] [stdout] 307 | fn search_combinations( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_redo_cut` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:8:8 [INFO] [stdout] | [INFO] [stdout] 8 | pub fn best_redo_cut( [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `remove_edges_dfg` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:161:4 [INFO] [stdout] | [INFO] [stdout] 161 | fn remove_edges_dfg( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `remove_activity_from_dfg` is never used [INFO] [stdout] --> src/best_redo_cuts.rs:190:4 [INFO] [stdout] | [INFO] [stdout] 190 | fn remove_activity_from_dfg(dfg: &mut HashMap<(String, String), usize>, activity: &String) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `Graph` is never constructed [INFO] [stdout] --> src/best_sequence_cut_v2.rs:4:8 [INFO] [stdout] | [INFO] [stdout] 4 | struct Graph { [INFO] [stdout] | ^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: multiple associated items are never used [INFO] [stdout] --> src/best_sequence_cut_v2.rs:11:8 [INFO] [stdout] | [INFO] [stdout] 10 | impl Graph { [INFO] [stdout] | ---------- associated items in this implementation [INFO] [stdout] 11 | fn new() -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] ... [INFO] [stdout] 19 | fn add_edge(&mut self, from: String, to: String, cap: usize) { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 27 | fn get_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 31 | fn get_flow(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 35 | fn get_residual_capacity(&self, from: &str, to: &str) -> usize { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 39 | fn push_flow(&mut self, from: &str, to: &str, amount: usize) { [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 52 | fn bfs_find_path(&self, source: &str, sink: &str) -> Option> { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 89 | fn max_flow(&mut self, source: &str, sink: &str) -> usize { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 113 | fn find_reachable_from_source(&self, source: &str) -> HashSet { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_exclusive_cut` is never used [INFO] [stdout] --> src/best_sequence_cut_v2.rs:133:8 [INFO] [stdout] | [INFO] [stdout] 133 | pub fn best_exclusive_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PartitionResult` is never constructed [INFO] [stdout] --> src/best_parallel_cut_v2.rs:5:12 [INFO] [stdout] | [INFO] [stdout] 5 | pub struct PartitionResult { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `bfs` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:25:4 [INFO] [stdout] | [INFO] [stdout] 25 | fn bfs( [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `find_s_t_min_cut` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:66:4 [INFO] [stdout] | [INFO] [stdout] 66 | fn find_s_t_min_cut( [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `best_parallel_cut_v2` is never used [INFO] [stdout] --> src/best_parallel_cut_v2.rs:126:8 [INFO] [stdout] | [INFO] [stdout] 126 | pub fn best_parallel_cut_v2( [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable `totalCost` should have a snake case name [INFO] [stdout] --> src/cost_to_add.rs:12:13 [INFO] [stdout] | [INFO] [stdout] 12 | let mut totalCost = 0; [INFO] [stdout] | ^^^^^^^^^ help: convert the identifier to snake case: `total_cost` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(non_snake_case)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.31s [INFO] running `Command { std: "docker" "inspect" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }` [INFO] [stdout] ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f