[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] 836632393998fb590dfa2d63b1851b59705278fc
[INFO] testing denzyldick/phanalist against try#bd7d74411512a3dd3b35d2f699c51dd2557c7e7e+cargoflags=-Zbuild-dir-new-layout for pr-149852-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdenzyldick%2Fphanalist" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/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-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/denzyldick/phanalist on toolchain bd7d74411512a3dd3b35d2f699c51dd2557c7e7e
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "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" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 3738a4f14d1808e971f8e58c409ba5869106db01e65725a19429b906317f2c07
[INFO] running `Command { std: "docker" "start" "-a" "3738a4f14d1808e971f8e58c409ba5869106db01e65725a19429b906317f2c07", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "3738a4f14d1808e971f8e58c409ba5869106db01e65725a19429b906317f2c07", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3738a4f14d1808e971f8e58c409ba5869106db01e65725a19429b906317f2c07", kill_on_drop: false }`
[INFO] [stdout] 3738a4f14d1808e971f8e58c409ba5869106db01e65725a19429b906317f2c07
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "build" "--frozen" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 3f15e704597871e716ab7b13efab3fc29ea31446e75b85dd1aee57fc6623e0e4
[INFO] running `Command { std: "docker" "start" "-a" "3f15e704597871e716ab7b13efab3fc29ea31446e75b85dd1aee57fc6623e0e4", kill_on_drop: false }`
[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 prettyplease v0.2.20
[INFO] [stderr]    Compiling colorchoice v1.0.1
[INFO] [stderr]    Compiling rustversion v1.0.17
[INFO] [stderr]    Compiling anstyle v1.0.7
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling anstyle-parse v0.2.4
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.0
[INFO] [stderr]    Compiling anstyle-query v1.1.0
[INFO] [stderr]    Compiling clap_lex v0.7.1
[INFO] [stderr]    Compiling uriparse v0.6.4
[INFO] [stderr]    Compiling schemars v0.8.21
[INFO] [stderr]    Compiling crossbeam-channel v0.5.15
[INFO] [stderr]    Compiling crossbeam-queue v0.3.11
[INFO] [stderr]    Compiling syn v2.0.71
[INFO] [stderr]    Compiling either v1.13.0
[INFO] [stderr]    Compiling anstream v0.6.14
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling dyn-clone v1.0.17
[INFO] [stderr]    Compiling equivalent v1.0.1
[INFO] [stderr]    Compiling yansi v0.5.1
[INFO] [stderr]    Compiling rayon v1.10.0
[INFO] [stderr]    Compiling csv-core v0.1.11
[INFO] [stderr]    Compiling console v0.15.8
[INFO] [stderr]    Compiling clap_builder v4.5.9
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling ariadne v0.1.5
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling crossbeam v0.8.4
[INFO] [stderr]    Compiling indexmap v2.2.6
[INFO] [stderr]    Compiling indicatif v0.17.8
[INFO] [stderr]    Compiling memory-stats v1.2.0
[INFO] [stderr]    Compiling colored v2.1.0
[INFO] [stderr]    Compiling human_bytes v0.4.3
[INFO] [stderr]    Compiling exitcode v1.1.2
[INFO] [stderr]    Compiling regex-automata v0.4.7
[INFO] [stderr]    Compiling jwalk v0.8.1
[INFO] [stderr]    Compiling cli-table-derive v0.4.6
[INFO] [stderr]    Compiling darling_core v0.20.10
[INFO] [stderr]    Compiling serde_derive_internals v0.29.1
[INFO] [stderr]    Compiling regex v1.10.5
[INFO] [stderr]    Compiling Inflector v0.11.4
[INFO] [stderr]    Compiling serde_derive v1.0.204
[INFO] [stderr]    Compiling schemars_derive v0.8.21
[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 thiserror v1.0.63
[INFO] [stderr]    Compiling clap v4.5.9
[INFO] [stderr]    Compiling darling_macro v0.20.10
[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)]` (part of `#[warn(unused)]`) 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:86
[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:110:14
[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:138:14
[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:71:14
[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:82:14
[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:133:14
[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:218:14
[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:260:14
[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:282:14
[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:328:14
[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:355:14
[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:61:14
[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:48:14
[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:38:14
[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:46:14
[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:89:14
[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:47:14
[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:81:14
[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: unused import: `arg`
[INFO] [stdout]  --> src/main.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | use clap::{arg, Parser};
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[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)]` (part of `#[warn(unused)]`) 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:86
[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:110:14
[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:138:14
[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:71:14
[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:82:14
[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:133:14
[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:218:14
[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:260:14
[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:282:14
[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:328:14
[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:355:14
[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:61:14
[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:48:14
[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:38:14
[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:46:14
[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:89:14
[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:47:14
[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:81:14
[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 56.09s
[INFO] running `Command { std: "docker" "inspect" "3f15e704597871e716ab7b13efab3fc29ea31446e75b85dd1aee57fc6623e0e4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "3f15e704597871e716ab7b13efab3fc29ea31446e75b85dd1aee57fc6623e0e4", kill_on_drop: false }`
[INFO] [stdout] 3f15e704597871e716ab7b13efab3fc29ea31446e75b85dd1aee57fc6623e0e4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "--no-run" "--message-format=json" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] 7630c451dcead6fc151be29538dac109aa617a1d30511bff7276404d73a9ac12
[INFO] running `Command { std: "docker" "start" "-a" "7630c451dcead6fc151be29538dac109aa617a1d30511bff7276404d73a9ac12", 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)]` (part of `#[warn(unused)]`) 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:86
[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:110:14
[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:138:14
[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:71:14
[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:82:14
[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:133:14
[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:218:14
[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:260:14
[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:282:14
[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:328:14
[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:355:14
[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:61:14
[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:48:14
[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] [stderr]    Compiling phanalist v0.1.21 (/opt/rustwide/workdir)
[INFO] [stdout] warning: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e5.rs:38:14
[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:46:14
[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:89:14
[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:47:14
[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:81:14
[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: unused import: `arg`
[INFO] [stdout]  --> src/main.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | use clap::{arg, Parser};
[INFO] [stdout]   |            ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[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)]` (part of `#[warn(unused)]`) 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: 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)]` (part of `#[warn(unused)]`) 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:86
[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:110:14
[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:138:14
[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:71:14
[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:82:14
[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:133:14
[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/mod.rs:100:86
[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/e12.rs:218:14
[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:260:14
[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/mod.rs:110:14
[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/e12.rs:282:14
[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:328:14
[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:355:14
[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/mod.rs:138:14
[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/e3.rs:61:14
[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:48:14
[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:38:14
[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:46:14
[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:89:14
[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:47:14
[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/e1.rs:71:14
[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/e9.rs:81:14
[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: eliding a lifetime that's named elsewhere is confusing
[INFO] [stdout]   --> src/rules/e10.rs:82:14
[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:133:14
[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:218:14
[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:260:14
[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:282:14
[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:328:14
[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:355:14
[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:61:14
[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:48:14
[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:38:14
[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:46:14
[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:89:14
[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:47:14
[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:81:14
[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 4.11s
[INFO] running `Command { std: "docker" "inspect" "7630c451dcead6fc151be29538dac109aa617a1d30511bff7276404d73a9ac12", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7630c451dcead6fc151be29538dac109aa617a1d30511bff7276404d73a9ac12", kill_on_drop: false }`
[INFO] [stdout] 7630c451dcead6fc151be29538dac109aa617a1d30511bff7276404d73a9ac12
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bd7d74411512a3dd3b35d2f699c51dd2557c7e7e" "test" "--frozen" "-Zbuild-dir-new-layout", kill_on_drop: false }`
[INFO] [stdout] f7f05bcc78312a16f40a53f6efdc9484a07fd5d9f7ddb8af00822aef5bffd986
[INFO] running `Command { std: "docker" "start" "-a" "f7f05bcc78312a16f40a53f6efdc9484a07fd5d9f7ddb8af00822aef5bffd986", 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)]` (part of `#[warn(unused)]`) 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:86
[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:110:14
[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:138:14
[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:71:14
[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:82:14
[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:133:14
[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:218:14
[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:260:14
[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:282:14
[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:328:14
[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:355:14
[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:61:14
[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:48:14
[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:38:14
[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:46:14
[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:89:14
[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:47:14
[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:81:14
[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 (run `cargo fix --lib -p phanalist` to apply 18 suggestions)
[INFO] [stderr] warning: `phanalist` (lib test) generated 41 warnings (40 duplicates)
[INFO] [stderr] warning: unused import: `arg`
[INFO] [stderr]  --> src/main.rs:7:12
[INFO] [stderr]   |
[INFO] [stderr] 7 | use clap::{arg, Parser};
[INFO] [stderr]   |            ^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[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]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `phanalist` (bin "phanalist" test) generated 21 warnings (19 duplicates) (run `cargo fix --bin "phanalist" -p phanalist --tests` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.31s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/build/phanalist/90251764c59801ad/deps/phanalist-90251764c59801ad)
[INFO] [stdout] 
[INFO] [stdout] running 80 tests
[INFO] [stdout] test analyse::tests::test_filter_active_codes_all_enabled ... 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_some_disabled ... ok
[INFO] [stdout] test results::tests::test_has_any_violations_expected_false ... ok
[INFO] [stdout] test results::tests::test_add_file_violations_expected_codes_count ... ok
[INFO] [stdout] test results::tests::test_has_any_violations_expected_true ... ok
[INFO] [stdout] test results::tests::test_add_file_violations_expected_file_violations ... ok
[INFO] [stdout] test rules::e10::tests::graph_calculate ... ok
[INFO] [stdout] test rules::e0::tests::example ... ok
[INFO] [stdout] test rules::e11::tests::example ... 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_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_array ... ok
[INFO] [stdout] test rules::e12::tests::increment_local_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::set_array_in_method ... ok
[INFO] [stdout] test rules::e12::tests::set_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_array_null_coalescing_or_null ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_catch ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_finalliy ... ok
[INFO] [stdout] test rules::e12::tests::set_in_assigment ... ok
[INFO] [stdout] test rules::e12::tests::read_in_method_call ... ok
[INFO] [stdout] test rules::e12::tests::read_static_array_null_coalescing_or_null ... ok
[INFO] [stdout] test rules::e12::tests::read_local_set ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_ignore_ns ... ok
[INFO] [stdout] test rules::e12::tests::set_in_null_coalescing ... ok
[INFO] [stdout] test rules::e12::tests::increment_in_static_method ... ok
[INFO] [stdout] test rules::e12::tests::read_null_coalescing_or_throw ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_wth_reset_interface ... ok
[INFO] [stdout] test rules::e12::tests::read_in_return ... ok
[INFO] [stdout] test rules::e12::tests::set_in_trait_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_return ... ok
[INFO] [stdout] test rules::e12::tests::set_in_constructor ... ok
[INFO] [stdout] test rules::e12::tests::set_in_trait_static_method ... ok
[INFO] [stdout] test rules::e12::tests::set_in_method_try ... ok
[INFO] [stdout] test rules::e12::tests::set_local_in_method ... ok
[INFO] [stdout] test rules::e12::tests::read_static_array_null_coalescing_or_array ... ok
[INFO] [stdout] test rules::e12::tests::set_local_in_static_method ... ok
[INFO] [stdout] test rules::e1::tests::bin_with_valid_openning_tag ... ok
[INFO] [stdout] test rules::e12::tests::set_in_return_nested_method ... ok
[INFO] [stdout] test rules::e3::tests::with_modifiers ... ok
[INFO] [stdout] test rules::e3::tests::no_constructor_modifier ... 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::e12::tests::set_in_static_method ... ok
[INFO] [stdout] test rules::e1::tests::short_opening_tag_not_first_line ... ok
[INFO] [stdout] test rules::e5::tests::non_capitalized_classname ... ok
[INFO] [stdout] test rules::e1::tests::short_full_opening_tag_not_first_column ... ok
[INFO] [stdout] test rules::e1::tests::full_opening_tag_valid ... ok
[INFO] [stdout] test rules::e1::tests::full_opening_tag_not_first_line ... ok
[INFO] [stdout] test rules::e13::tests::example ... ok
[INFO] [stdout] test rules::e7::tests::constructor_max_params ... ok
[INFO] [stdout] test rules::e7::tests::method_max_params ... ok
[INFO] [stdout] test rules::e8::tests::no_return_type ... ok
[INFO] [stdout] test rules::e7::tests::valid_amount_of_params ... ok
[INFO] [stdout] test rules::e8::tests::valid_amount_of_params ... ok
[INFO] [stdout] test rules::e1::tests::short_opening_tag_valid ... ok
[INFO] [stdout] test rules::e1::tests::test_full_opening_tag_not_first_column ... ok
[INFO] [stdout] test rules::e2::tests::non_empty_catch ... ok
[INFO] [stdout] test rules::e2::tests::empty_catch ... ok
[INFO] [stdout] test rules::e6::tests::with_modifiers ... ok
[INFO] [stdout] test rules::e6::tests::no_method_modifiers ... ok
[INFO] [stdout] test rules::e3::tests::no_method_modifiers ... ok
[INFO] [stdout] test rules::tests::do_validate_namespace_include_contains ... ok
[INFO] [stdout] test rules::tests::do_validate_namespace_include_not_contains ... ok
[INFO] [stderr] 
[INFO] [stdout] test rules::tests::do_validate_namespace_exclude_not_contains ... ok
[INFO] [stderr] thread 'rules::e9::tests::complex' (94) has overflowed its stack
[INFO] [stdout] test rules::e9::tests::not_complex ... ok
[INFO] [stderr] fatal runtime error: stack overflow, aborting
[INFO] [stdout] test rules::e10::tests::complex ... ok
[INFO] [stdout] test rules::tests::validate_markdown ... ok
[INFO] [stdout] test rules::e9::tests::graph_calculate ... ok
[INFO] [stdout] test rules::tests::do_validate_namespace_empty_include_and_exclude ... ok
[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/build/phanalist/90251764c59801ad/deps/phanalist-90251764c59801ad` (signal: 6, SIGABRT: process abort signal)
[INFO] [stdout] test rules::tests::do_validate_namespace_exclude_contains ... 
[INFO] running `Command { std: "docker" "inspect" "f7f05bcc78312a16f40a53f6efdc9484a07fd5d9f7ddb8af00822aef5bffd986", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f7f05bcc78312a16f40a53f6efdc9484a07fd5d9f7ddb8af00822aef5bffd986", kill_on_drop: false }`
[INFO] [stdout] f7f05bcc78312a16f40a53f6efdc9484a07fd5d9f7ddb8af00822aef5bffd986
