[INFO] cloning repository https://github.com/mengll/ocpc
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/mengll/ocpc" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmengll%2Focpc", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmengll%2Focpc'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7c95572062683bee435aceb2e0f715ee2c5dde5a
[INFO] checking mengll/ocpc/7c95572062683bee435aceb2e0f715ee2c5dde5a against 1.95.0 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmengll%2Focpc" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/mengll/ocpc
[INFO] finished tweaking git repo https://github.com/mengll/ocpc
[INFO] tweaked toml for git repo https://github.com/mengll/ocpc written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/mengll/ocpc on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/mengll/ocpc already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded async-trait v0.1.59
[INFO] [stderr]   Downloaded cookie v0.16.1
[INFO] [stderr]   Downloaded paste v1.0.9
[INFO] [stderr]   Downloaded ipnet v2.6.0
[INFO] [stderr]   Downloaded openssl-sys v0.9.79
[INFO] [stderr]   Downloaded openssl v0.10.44
[INFO] [stderr]   Downloaded redis v0.21.6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 683f0edca28861f662b85461c375f311c0bee1ab808cf71e6b91689d03e01cf6
[INFO] running `Command { std: "docker" "start" "-a" "683f0edca28861f662b85461c375f311c0bee1ab808cf71e6b91689d03e01cf6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "683f0edca28861f662b85461c375f311c0bee1ab808cf71e6b91689d03e01cf6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "683f0edca28861f662b85461c375f311c0bee1ab808cf71e6b91689d03e01cf6", kill_on_drop: false }`
[INFO] [stdout] 683f0edca28861f662b85461c375f311c0bee1ab808cf71e6b91689d03e01cf6
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] f4613b89d6b1d3f6e339174dfb4eb4808b752b3da6eb5a778427df463130d93b
[INFO] running `Command { std: "docker" "start" "-a" "f4613b89d6b1d3f6e339174dfb4eb4808b752b3da6eb5a778427df463130d93b", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.138
[INFO] [stderr]    Compiling proc-macro2 v1.0.47
[INFO] [stderr]    Compiling unicode-ident v1.0.5
[INFO] [stderr]    Compiling quote v1.0.21
[INFO] [stderr]    Compiling syn v1.0.105
[INFO] [stderr]     Checking once_cell v1.16.0
[INFO] [stderr]     Checking itoa v1.0.4
[INFO] [stderr]    Compiling tokio v1.23.0
[INFO] [stderr]    Compiling futures-task v0.3.25
[INFO] [stderr]    Compiling futures-channel v0.3.25
[INFO] [stderr]    Compiling futures-util v0.3.25
[INFO] [stderr]     Checking futures-io v0.3.25
[INFO] [stderr]    Compiling pkg-config v0.3.26
[INFO] [stderr]    Compiling serde_derive v1.0.149
[INFO] [stderr]    Compiling serde v1.0.149
[INFO] [stderr]    Compiling openssl v0.10.44
[INFO] [stderr]     Checking http v0.2.8
[INFO] [stderr]    Compiling native-tls v0.2.11
[INFO] [stderr]     Checking ryu v1.0.11
[INFO] [stderr]     Checking tracing-core v0.1.30
[INFO] [stderr]    Compiling serde_json v1.0.89
[INFO] [stderr]    Compiling paste v1.0.9
[INFO] [stderr]     Checking want v0.3.0
[INFO] [stderr]    Compiling cookie v0.16.1
[INFO] [stderr]    Compiling async-trait v0.1.59
[INFO] [stderr]     Checking time v0.3.17
[INFO] [stderr]     Checking sha1_smol v1.0.0
[INFO] [stderr]     Checking combine v4.6.6
[INFO] [stderr]     Checking ipnet v2.6.0
[INFO] [stderr]     Checking parking_lot_core v0.9.5
[INFO] [stderr]     Checking signal-hook-registry v1.4.0
[INFO] [stderr]     Checking num_cpus v1.14.0
[INFO] [stderr]     Checking mio v0.8.5
[INFO] [stderr]     Checking socket2 v0.4.7
[INFO] [stderr]     Checking getrandom v0.2.8
[INFO] [stderr]     Checking sha1 v0.6.1
[INFO] [stderr]     Checking actix-service v2.0.2
[INFO] [stderr]     Checking http-body v0.4.5
[INFO] [stderr]     Checking tracing v0.1.37
[INFO] [stderr]     Checking parking_lot v0.12.1
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking ahash v0.7.6
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling jobserver v0.1.25
[INFO] [stderr]    Compiling cc v1.0.77
[INFO] [stderr]    Compiling openssl-sys v0.9.79
[INFO] [stderr]    Compiling zstd-sys v2.0.4+zstd.1.5.2
[INFO] [stderr]    Compiling actix-router v0.5.1
[INFO] [stderr]    Compiling tokio-macros v1.8.2
[INFO] [stderr]    Compiling futures-macro v0.3.25
[INFO] [stderr]    Compiling openssl-macros v0.1.0
[INFO] [stderr]    Compiling derive_more v0.99.17
[INFO] [stderr]    Compiling actix-macros v0.2.3
[INFO] [stderr]    Compiling actix-web-codegen v4.1.0
[INFO] [stderr]    Compiling zstd-safe v5.0.2+zstd.1.5.2
[INFO] [stderr]     Checking redis v0.21.6
[INFO] [stderr]     Checking zstd v0.11.2+zstd.1.5.2
[INFO] [stderr]     Checking local-channel v0.1.3
[INFO] [stderr]     Checking futures-executor v0.3.25
[INFO] [stderr]     Checking futures v0.3.25
[INFO] [stderr]     Checking tokio-util v0.7.4
[INFO] [stderr]     Checking actix-rt v2.7.0
[INFO] [stderr]     Checking tokio-native-tls v0.3.0
[INFO] [stderr]     Checking actix-server v2.1.1
[INFO] [stderr]     Checking h2 v0.3.15
[INFO] [stderr]     Checking actix-codec v0.5.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking hyper v0.14.23
[INFO] [stderr]     Checking actix-http v3.2.2
[INFO] [stderr]     Checking actix-web v4.2.1
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.13
[INFO] [stderr]     Checking ocpc v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/media/common/media.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `middler_func` should have an upper camel case name
[INFO] [stdout]   --> src/media/common/media.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 47 | type middler_func = fn(c:MediaReport);
[INFO] [stdout]    |      ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `MiddlerFunc`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RedisError`
[INFO] [stdout]  --> src/media/common/redis.rs:2:51
[INFO] [stdout]   |
[INFO] [stdout] 2 | use redis::{Commands, Connection, FromRedisValue, RedisError, RedisResult};
[INFO] [stdout]   |                                                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::media::common::media::MediaReport`
[INFO] [stdout]  --> src/media/jrtt/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::media::common::media::MediaReport;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HttpRequest`
[INFO] [stdout]  --> src/media/jrtt/jrtt.rs:9:22
[INFO] [stdout]   |
[INFO] [stdout] 9 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `time::macros::date`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use time::macros::date;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MatchFn`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:18:37
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::media::jrtt::{MatchData, MatchFn};
[INFO] [stdout]    |                                     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/media/jrtt/model.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/media/common/media.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `middler_func` should have an upper camel case name
[INFO] [stdout]   --> src/media/common/media.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 47 | type middler_func = fn(c:MediaReport);
[INFO] [stdout]    |      ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `MiddlerFunc`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RedisError`
[INFO] [stdout]  --> src/media/common/redis.rs:2:51
[INFO] [stdout]   |
[INFO] [stdout] 2 | use redis::{Commands, Connection, FromRedisValue, RedisError, RedisResult};
[INFO] [stdout]   |                                                   ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::media::common::media::MediaReport`
[INFO] [stdout]  --> src/media/jrtt/mod.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::media::common::media::MediaReport;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HttpRequest`
[INFO] [stdout]  --> src/media/jrtt/jrtt.rs:9:22
[INFO] [stdout]   |
[INFO] [stdout] 9 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                      ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `time::macros::date`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use time::macros::date;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MatchFn`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:18:37
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crate::media::jrtt::{MatchData, MatchFn};
[INFO] [stdout]    |                                     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/media/jrtt/model.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/gdt/gdt.rs:7:17
[INFO] [stdout]   |
[INFO] [stdout] 7 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/baidu/baidu.rs:7:17
[INFO] [stdout]   |
[INFO] [stdout] 7 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/kuaishou/model.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/uc/model.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/gdt/gdt.rs:7:17
[INFO] [stdout]   |
[INFO] [stdout] 7 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/baidu/baidu.rs:7:17
[INFO] [stdout]   |
[INFO] [stdout] 7 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/kuaishou/model.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `HttpRequest`, `HttpResponse`, `Responder`, `get`, and `web`
[INFO] [stdout]  --> src/media/uc/model.rs:6:17
[INFO] [stdout]   |
[INFO] [stdout] 6 | use actix_web::{get, HttpRequest, HttpResponse, Responder, web};
[INFO] [stdout]   |                 ^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^  ^^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/media/common/media.rs:53:23
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn media_middler<T,U>(a : &dyn Media<RS=T,Err=U>){
[INFO] [stdout]    |                       ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/media/common/redis.rs:10:13
[INFO] [stdout]    |
[INFO] [stdout] 10 |         let mut con = client.get_connection().unwrap();
[INFO] [stdout]    |             ----^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a`
[INFO] [stdout]   --> src/media/common/media.rs:53:23
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn media_middler<T,U>(a : &dyn Media<RS=T,Err=U>){
[INFO] [stdout]    |                       ^ help: if this is intentional, prefix it with an underscore: `_a`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/media/common/redis.rs:10:13
[INFO] [stdout]    |
[INFO] [stdout] 10 |         let mut con = client.get_connection().unwrap();
[INFO] [stdout]    |             ----^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:74:13
[INFO] [stdout]    |
[INFO] [stdout] 74 |         let req = r.build().expect("request is valid");
[INFO] [stdout]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_req`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let res = {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |             let res = {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `req`
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:74:13
[INFO] [stdout]    |
[INFO] [stdout] 74 |         let req = r.build().expect("request is valid");
[INFO] [stdout]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_req`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:118:17
[INFO] [stdout]     |
[INFO] [stdout] 118 |             let res = {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `res`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:130:17
[INFO] [stdout]     |
[INFO] [stdout] 130 |             let res = {
[INFO] [stdout]     |                 ^^^ help: if this is intentional, prefix it with an underscore: `_res`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:151:15
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn match_oaid(m:MatchData)->bool{
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:156:15
[INFO] [stdout]     |
[INFO] [stdout] 156 | fn match_muid(m:MatchData)->bool{
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 | fn match_ip(m:MatchData)->bool {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:166:15
[INFO] [stdout]     |
[INFO] [stdout] 166 | fn match_caid(m:MatchData)->bool {
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:151:15
[INFO] [stdout]     |
[INFO] [stdout] 151 | fn match_oaid(m:MatchData)->bool{
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:156:15
[INFO] [stdout]     |
[INFO] [stdout] 156 | fn match_muid(m:MatchData)->bool{
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:161:13
[INFO] [stdout]     |
[INFO] [stdout] 161 | fn match_ip(m:MatchData)->bool {
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `m`
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:166:15
[INFO] [stdout]     |
[INFO] [stdout] 166 | fn match_caid(m:MatchData)->bool {
[INFO] [stdout]     |               ^ help: if this is intentional, prefix it with an underscore: `_m`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `middler_func` is never used
[INFO] [stdout]   --> src/media/common/media.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 47 | type middler_func = fn(c:MediaReport);
[INFO] [stdout]    |      ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `media_middler` is never used
[INFO] [stdout]   --> src/media/common/media.rs:53:4
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn media_middler<T,U>(a : &dyn Media<RS=T,Err=U>){
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `middler_func` is never used
[INFO] [stdout]   --> src/media/common/media.rs:47:6
[INFO] [stdout]    |
[INFO] [stdout] 47 | type middler_func = fn(c:MediaReport);
[INFO] [stdout]    |      ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/media/jrtt/mod.rs:8:5
[INFO] [stdout]    |
[INFO] [stdout]  7 | struct MatchData<'a> {
[INFO] [stdout]    |        --------- fields in this struct
[INFO] [stdout]  8 |     game_id:i32,               // 游戏包ID
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]  9 |     muid:Option<&'a str>,      // 媒体设备识别
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 10 |     imei_md5:Option<&'a str>,  // 安卓设备的 标识
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 11 |     bd_id:Option<&'a str>,     // 设备的组合ID
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 12 |     oaid_md5:Option<&'a str>,  // 安卓10 以上设备ID
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 13 |     ip:Option<&'a str>,        // ip 地址
[INFO] [stdout]    |     ^^
[INFO] [stdout] 14 |     caid_str:Option<&'a str>   // ios 的设备信息
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MatchData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MatchFn` is never used
[INFO] [stdout]   --> src/media/jrtt/mod.rs:17:6
[INFO] [stdout]    |
[INFO] [stdout] 17 | type MatchFn<'a> = fn(d:MatchData<'a>)->bool;
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `media_middler` is never used
[INFO] [stdout]   --> src/media/common/media.rs:53:4
[INFO] [stdout]    |
[INFO] [stdout] 53 | fn media_middler<T,U>(a : &dyn Media<RS=T,Err=U>){
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Params` is never constructed
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | struct Params {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:27:19
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `tt_get` is never used
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl Jrtt<'_> {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     fn tt_get(&self,ac:i8){
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/media/jrtt/mod.rs:8:5
[INFO] [stdout]    |
[INFO] [stdout]  7 | struct MatchData<'a> {
[INFO] [stdout]    |        --------- fields in this struct
[INFO] [stdout]  8 |     game_id:i32,               // 游戏包ID
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]  9 |     muid:Option<&'a str>,      // 媒体设备识别
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 10 |     imei_md5:Option<&'a str>,  // 安卓设备的 标识
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 11 |     bd_id:Option<&'a str>,     // 设备的组合ID
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 12 |     oaid_md5:Option<&'a str>,  // 安卓10 以上设备ID
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 13 |     ip:Option<&'a str>,        // ip 地址
[INFO] [stdout]    |     ^^
[INFO] [stdout] 14 |     caid_str:Option<&'a str>   // ios 的设备信息
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MatchData` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `MatchFn` is never used
[INFO] [stdout]   --> src/media/jrtt/mod.rs:17:6
[INFO] [stdout]    |
[INFO] [stdout] 17 | type MatchFn<'a> = fn(d:MatchData<'a>)->bool;
[INFO] [stdout]    |      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Params` is never constructed
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:21:8
[INFO] [stdout]    |
[INFO] [stdout] 21 | struct Params {
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:27:19
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `tt_get` is never used
[INFO] [stdout]   --> src/media/jrtt/jrtt.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl Jrtt<'_> {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     fn tt_get(&self,ac:i8){
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `match_caid` is never used
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:166:4
[INFO] [stdout]     |
[INFO] [stdout] 166 | fn match_caid(m:MatchData)->bool {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/gdt/gdt.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `match_caid` is never used
[INFO] [stdout]    --> src/media/jrtt/jrtt.rs:166:4
[INFO] [stdout]     |
[INFO] [stdout] 166 | fn match_caid(m:MatchData)->bool {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/gdt/gdt.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/baidu/baidu.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/kuaishou/model.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/uc/model.rs:11:19
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `haspMap_cache` should have a snake case name
[INFO] [stdout]   --> src/media/common/redis.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub fn haspMap_cache<T,U>(&mut self,key:&str)->HashMap<T,U>
[INFO] [stdout]    |            ^^^^^^^^^^^^^ help: convert the identifier to snake case: `hasp_map_cache`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getOs` should have a snake case name
[INFO] [stdout]  --> src/media/jrtt/model.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn getOs(o:i8)->&'static str {
[INFO] [stdout]   |        ^^^^^ help: convert the identifier to snake case: `get_os`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/baidu/baidu.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/kuaishou/model.rs:10:19
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Jrtt` is never constructed
[INFO] [stdout]   --> src/media/uc/model.rs:11:19
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub(crate) struct Jrtt<'a>(MediaReport<'a>);
[INFO] [stdout]    |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `haspMap_cache` should have a snake case name
[INFO] [stdout]   --> src/media/common/redis.rs:37:12
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub fn haspMap_cache<T,U>(&mut self,key:&str)->HashMap<T,U>
[INFO] [stdout]    |            ^^^^^^^^^^^^^ help: convert the identifier to snake case: `hasp_map_cache`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getOs` should have a snake case name
[INFO] [stdout]  --> src/media/jrtt/model.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn getOs(o:i8)->&'static str {
[INFO] [stdout]   |        ^^^^^ help: convert the identifier to snake case: `get_os`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `post` and `web`
[INFO] [stdout]  --> src/main.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use actix_web::{get, post, web, App, HttpResponse, HttpServer, Responder};
[INFO] [stdout]   |                      ^^^^  ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `post` and `web`
[INFO] [stdout]  --> src/main.rs:1:22
[INFO] [stdout]   |
[INFO] [stdout] 1 | use actix_web::{get, post, web, App, HttpResponse, HttpServer, Responder};
[INFO] [stdout]   |                      ^^^^  ^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 40.00s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: openssl v0.10.44, redis v0.21.6
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 6`
[INFO] running `Command { std: "docker" "inspect" "f4613b89d6b1d3f6e339174dfb4eb4808b752b3da6eb5a778427df463130d93b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "f4613b89d6b1d3f6e339174dfb4eb4808b752b3da6eb5a778427df463130d93b", kill_on_drop: false }`
[INFO] [stdout] f4613b89d6b1d3f6e339174dfb4eb4808b752b3da6eb5a778427df463130d93b
