[INFO] cloning repository https://github.com/denzyldick/phanalist
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/denzyldick/phanalist" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdenzyldick%2Fphanalist", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdenzyldick%2Fphanalist'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] a9c7cfb9413c74548f119f09b571e6587f6c59a9
[INFO] testing denzyldick/phanalist/a9c7cfb9413c74548f119f09b571e6587f6c59a9 against 1.90.0 for beta-1.91-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdenzyldick%2Fphanalist" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/denzyldick/phanalist
[INFO] finished tweaking git repo https://github.com/denzyldick/phanalist
[INFO] tweaked toml for git repo https://github.com/denzyldick/phanalist written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/denzyldick/phanalist on toolchain 1.90.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/denzyldick/phanalist already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.90.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Updating git repository `https://github.com/php-rust-tools/parser`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded derive_builder_macro v0.20.0
[INFO] [stderr]   Downloaded schemafy_core v0.6.0
[INFO] [stderr]   Downloaded schemafy_lib v0.6.0
[INFO] [stderr]   Downloaded serde-sarif v0.5.0
[INFO] [stderr]   Downloaded derive_builder v0.20.0
[INFO] [stderr]   Downloaded cli-table v0.4.9
[INFO] [stderr]   Downloaded cli-table-derive v0.4.6
[INFO] [stderr]   Downloaded serde_derive_internals v0.29.1
[INFO] [stderr]   Downloaded clap v4.5.9
[INFO] [stderr]   Downloaded indicatif v0.17.8
[INFO] [stderr]   Downloaded schemars v0.8.21
[INFO] [stderr]   Downloaded jwalk v0.8.1
[INFO] [stderr]   Downloaded ariadne v0.1.5
[INFO] [stderr]   Downloaded syn v2.0.71
[INFO] [stderr]   Downloaded clap_derive v4.5.8
[INFO] [stderr]   Downloaded schemars_derive v0.8.21
[INFO] [stderr]   Downloaded derive_builder_core v0.20.0
[INFO] [stderr]   Downloaded serde_derive v1.0.204
[INFO] [stderr]   Downloaded clap_builder v4.5.9
[INFO] [stderr]   Downloaded serde v1.0.204
[INFO] [stderr]   Downloaded exitcode v1.1.2
[INFO] [stderr]   Downloaded human_bytes v0.4.3
[INFO] [stderr]   Downloaded memory-stats v1.2.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] f145cfa7ae2ff34814af4588a8c9f92025f2ee1503db36f388e8bef8af769c26
[INFO] running `Command { std: "docker" "start" "-a" "f145cfa7ae2ff34814af4588a8c9f92025f2ee1503db36f388e8bef8af769c26", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "f145cfa7ae2ff34814af4588a8c9f92025f2ee1503db36f388e8bef8af769c26", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f145cfa7ae2ff34814af4588a8c9f92025f2ee1503db36f388e8bef8af769c26", kill_on_drop: false }`
[INFO] [stdout] f145cfa7ae2ff34814af4588a8c9f92025f2ee1503db36f388e8bef8af769c26
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a69fc72231e2402d8ec9a49bcc273887af4c2901bce787d05db5088822f59eb7
[INFO] running `Command { std: "docker" "start" "-a" "a69fc72231e2402d8ec9a49bcc273887af4c2901bce787d05db5088822f59eb7", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.86
[INFO] [stderr]    Compiling serde v1.0.204
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling serde_json v1.0.120
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling regex-syntax v0.8.4
[INFO] [stderr]    Compiling anyhow v1.0.86
[INFO] [stderr]    Compiling uriparse v0.6.4
[INFO] [stderr]    Compiling clap_lex v0.7.1
[INFO] [stderr]    Compiling unicode-width v0.1.13
[INFO] [stderr]    Compiling schemars v0.8.21
[INFO] [stderr]    Compiling thiserror v1.0.63
[INFO] [stderr]    Compiling portable-atomic v1.7.0
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling clap_builder v4.5.9
[INFO] [stderr]    Compiling csv-core v0.1.11
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling crossbeam-queue v0.3.11
[INFO] [stderr]    Compiling syn v2.0.71
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling yansi v0.5.1
[INFO] [stderr]    Compiling dyn-clone v1.0.17
[INFO] [stderr]    Compiling either v1.13.0
[INFO] [stderr]    Compiling ariadne v0.1.5
[INFO] [stderr]    Compiling rayon v1.10.0
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling console v0.15.8
[INFO] [stderr]    Compiling regex-automata v0.4.7
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling termcolor v1.4.1
[INFO] [stderr]    Compiling indicatif v0.17.8
[INFO] [stderr]    Compiling cli-table-derive v0.4.6
[INFO] [stderr]    Compiling memory-stats v1.2.0
[INFO] [stderr]    Compiling human_bytes v0.4.3
[INFO] [stderr]    Compiling exitcode v1.1.2
[INFO] [stderr]    Compiling jwalk v0.8.1
[INFO] [stderr]    Compiling regex v1.10.5
[INFO] [stderr]    Compiling darling_core v0.20.10
[INFO] [stderr]    Compiling prettyplease v0.2.20
[INFO] [stderr]    Compiling serde_derive_internals v0.29.1
[INFO] [stderr]    Compiling Inflector v0.11.4
[INFO] [stderr]    Compiling serde_derive v1.0.204
[INFO] [stderr]    Compiling clap_derive v4.5.8
[INFO] [stderr]    Compiling thiserror-impl v1.0.63
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling schemars_derive v0.8.21
[INFO] [stderr]    Compiling darling_macro v0.20.10
[INFO] [stderr]    Compiling clap v4.5.9
[INFO] [stderr]    Compiling darling v0.20.10
[INFO] [stderr]    Compiling derive_builder_core v0.20.0
[INFO] [stderr]    Compiling derive_builder_macro v0.20.0
[INFO] [stderr]    Compiling derive_builder v0.20.0
[INFO] [stderr]    Compiling csv v1.3.0
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling cli-table v0.4.9
[INFO] [stderr]    Compiling schemafy_core v0.6.0
[INFO] [stderr]    Compiling schemafy_lib v0.6.0
[INFO] [stderr]    Compiling serde-sarif v0.5.0
[INFO] [stderr]    Compiling php-parser-rs v0.1.3 (https://github.com/php-rust-tools/parser#ec4cb411)
[INFO] [stderr]    Compiling phanalist v0.1.21 (/opt/rustwide/workdir)
[INFO] [stdout] warning: method `output` is never used
[INFO] [stdout]    --> src/analyse.rs:157:19
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl Analyse {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub(crate) fn output(&mut self, results: &mut Results, format: Format, summary_only: bool) {
[INFO] [stdout]     |                   ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `OutputFormatter` is never used
[INFO] [stdout]   --> src/outputs/mod.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait OutputFormatter {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CodeClimate` is never constructed
[INFO] [stdout]  --> src/outputs/codeclimate.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct CodeClimate {}
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Text` is never constructed
[INFO] [stdout]   --> src/outputs/text.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Text {}
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `output_files_with_violations` and `output_summary` are never used
[INFO] [stdout]   --> src/outputs/text.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Text {
[INFO] [stdout]    | --------- associated functions in this implementation
[INFO] [stdout] 34 |     fn output_files_with_violations(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn output_summary(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Json` is never constructed
[INFO] [stdout]  --> src/outputs/json.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Json {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Sarif` is never constructed
[INFO] [stdout]   --> src/outputs/sarif.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Sarif {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `description` and `get_detailed_explanation` are never used
[INFO] [stdout]   --> src/rules/mod.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub trait Rule {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn description(&self) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn get_detailed_explanation(&self) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CODE` is never used
[INFO] [stdout]  --> src/rules/e0.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | static CODE: &str = "E0000";
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e0.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rule` is never constructed
[INFO] [stdout]  --> src/rules/e0.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Rule {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e1.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Opening tag position";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e10.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Npath complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e11.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Detect the error suppression symbol: @";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e12.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | static DESCRIPTION: &str = "Service compatibility with Shared Memory Model";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e13.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Private method not being called.";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e2.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | static DESCRIPTION: &str = "Empty catch";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e3.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Method modifiers";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e4.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Uppercase constants";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e5.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Capitalized class name";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e6.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Property modifiers";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e7.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | static DESCRIPTION: &str = "Method parameters count";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e8.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Return type signature";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e9.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Cyclomatic complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:100:44
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stdout]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stdout]     |                                            |                    |
[INFO] [stdout]     |                                            |                    the lifetime is named here
[INFO] [stdout]     |                                            the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stdout]     |                                                                                       ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:107:10
[INFO] [stdout]     |
[INFO] [stdout] 107 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 109 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 110 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:135:10
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 137 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 138 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e1.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                      ^^ the lifetime is named here
[INFO] [stdout] 70 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 71 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:79:10
[INFO] [stdout]    |
[INFO] [stdout] 79 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 81 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 82 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:130:10
[INFO] [stdout]     |
[INFO] [stdout] 130 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 132 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 133 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stdout]     |                                                ^^ the lifetime is named here
[INFO] [stdout] 217 |         expression: &'a Expression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 218 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:258:10
[INFO] [stdout]     |
[INFO] [stdout] 258 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 260 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:280:10
[INFO] [stdout]     |
[INFO] [stdout] 280 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 282 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:326:10
[INFO] [stdout]     |
[INFO] [stdout] 326 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 328 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:353:10
[INFO] [stdout]     |
[INFO] [stdout] 353 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 355 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e3.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 60 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 61 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e4.rs:45:10
[INFO] [stdout]    |
[INFO] [stdout] 45 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 47 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 48 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:35:10
[INFO] [stdout]    |
[INFO] [stdout] 35 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 37 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 38 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e6.rs:43:10
[INFO] [stdout]    |
[INFO] [stdout] 43 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 45 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 46 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e7.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 88 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 89 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e8.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 46 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 47 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e9.rs:78:10
[INFO] [stdout]    |
[INFO] [stdout] 78 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 80 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 81 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CODE` is never used
[INFO] [stdout]  --> src/rules/e0.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | static CODE: &str = "E0000";
[INFO] [stdout]   |        ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e0.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rule` is never constructed
[INFO] [stdout]  --> src/rules/e0.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Rule {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:100:44
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stdout]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stdout]     |                                            |                    |
[INFO] [stdout]     |                                            |                    the lifetime is named here
[INFO] [stdout]     |                                            the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stdout]     |                                                                                       ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:107:10
[INFO] [stdout]     |
[INFO] [stdout] 107 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 109 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 110 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:135:10
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 137 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 138 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e1.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                      ^^ the lifetime is named here
[INFO] [stdout] 70 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 71 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:79:10
[INFO] [stdout]    |
[INFO] [stdout] 79 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 81 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 82 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:130:10
[INFO] [stdout]     |
[INFO] [stdout] 130 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 132 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 133 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stdout]     |                                                ^^ the lifetime is named here
[INFO] [stdout] 217 |         expression: &'a Expression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 218 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:258:10
[INFO] [stdout]     |
[INFO] [stdout] 258 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 260 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:280:10
[INFO] [stdout]     |
[INFO] [stdout] 280 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 282 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:326:10
[INFO] [stdout]     |
[INFO] [stdout] 326 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 328 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:353:10
[INFO] [stdout]     |
[INFO] [stdout] 353 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 355 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e3.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 60 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 61 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e4.rs:45:10
[INFO] [stdout]    |
[INFO] [stdout] 45 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 47 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 48 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:35:10
[INFO] [stdout]    |
[INFO] [stdout] 35 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 37 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 38 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e6.rs:43:10
[INFO] [stdout]    |
[INFO] [stdout] 43 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 45 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 46 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e7.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 88 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 89 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e8.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 46 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 47 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e9.rs:78:10
[INFO] [stdout]    |
[INFO] [stdout] 78 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 80 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 81 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 41s
[INFO] running `Command { std: "docker" "inspect" "a69fc72231e2402d8ec9a49bcc273887af4c2901bce787d05db5088822f59eb7", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a69fc72231e2402d8ec9a49bcc273887af4c2901bce787d05db5088822f59eb7", kill_on_drop: false }`
[INFO] [stdout] a69fc72231e2402d8ec9a49bcc273887af4c2901bce787d05db5088822f59eb7
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 238b5379331cf8b83b99dcb883ac8a30ef43acfd0894796db67b2d1ece9783c9
[INFO] running `Command { std: "docker" "start" "-a" "238b5379331cf8b83b99dcb883ac8a30ef43acfd0894796db67b2d1ece9783c9", kill_on_drop: false }`
[INFO] [stdout] warning: method `output` is never used
[INFO] [stdout]    --> src/analyse.rs:157:19
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl Analyse {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub(crate) fn output(&mut self, results: &mut Results, format: Format, summary_only: bool) {
[INFO] [stdout]     |                   ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `OutputFormatter` is never used
[INFO] [stdout]   --> src/outputs/mod.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait OutputFormatter {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CodeClimate` is never constructed
[INFO] [stdout]  --> src/outputs/codeclimate.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct CodeClimate {}
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Text` is never constructed
[INFO] [stdout]   --> src/outputs/text.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Text {}
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `output_files_with_violations` and `output_summary` are never used
[INFO] [stdout]   --> src/outputs/text.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Text {
[INFO] [stdout]    | --------- associated functions in this implementation
[INFO] [stdout] 34 |     fn output_files_with_violations(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn output_summary(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Json` is never constructed
[INFO] [stdout]  --> src/outputs/json.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Json {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Sarif` is never constructed
[INFO] [stdout]   --> src/outputs/sarif.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Sarif {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `description` and `get_detailed_explanation` are never used
[INFO] [stdout]   --> src/rules/mod.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub trait Rule {
[INFO] [stdout]    |           ---- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn description(&self) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn get_detailed_explanation(&self) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `CODE` is never used
[INFO] [stdout]  --> src/rules/e0.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | static CODE: &str = "E0000";
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e0.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rule` is never constructed
[INFO] [stdout]  --> src/rules/e0.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Rule {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e1.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Opening tag position";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e10.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Npath complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e11.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Detect the error suppression symbol: @";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e12.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | static DESCRIPTION: &str = "Service compatibility with Shared Memory Model";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e13.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Private method not being called.";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e2.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | static DESCRIPTION: &str = "Empty catch";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e3.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Method modifiers";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e4.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Uppercase constants";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e5.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Capitalized class name";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e6.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Property modifiers";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e7.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | static DESCRIPTION: &str = "Method parameters count";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e8.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Return type signature";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e9.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Cyclomatic complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:100:44
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stdout]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stdout]     |                                            |                    |
[INFO] [stdout]     |                                            |                    the lifetime is named here
[INFO] [stdout]     |                                            the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stdout]     |                                                                                       ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:107:10
[INFO] [stdout]     |
[INFO] [stdout] 107 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 109 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 110 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:135:10
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 137 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 138 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e1.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                      ^^ the lifetime is named here
[INFO] [stdout] 70 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 71 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:79:10
[INFO] [stdout]    |
[INFO] [stdout] 79 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 81 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 82 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:130:10
[INFO] [stdout]     |
[INFO] [stdout] 130 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 132 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 133 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stdout]     |                                                ^^ the lifetime is named here
[INFO] [stdout] 217 |         expression: &'a Expression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 218 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:258:10
[INFO] [stdout]     |
[INFO] [stdout] 258 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 260 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:280:10
[INFO] [stdout]     |
[INFO] [stdout] 280 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 282 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:326:10
[INFO] [stdout]     |
[INFO] [stdout] 326 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 328 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:353:10
[INFO] [stdout]     |
[INFO] [stdout] 353 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 355 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e3.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 60 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 61 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e4.rs:45:10
[INFO] [stdout]    |
[INFO] [stdout] 45 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 47 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 48 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:35:10
[INFO] [stdout]    |
[INFO] [stdout] 35 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 37 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 38 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e6.rs:43:10
[INFO] [stdout]    |
[INFO] [stdout] 43 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 45 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 46 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e7.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 88 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 89 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e8.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 46 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 47 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e9.rs:78:10
[INFO] [stdout]    |
[INFO] [stdout] 78 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 80 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 81 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling phanalist v0.1.21 (/opt/rustwide/workdir)
[INFO] [stdout] warning: method `output` is never used
[INFO] [stdout]    --> src/analyse.rs:157:19
[INFO] [stdout]     |
[INFO] [stdout]  55 | impl Analyse {
[INFO] [stdout]     | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 157 |     pub(crate) fn output(&mut self, results: &mut Results, format: Format, summary_only: bool) {
[INFO] [stdout]     |                   ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `OutputFormatter` is never used
[INFO] [stdout]   --> src/outputs/mod.rs:10:11
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub trait OutputFormatter {
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CodeClimate` is never constructed
[INFO] [stdout]  --> src/outputs/codeclimate.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct CodeClimate {}
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Text` is never constructed
[INFO] [stdout]   --> src/outputs/text.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Text {}
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `output_files_with_violations` and `output_summary` are never used
[INFO] [stdout]   --> src/outputs/text.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | impl Text {
[INFO] [stdout]    | --------- associated functions in this implementation
[INFO] [stdout] 34 |     fn output_files_with_violations(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn output_summary(results: &Results) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Json` is never constructed
[INFO] [stdout]  --> src/outputs/json.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct Json {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Sarif` is never constructed
[INFO] [stdout]   --> src/outputs/sarif.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Sarif {}
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]   --> src/rules/mod.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub trait Rule {
[INFO] [stdout]    |           ---- method in this trait
[INFO] [stdout] ...
[INFO] [stdout] 38 |     fn description(&self) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e0.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rule` is never constructed
[INFO] [stdout]  --> src/rules/e0.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Rule {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e1.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Opening tag position";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e10.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Npath complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e11.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Detect the error suppression symbol: @";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e12.rs:23:8
[INFO] [stdout]    |
[INFO] [stdout] 23 | static DESCRIPTION: &str = "Service compatibility with Shared Memory Model";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e13.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Private method not being called.";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e2.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | static DESCRIPTION: &str = "Empty catch";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e3.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Method modifiers";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e4.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | static DESCRIPTION: &str = "Uppercase constants";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e5.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Capitalized class name";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e6.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Property modifiers";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e7.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | static DESCRIPTION: &str = "Method parameters count";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e8.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | static DESCRIPTION: &str = "Return type signature";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]   --> src/rules/e9.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | static DESCRIPTION: &str = "Cyclomatic complexity";
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:100:44
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stdout]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stdout]     |                                            |                    |
[INFO] [stdout]     |                                            |                    the lifetime is named here
[INFO] [stdout]     |                                            the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stdout]     |                                                                                       ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:107:10
[INFO] [stdout]     |
[INFO] [stdout] 107 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 109 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 110 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:135:10
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 137 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 138 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e1.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                      ^^ the lifetime is named here
[INFO] [stdout] 70 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 71 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:79:10
[INFO] [stdout]    |
[INFO] [stdout] 79 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 81 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 82 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:130:10
[INFO] [stdout]     |
[INFO] [stdout] 130 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 132 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 133 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stdout]     |                                                ^^ the lifetime is named here
[INFO] [stdout] 217 |         expression: &'a Expression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 218 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:258:10
[INFO] [stdout]     |
[INFO] [stdout] 258 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 260 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:280:10
[INFO] [stdout]     |
[INFO] [stdout] 280 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 282 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:326:10
[INFO] [stdout]     |
[INFO] [stdout] 326 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 328 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:353:10
[INFO] [stdout]     |
[INFO] [stdout] 353 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 355 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e3.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 60 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 61 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e4.rs:45:10
[INFO] [stdout]    |
[INFO] [stdout] 45 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 47 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 48 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:35:10
[INFO] [stdout]    |
[INFO] [stdout] 35 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 37 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 38 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e6.rs:43:10
[INFO] [stdout]    |
[INFO] [stdout] 43 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 45 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 46 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e7.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 88 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 89 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e8.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 46 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 47 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e9.rs:78:10
[INFO] [stdout]    |
[INFO] [stdout] 78 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 80 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 81 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: static `DESCRIPTION` is never used
[INFO] [stdout]  --> src/rules/e0.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Rule` is never constructed
[INFO] [stdout]  --> src/rules/e0.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Rule {}
[INFO] [stdout]   |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:100:44
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stdout]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stdout]     |                                            |                    |
[INFO] [stdout]     |                                            |                    the lifetime is named here
[INFO] [stdout]     |                                            the lifetime is named here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stdout]     |                                                                                       ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:107:10
[INFO] [stdout]     |
[INFO] [stdout] 107 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 109 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 110 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/mod.rs:135:10
[INFO] [stdout]     |
[INFO] [stdout] 135 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 137 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 138 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e1.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                      ^^ the lifetime is named here
[INFO] [stdout] 70 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 71 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:79:10
[INFO] [stdout]    |
[INFO] [stdout] 79 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 81 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 82 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:130:10
[INFO] [stdout]     |
[INFO] [stdout] 130 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]     |                                      ^^ the lifetime is named here
[INFO] [stdout] 132 |         statement: &'a Statement,
[INFO] [stdout]     |                     ^^ the lifetime is named here
[INFO] [stdout] 133 |     ) -> Vec<&Statement> {
[INFO] [stdout]     |              ---------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stdout]     |                                                ^^ the lifetime is named here
[INFO] [stdout] 217 |         expression: &'a Expression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 218 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:258:10
[INFO] [stdout]     |
[INFO] [stdout] 258 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 260 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:280:10
[INFO] [stdout]     |
[INFO] [stdout] 280 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 282 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:326:10
[INFO] [stdout]     |
[INFO] [stdout] 326 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stdout]     |                      ^^ the lifetime is named here
[INFO] [stdout] 328 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]    --> src/rules/e12.rs:353:10
[INFO] [stdout]     |
[INFO] [stdout] 353 |         &'a self,
[INFO] [stdout]     |          ^^ the lifetime is named here
[INFO] [stdout] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stdout]     |                       ^^ the lifetime is named here
[INFO] [stdout] 355 |     ) -> Vec<&Expression> {
[INFO] [stdout]     |              ----------- the same lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]     |
[INFO] [stdout] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stdout]     |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e3.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 60 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 61 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e4.rs:45:10
[INFO] [stdout]    |
[INFO] [stdout] 45 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 47 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 48 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:35:10
[INFO] [stdout]    |
[INFO] [stdout] 35 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 37 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 38 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e6.rs:43:10
[INFO] [stdout]    |
[INFO] [stdout] 43 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 45 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 46 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e7.rs:86:10
[INFO] [stdout]    |
[INFO] [stdout] 86 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 88 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 89 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e8.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 46 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 47 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e9.rs:78:10
[INFO] [stdout]    |
[INFO] [stdout] 78 |         &'a self,
[INFO] [stdout]    |          ^^ the lifetime is named here
[INFO] [stdout] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stdout]    |                                  ^^ the lifetime is named here
[INFO] [stdout] 80 |         statement: &'a Statement,
[INFO] [stdout]    |                     ^^ the lifetime is named here
[INFO] [stdout] 81 |     ) -> Vec<&Statement> {
[INFO] [stdout]    |              ---------- the same lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: consistently use `'a`
[INFO] [stdout]    |
[INFO] [stdout] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stdout]    |               ++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 5.11s
[INFO] running `Command { std: "docker" "inspect" "238b5379331cf8b83b99dcb883ac8a30ef43acfd0894796db67b2d1ece9783c9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "238b5379331cf8b83b99dcb883ac8a30ef43acfd0894796db67b2d1ece9783c9", kill_on_drop: false }`
[INFO] [stdout] 238b5379331cf8b83b99dcb883ac8a30ef43acfd0894796db67b2d1ece9783c9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.90.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 6162131fe068c67aafd199794948bb5678c1806c8b4eecdacf01a80c97554584
[INFO] running `Command { std: "docker" "start" "-a" "6162131fe068c67aafd199794948bb5678c1806c8b4eecdacf01a80c97554584", kill_on_drop: false }`
[INFO] [stderr] warning: method `output` is never used
[INFO] [stderr]    --> src/analyse.rs:157:19
[INFO] [stderr]     |
[INFO] [stderr]  55 | impl Analyse {
[INFO] [stderr]     | ------------ method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 157 |     pub(crate) fn output(&mut self, results: &mut Results, format: Format, summary_only: bool) {
[INFO] [stderr]     |                   ^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait `OutputFormatter` is never used
[INFO] [stderr]   --> src/outputs/mod.rs:10:11
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub trait OutputFormatter {
[INFO] [stderr]    |           ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CodeClimate` is never constructed
[INFO] [stderr]  --> src/outputs/codeclimate.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub struct CodeClimate {}
[INFO] [stderr]   |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Text` is never constructed
[INFO] [stderr]   --> src/outputs/text.rs:12:12
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct Text {}
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated functions `output_files_with_violations` and `output_summary` are never used
[INFO] [stderr]   --> src/outputs/text.rs:34:8
[INFO] [stderr]    |
[INFO] [stderr] 33 | impl Text {
[INFO] [stderr]    | --------- associated functions in this implementation
[INFO] [stderr] 34 |     fn output_files_with_violations(results: &Results) {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 63 |     fn output_summary(results: &Results) {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Json` is never constructed
[INFO] [stderr]  --> src/outputs/json.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct Json {}
[INFO] [stderr]   |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Sarif` is never constructed
[INFO] [stderr]   --> src/outputs/sarif.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub struct Sarif {}
[INFO] [stderr]    |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `description` and `get_detailed_explanation` are never used
[INFO] [stderr]   --> src/rules/mod.rs:38:8
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub trait Rule {
[INFO] [stderr]    |           ---- methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 38 |     fn description(&self) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 44 |     fn get_detailed_explanation(&self) -> Option<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `CODE` is never used
[INFO] [stderr]  --> src/rules/e0.rs:6:8
[INFO] [stderr]   |
[INFO] [stderr] 6 | static CODE: &str = "E0000";
[INFO] [stderr]   |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e0.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `Rule` is never constructed
[INFO] [stderr]  --> src/rules/e0.rs:9:12
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub struct Rule {}
[INFO] [stderr]   |            ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e1.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | static DESCRIPTION: &str = "Opening tag position";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e10.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | static DESCRIPTION: &str = "Npath complexity";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e11.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | static DESCRIPTION: &str = "Detect the error suppression symbol: @";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e12.rs:23:8
[INFO] [stderr]    |
[INFO] [stderr] 23 | static DESCRIPTION: &str = "Service compatibility with Shared Memory Model";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e13.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | static DESCRIPTION: &str = "Private method not being called.";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e2.rs:8:8
[INFO] [stderr]   |
[INFO] [stderr] 8 | static DESCRIPTION: &str = "Empty catch";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e3.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | static DESCRIPTION: &str = "Method modifiers";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e4.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | static DESCRIPTION: &str = "Uppercase constants";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e5.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | static DESCRIPTION: &str = "Capitalized class name";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e6.rs:10:8
[INFO] [stderr]    |
[INFO] [stderr] 10 | static DESCRIPTION: &str = "Property modifiers";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e7.rs:13:8
[INFO] [stderr]    |
[INFO] [stderr] 13 | static DESCRIPTION: &str = "Method parameters count";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e8.rs:10:8
[INFO] [stderr]    |
[INFO] [stderr] 10 | static DESCRIPTION: &str = "Return type signature";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]   --> src/rules/e9.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | static DESCRIPTION: &str = "Cyclomatic complexity";
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/mod.rs:100:44
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&Statement> {
[INFO] [stderr]     |                                            ^^                   ^^                   ---------- the same lifetime is elided here
[INFO] [stderr]     |                                            |                    |
[INFO] [stderr]     |                                            |                    the lifetime is named here
[INFO] [stderr]     |                                            the lifetime is named here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 100 |     fn flatten_statements_to_validate<'a>(&'a self, statement: &'a Statement) -> Vec<&'a Statement> {
[INFO] [stderr]     |                                                                                       ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/mod.rs:107:10
[INFO] [stderr]     |
[INFO] [stderr] 107 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 108 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]     |                                      ^^ the lifetime is named here
[INFO] [stderr] 109 |         statement: &'a Statement,
[INFO] [stderr]     |                     ^^ the lifetime is named here
[INFO] [stderr] 110 |     ) -> Vec<&Statement> {
[INFO] [stderr]     |              ---------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 110 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/mod.rs:135:10
[INFO] [stderr]     |
[INFO] [stderr] 135 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 136 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]     |                                      ^^ the lifetime is named here
[INFO] [stderr] 137 |         statement: &'a Statement,
[INFO] [stderr]     |                     ^^ the lifetime is named here
[INFO] [stderr] 138 |     ) -> Vec<&Statement> {
[INFO] [stderr]     |              ---------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 138 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e1.rs:68:10
[INFO] [stderr]    |
[INFO] [stderr] 68 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 69 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                      ^^ the lifetime is named here
[INFO] [stderr] 70 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 71 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 71 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e10.rs:79:10
[INFO] [stderr]    |
[INFO] [stderr] 79 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 80 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 81 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 82 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 82 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:130:10
[INFO] [stderr]     |
[INFO] [stderr] 130 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 131 |         mut flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]     |                                      ^^ the lifetime is named here
[INFO] [stderr] 132 |         statement: &'a Statement,
[INFO] [stderr]     |                     ^^ the lifetime is named here
[INFO] [stderr] 133 |     ) -> Vec<&Statement> {
[INFO] [stderr]     |              ---------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 133 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:215:10
[INFO] [stderr]     |
[INFO] [stderr] 215 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 216 |         mut flatten_property_expressions: Vec<&'a Expression>,
[INFO] [stderr]     |                                                ^^ the lifetime is named here
[INFO] [stderr] 217 |         expression: &'a Expression,
[INFO] [stderr]     |                      ^^ the lifetime is named here
[INFO] [stderr] 218 |     ) -> Vec<&Expression> {
[INFO] [stderr]     |              ----------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 218 |     ) -> Vec<&'a Expression> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:258:10
[INFO] [stderr]     |
[INFO] [stderr] 258 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 259 |         short_array: &'a ShortArrayExpression,
[INFO] [stderr]     |                       ^^ the lifetime is named here
[INFO] [stderr] 260 |     ) -> Vec<&Expression> {
[INFO] [stderr]     |              ----------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 260 |     ) -> Vec<&'a Expression> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:280:10
[INFO] [stderr]     |
[INFO] [stderr] 280 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 281 |         assignment: &'a AssignmentOperationExpression,
[INFO] [stderr]     |                      ^^ the lifetime is named here
[INFO] [stderr] 282 |     ) -> Vec<&Expression> {
[INFO] [stderr]     |              ----------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 282 |     ) -> Vec<&'a Expression> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:326:10
[INFO] [stderr]     |
[INFO] [stderr] 326 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 327 |         arithmetic: &'a ArithmeticOperationExpression,
[INFO] [stderr]     |                      ^^ the lifetime is named here
[INFO] [stderr] 328 |     ) -> Vec<&Expression> {
[INFO] [stderr]     |              ----------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 328 |     ) -> Vec<&'a Expression> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]    --> src/rules/e12.rs:353:10
[INFO] [stderr]     |
[INFO] [stderr] 353 |         &'a self,
[INFO] [stderr]     |          ^^ the lifetime is named here
[INFO] [stderr] 354 |         method_call: &'a MethodCallExpression,
[INFO] [stderr]     |                       ^^ the lifetime is named here
[INFO] [stderr] 355 |     ) -> Vec<&Expression> {
[INFO] [stderr]     |              ----------- the same lifetime is elided here
[INFO] [stderr]     |
[INFO] [stderr]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]     |
[INFO] [stderr] 355 |     ) -> Vec<&'a Expression> {
[INFO] [stderr]     |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e3.rs:58:10
[INFO] [stderr]    |
[INFO] [stderr] 58 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 59 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 60 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 61 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 61 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e4.rs:45:10
[INFO] [stderr]    |
[INFO] [stderr] 45 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 46 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 47 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 48 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 48 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e5.rs:35:10
[INFO] [stderr]    |
[INFO] [stderr] 35 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 36 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 37 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 38 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 38 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e6.rs:43:10
[INFO] [stderr]    |
[INFO] [stderr] 43 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 44 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 45 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 46 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 46 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e7.rs:86:10
[INFO] [stderr]    |
[INFO] [stderr] 86 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 87 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 88 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 89 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 89 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e8.rs:44:10
[INFO] [stderr]    |
[INFO] [stderr] 44 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 45 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 46 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 47 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 47 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stderr]   --> src/rules/e9.rs:78:10
[INFO] [stderr]    |
[INFO] [stderr] 78 |         &'a self,
[INFO] [stderr]    |          ^^ the lifetime is named here
[INFO] [stderr] 79 |         flatten_statements: Vec<&'a Statement>,
[INFO] [stderr]    |                                  ^^ the lifetime is named here
[INFO] [stderr] 80 |         statement: &'a Statement,
[INFO] [stderr]    |                     ^^ the lifetime is named here
[INFO] [stderr] 81 |     ) -> Vec<&Statement> {
[INFO] [stderr]    |              ---------- the same lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr] help: consistently use `'a`
[INFO] [stderr]    |
[INFO] [stderr] 81 |     ) -> Vec<&'a Statement> {
[INFO] [stderr]    |               ++
[INFO] [stderr] 
[INFO] [stderr] warning: method `description` is never used
[INFO] [stderr]   --> src/rules/mod.rs:38:8
[INFO] [stderr]    |
[INFO] [stderr] 33 | pub trait Rule {
[INFO] [stderr]    |           ---- method in this trait
[INFO] [stderr] ...
[INFO] [stderr] 38 |     fn description(&self) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `phanalist` (lib) generated 42 warnings
[INFO] [stderr] warning: `phanalist` (lib test) generated 41 warnings (40 duplicates)
[INFO] [stderr] warning: static `DESCRIPTION` is never used
[INFO] [stderr]  --> src/rules/e0.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | static DESCRIPTION: &str = "Example rule";
[INFO] [stderr]   |        ^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `phanalist` (bin "phanalist" test) generated 20 warnings (19 duplicates)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.18s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/phanalist-acb03fa9d28566ab)
[INFO] [stdout] 
[INFO] [stdout] running 80 tests
[INFO] [stdout] test analyse::tests::test_filter_active_codes_some_disabled ... ok
[INFO] [stdout] test analyse::tests::test_filter_active_codes_some_enabled_and_disabled ... ok
[INFO] [stdout] test analyse::tests::test_filter_active_codes_some_enabled ... ok
[INFO] [stdout] test analyse::tests::test_filter_active_codes_all_enabled ... ok
[INFO] [stdout] test results::tests::test_add_file_violations_expected_file_violations ... ok
[INFO] [stdout] test results::tests::test_add_file_violations_expected_codes_count ... ok
[INFO] [stdout] test rules::e10::tests::graph_calculate ... ok
[INFO] [stdout] test results::tests::test_has_any_violations_expected_false ... ok
[INFO] [stdout] test rules::e0::tests::example ... ok
[INFO] [stdout] test results::tests::test_has_any_violations_expected_true ... ok
[INFO] [stdout] test rules::e12::tests::define_in_constructor ... ok
[INFO] [stdout] test rules::e12::tests::increment_array_in_method ... ok
[INFO] [stdout] test rules::e12::tests::increment_local_in_method ... ok
[INFO] [stdout] test rules::e12::tests::read_array_null_coalescing_or_null ... ok
[INFO] [stdout] test rules::e12::tests::increment_in_method ... ok
[INFO] [stdout] test rules::e12::tests::read_in_method_call ... ok
[INFO] [stdout] test rules::e12::tests::read_array_null_coalescing_or_array ... ok
[INFO] [stdout] test rules::e12::tests::read_in_return ... ok
[INFO] [stdout] test rules::e12::tests::increment_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::read_local_set ... ok
[INFO] [stdout] test rules::e12::tests::increment_local_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::read_null_coalescing_or_throw ... ok
[INFO] [stdout] test rules::e11::tests::example ... ok
[INFO] [stdout] test rules::e12::tests::set_array_in_method ... ok
[INFO] [stdout] test rules::e12::tests::read_static_null_coalescing_or_throw ... ok
[INFO] [stdout] test rules::e12::tests::set_array_in_null_coalescing ... ok
[INFO] [stdout] test rules::e12::tests::read_static_array_null_coalescing_or_null ... ok
[INFO] [stdout] test rules::e12::tests::read_static_array_null_coalescing_or_array ... ok
[INFO] [stdout] test rules::e12::tests::set_in_assigment ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_catch ... ok
[INFO] [stdout] test rules::e12::tests::set_in_constructor ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_ignore_ns ... ok
[INFO] [stdout] test rules::e12::tests::set_in_return ... ok
[INFO] [stdout] test rules::e12::tests::set_in_null_coalescing ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_try ... ok
[INFO] [stdout] test rules::e12::tests::set_in_return_nested_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_wth_reset_interface ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_finalliy ... ok
[INFO] [stdout] test rules::e12::tests::set_local_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_trait_static_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_trait_method ... ok
[INFO] [stdout] test rules::e1::tests::bin_with_valid_openning_tag ... ok
[INFO] [stdout] test rules::e13::tests::example ... ok
[INFO] [stdout] test rules::e12::tests::set_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::set_local_in_method ... ok
[INFO] [stdout] test rules::e1::tests::full_opening_tag_not_first_line ... ok
[INFO] [stdout] test rules::e1::tests::test_full_opening_tag_not_first_column ... ok
[INFO] [stdout] test rules::e1::tests::full_opening_tag_valid ... ok
[INFO] [stdout] test rules::e1::tests::short_opening_tag_not_first_line ... ok
[INFO] [stdout] test rules::e2::tests::non_empty_catch ... ok
[INFO] [stdout] test rules::e2::tests::empty_catch ... ok
[INFO] [stdout] test rules::e1::tests::short_full_opening_tag_not_first_column ... ok
[INFO] [stdout] test rules::e3::tests::with_modifiers ... ok
[INFO] [stdout] test rules::e4::tests::no_uppercase_constant ... ok
[INFO] [stdout] test rules::e4::tests::uppercase_constant ... ok
[INFO] [stdout] test rules::e5::tests::capitalized_classname ... ok
[INFO] [stdout] test rules::e3::tests::no_constructor_modifier ... ok
[INFO] [stdout] test rules::e6::tests::with_modifiers ... ok
[INFO] [stdout] test rules::e1::tests::short_opening_tag_valid ... ok
[INFO] [stdout] test rules::e7::tests::valid_amount_of_params ... ok
[INFO] [stdout] test rules::e7::tests::constructor_max_params ... ok
[INFO] [stdout] test rules::e5::tests::non_capitalized_classname ... ok
[INFO] [stdout] test rules::e7::tests::method_max_params ... ok
[INFO] [stderr] 
[INFO] [stderr] thread 'rules::e9::tests::complex' has overflowed its stack
[INFO] [stderr] fatal runtime error: stack overflow, aborting
[INFO] [stderr] error: test failed, to rerun pass `--lib`
[INFO] [stderr] 
[INFO] [stderr] Caused by:
[INFO] [stderr]   process didn't exit successfully: `/opt/rustwide/target/debug/deps/phanalist-acb03fa9d28566ab` (signal: 6, SIGABRT: process abort signal)
[INFO] running `Command { std: "docker" "inspect" "6162131fe068c67aafd199794948bb5678c1806c8b4eecdacf01a80c97554584", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6162131fe068c67aafd199794948bb5678c1806c8b4eecdacf01a80c97554584", kill_on_drop: false }`
[INFO] [stdout] 6162131fe068c67aafd199794948bb5678c1806c8b4eecdacf01a80c97554584
