[INFO] updating cached repository hokora/rust-bot [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/hokora/rust-bot [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/hokora/rust-bot" "work/ex/beta-1.38-1/sources/1.37.0/gh/hokora/rust-bot"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/1.37.0/gh/hokora/rust-bot'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/hokora/rust-bot" "work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/hokora/rust-bot"` [INFO] [stderr] Cloning into 'work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/hokora/rust-bot'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 209260c188fb6e2350c89205b56b98d04f81d936 [INFO] sha for GitHub repo hokora/rust-bot: 209260c188fb6e2350c89205b56b98d04f81d936 [INFO] validating manifest of hokora/rust-bot on toolchain 1.37.0 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of hokora/rust-bot on toolchain beta-2019-08-13 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing hokora/rust-bot [INFO] finished frobbing hokora/rust-bot [INFO] frobbed toml for hokora/rust-bot written to work/ex/beta-1.38-1/sources/1.37.0/gh/hokora/rust-bot/Cargo.toml [INFO] started frobbing hokora/rust-bot [INFO] finished frobbing hokora/rust-bot [INFO] frobbed toml for hokora/rust-bot written to work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/hokora/rust-bot/Cargo.toml [INFO] crate hokora/rust-bot already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+1.37.0" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+beta-2019-08-13" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] testing hokora/rust-bot against beta-2019-08-13 for beta-1.38-1 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-1/beta-2019-08-13:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/hokora/rust-bot:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+beta-2019-08-13" "build" "--frozen"` [INFO] [stdout] 61a8d14a43c67ed0f2dec3ecffbed93b668f05a8a170118260e268dd9511e51d [INFO] running `"docker" "start" "-a" "61a8d14a43c67ed0f2dec3ecffbed93b668f05a8a170118260e268dd9511e51d"` [INFO] [stderr] warning: An explicit [[bin]] section is specified in Cargo.toml which currently [INFO] [stderr] disables Cargo from automatically inferring other binary targets. [INFO] [stderr] This inference behavior will change in the Rust 2018 edition and the following [INFO] [stderr] files will be included as a binary target: [INFO] [stderr] [INFO] [stderr] * /opt/crater/workdir/src/bin/util.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/message_handler.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/parse.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/user.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/colors.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/nyaa.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/irc.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/config.rs [INFO] [stderr] [INFO] [stderr] This is likely to break cargo build or cargo test as these files may not be [INFO] [stderr] ready to be compiled as a binary target today. You can future-proof yourself [INFO] [stderr] and disable this warning by adding `autobins = false` to your [package] [INFO] [stderr] section. You may also move the files to a location where Cargo would not [INFO] [stderr] automatically infer them to be a target, such as in subfolders. [INFO] [stderr] [INFO] [stderr] For more information on this warning you can consult [INFO] [stderr] https://github.com/rust-lang/cargo/issues/5330 [INFO] [stderr] Compiling openssl v0.9.9 [INFO] [stderr] Compiling redis v0.8.0 [INFO] [stderr] Compiling serde v0.9.12 [INFO] [stderr] Compiling openssl-sys v0.9.9 [INFO] [stderr] Compiling quick-xml v0.4.2 [INFO] [stderr] Compiling hyper v0.10.5 [INFO] [stderr] Compiling serde_codegen_internals v0.14.2 [INFO] [stderr] Compiling chrono v0.3.0 [INFO] [stderr] Compiling rss v0.4.0 [INFO] [stderr] Compiling serde_derive v0.9.12 [INFO] [stderr] Compiling native-tls v0.1.1 [INFO] [stderr] Compiling hyper-native-tls v0.2.2 [INFO] [stderr] Compiling serde_json v0.9.9 [INFO] [stderr] Compiling rust-bot v0.1.0 (/opt/crater/workdir) [INFO] [stderr] warning: unused import: `serde` [INFO] [stderr] --> src/lib/bttv.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use serde; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variant `png` should have an upper camel case name [INFO] [stderr] --> src/lib/bttv.rs:30:5 [INFO] [stderr] | [INFO] [stderr] 30 | png, [INFO] [stderr] | ^^^ help: convert the identifier to upper camel case: `Png` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variant `gif` should have an upper camel case name [INFO] [stderr] --> src/lib/bttv.rs:31:5 [INFO] [stderr] | [INFO] [stderr] 31 | gif, [INFO] [stderr] | ^^^ help: convert the identifier to upper camel case: `Gif` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std` [INFO] [stderr] --> src/lib/ffz.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std; [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde` [INFO] [stderr] --> src/lib/ffz.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use serde; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::Read` [INFO] [stderr] --> src/lib/ffz.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::Read; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type `Ffz_json` should have an upper camel case name [INFO] [stderr] --> src/lib/ffz.rs:18:12 [INFO] [stderr] | [INFO] [stderr] 18 | pub struct Ffz_json{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to upper camel case: `FfzJson` [INFO] [stderr] [INFO] [stderr] warning: type `Set_id` should have an upper camel case name [INFO] [stderr] --> src/lib/ffz.rs:23:8 [INFO] [stderr] | [INFO] [stderr] 23 | struct Set_id{ [INFO] [stderr] | ^^^^^^ help: convert the identifier to upper camel case: `SetId` [INFO] [stderr] [INFO] [stderr] warning: the item `chrono` is imported redundantly [INFO] [stderr] --> src/lib/log.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | use chrono; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] ::: src/lib/lib.rs:18:1 [INFO] [stderr] | [INFO] [stderr] 18 | extern crate chrono; [INFO] [stderr] | -------------------- the item `chrono` is already imported here [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/lib/ffz.rs:67:13 [INFO] [stderr] | [INFO] [stderr] 67 | let mut default_sets = try!(v["default_sets"].as_array().ok_or(EmoteError::Json(JsonError::ParseError))); [INFO] [stderr] | ----^^^^^^^^^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_mut)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/lib/twitch.rs:48:13 [INFO] [stderr] | [INFO] [stderr] 48 | let mut sets = match emoticon_sets["0"].as_array(){ [INFO] [stderr] | ----^^^^ [INFO] [stderr] | | [INFO] [stderr] | help: remove this `mut` [INFO] [stderr] [INFO] [stderr] warning: constant item is never used: `GLOBAL_URL` [INFO] [stderr] --> src/lib/twitch.rs:9:1 [INFO] [stderr] | [INFO] [stderr] 9 | const GLOBAL_URL:&'static str = "https://api.twitch.tv/kraken/chat/emoticon_images?emotesets=0"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: field is never used: `http` [INFO] [stderr] --> src/lib/twitch.rs:13:5 [INFO] [stderr] | [INFO] [stderr] 13 | http: &'a http::Http, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: constant item is never used: `TWITCH_SERVER_SSL` [INFO] [stderr] --> src/lib/connection.rs:5:1 [INFO] [stderr] | [INFO] [stderr] 5 | const TWITCH_SERVER_SSL: &'static str = "irc.chat.twitch.tv:443"; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: structure field `imageType` should have a snake case name [INFO] [stderr] --> src/lib/bttv.rs:25:5 [INFO] [stderr] | [INFO] [stderr] 25 | imageType: ImageType, [INFO] [stderr] | ^^^^^^^^^ help: convert the identifier to snake case: `image_type` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_snake_case)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/lib/twitch.rs:44:9 [INFO] [stderr] | [INFO] [stderr] 44 | file.read_to_string(&mut s); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused import: `MessageHandler` [INFO] [stderr] --> src/bin/irc.rs:4:45 [INFO] [stderr] | [INFO] [stderr] 4 | use message_handler::{MessageHandlerBuilder,MessageHandler}; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:194:30 [INFO] [stderr] | [INFO] [stderr] 194 | let name = name_split[0].trim_left_matches(":").to_owned(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:236:30 [INFO] [stderr] | [INFO] [stderr] 236 | let name = name_split[0].trim_left_matches(":"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:319:30 [INFO] [stderr] | [INFO] [stderr] 319 | let name = name_split[0].trim_left_matches(":"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:193:40 [INFO] [stderr] | [INFO] [stderr] 193 | let key = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:194:40 [INFO] [stderr] | [INFO] [stderr] 194 | let val = split[2].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:214:40 [INFO] [stderr] | [INFO] [stderr] 214 | let key = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:279:36 [INFO] [stderr] | [INFO] [stderr] 279 | let cmd = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:302:36 [INFO] [stderr] | [INFO] [stderr] 302 | let cmd = split[1].trim_right(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `usernotice` [INFO] [stderr] --> src/bin/message_handler.rs:136:17 [INFO] [stderr] | [INFO] [stderr] 136 | let usernotice = match parse::handle_usernotice(&raw_message){ [INFO] [stderr] | ^^^^^^^^^^ help: consider prefixing with an underscore: `_usernotice` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `raw_message` [INFO] [stderr] --> src/bin/message_handler.rs:189:42 [INFO] [stderr] | [INFO] [stderr] 189 | fn handle_add_cmd(&mut self,msg:&str,raw_message:&str,name:&str,channel:&str)->bool{ [INFO] [stderr] | ^^^^^^^^^^^ help: consider prefixing with an underscore: `_raw_message` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `raw_message` [INFO] [stderr] --> src/bin/message_handler.rs:210:42 [INFO] [stderr] | [INFO] [stderr] 210 | fn handle_del_cmd(&mut self,msg:&str,raw_message:&str,name:&str,channel:&str)->bool{ [INFO] [stderr] | ^^^^^^^^^^^ help: consider prefixing with an underscore: `_raw_message` [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_action` [INFO] [stderr] --> src/bin/parse.rs:129:5 [INFO] [stderr] | [INFO] [stderr] 129 | pub fn is_action(&self) ->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_mod` [INFO] [stderr] --> src/bin/parse.rs:132:5 [INFO] [stderr] | [INFO] [stderr] 132 | pub fn is_mod(&self)->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_sub` [INFO] [stderr] --> src/bin/parse.rs:135:5 [INFO] [stderr] | [INFO] [stderr] 135 | pub fn is_sub(&self)->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_turbo` [INFO] [stderr] --> src/bin/parse.rs:144:5 [INFO] [stderr] | [INFO] [stderr] 144 | pub fn is_turbo(&self)->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `display_name` [INFO] [stderr] --> src/bin/parse.rs:150:5 [INFO] [stderr] | [INFO] [stderr] 150 | pub fn display_name(&self)->&str{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `message` [INFO] [stderr] --> src/bin/parse.rs:156:5 [INFO] [stderr] | [INFO] [stderr] 156 | pub fn message(&self) -> &str{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `handle_privmsg` [INFO] [stderr] --> src/bin/parse.rs:175:1 [INFO] [stderr] | [INFO] [stderr] 175 | pub fn handle_privmsg(s: &str,ignore_action:bool) -> Result{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function is never used: `combine_hashmap` [INFO] [stderr] --> src/bin/util.rs:27:1 [INFO] [stderr] | [INFO] [stderr] 27 | pub fn combine_hashmap(first:HashMap>,second:HashMap>)->HashMap>{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct is never constructed: `Time` [INFO] [stderr] --> src/bin/util.rs:43:1 [INFO] [stderr] | [INFO] [stderr] 43 | pub struct Time{ [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `new` [INFO] [stderr] --> src/bin/util.rs:50:5 [INFO] [stderr] | [INFO] [stderr] 50 | pub fn new(sec:u64)->Time{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never used: `start_time` [INFO] [stderr] --> src/bin/message_handler.rs:18:5 [INFO] [stderr] | [INFO] [stderr] 18 | start_time: std::time::Instant, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `handle_command_ping` [INFO] [stderr] --> src/bin/message_handler.rs:267:5 [INFO] [stderr] | [INFO] [stderr] 267 | fn handle_command_ping(&mut self,channel:&str)->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `disabled_cmds` [INFO] [stderr] --> src/bin/message_handler.rs:410:5 [INFO] [stderr] | [INFO] [stderr] 410 | pub fn disabled_cmds(mut self,v:Vec)->Self{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method is never used: `is_turbo` [INFO] [stderr] --> src/bin/user.rs:34:5 [INFO] [stderr] | [INFO] [stderr] 34 | pub fn is_turbo(&self)->bool{ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:32:48 [INFO] [stderr] | [INFO] [stderr] 32 | config::ConfigErr::Parse=>{logger.add("Config Parse Error");}, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:33:47 [INFO] [stderr] | [INFO] [stderr] 33 | config::ConfigErr::Read=>{logger.add("Config Read Error");}, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:34:47 [INFO] [stderr] | [INFO] [stderr] 34 | config::ConfigErr::Open=>{logger.add("Config Open Error");}, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:48:17 [INFO] [stderr] | [INFO] [stderr] 48 | logger.add("Could not connect to redis"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:53:13 [INFO] [stderr] | [INFO] [stderr] 53 | logger.add("Could not load commands from redis"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:58:17 [INFO] [stderr] | [INFO] [stderr] 58 | logger.add("Could not clone the socket. Error: "); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/irc.rs:96:17 [INFO] [stderr] | [INFO] [stderr] 96 | logger.add("Could not load colors file"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/nyaa.rs:41:17 [INFO] [stderr] | [INFO] [stderr] 41 | logger.add("first nyaa request could not be done"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/bin/message_handler.rs:166:31 [INFO] [stderr] | [INFO] [stderr] 166 | Some(ref mut l)=>{l.add(s);}, [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 35.02s [INFO] running `"docker" "inspect" "61a8d14a43c67ed0f2dec3ecffbed93b668f05a8a170118260e268dd9511e51d"` [INFO] running `"docker" "rm" "-f" "61a8d14a43c67ed0f2dec3ecffbed93b668f05a8a170118260e268dd9511e51d"` [INFO] [stdout] 61a8d14a43c67ed0f2dec3ecffbed93b668f05a8a170118260e268dd9511e51d [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/beta-1.38-1/worker-1/beta-2019-08-13:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/beta-1.38-1/sources/beta-2019-08-13/gh/hokora/rust-bot:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+beta-2019-08-13" "test" "--frozen" "--no-run"` [INFO] [stdout] 41815698c83f3f308c9cbb86da2da6b2efa5af80326d1dc029924c4fb6d73354 [INFO] running `"docker" "start" "-a" "41815698c83f3f308c9cbb86da2da6b2efa5af80326d1dc029924c4fb6d73354"` [INFO] [stderr] warning: An explicit [[bin]] section is specified in Cargo.toml which currently [INFO] [stderr] disables Cargo from automatically inferring other binary targets. [INFO] [stderr] This inference behavior will change in the Rust 2018 edition and the following [INFO] [stderr] files will be included as a binary target: [INFO] [stderr] [INFO] [stderr] * /opt/crater/workdir/src/bin/util.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/message_handler.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/parse.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/user.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/colors.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/nyaa.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/irc.rs [INFO] [stderr] * /opt/crater/workdir/src/bin/config.rs [INFO] [stderr] [INFO] [stderr] This is likely to break cargo build or cargo test as these files may not be [INFO] [stderr] ready to be compiled as a binary target today. You can future-proof yourself [INFO] [stderr] and disable this warning by adding `autobins = false` to your [package] [INFO] [stderr] section. You may also move the files to a location where Cargo would not [INFO] [stderr] automatically infer them to be a target, such as in subfolders. [INFO] [stderr] [INFO] [stderr] For more information on this warning you can consult [INFO] [stderr] https://github.com/rust-lang/cargo/issues/5330 [INFO] [stderr] Compiling rust-bot v0.1.0 (/opt/crater/workdir) [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `ConfigData` [INFO] [stderr] --> src/bin/config.rs:49:22 [INFO] [stderr] | [INFO] [stderr] 49 | let mut cd = ConfigData::new("tests/config_test.json").unwrap(); [INFO] [stderr] | ^^^^^^^^^^ use of undeclared type or module `ConfigData` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `user` [INFO] [stderr] --> src/bin/parse.rs:432:33 [INFO] [stderr] | [INFO] [stderr] 432 | user:user::User::new("twitchnotify","","twitchnotify",false,""), [INFO] [stderr] | ^^^^ use of undeclared type or module `user` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `user` [INFO] [stderr] --> src/bin/parse.rs:442:33 [INFO] [stderr] | [INFO] [stderr] 442 | user:user::User::new("name","#FF00FF","加",true,"12345"), [INFO] [stderr] | ^^^^ use of undeclared type or module `user` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Type` [INFO] [stderr] --> src/bin/parse.rs:480:13 [INFO] [stderr] | [INFO] [stderr] 480 | Type::Privmsg); [INFO] [stderr] | ^^^^ use of undeclared type or module `Type` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `user` [INFO] [stderr] --> src/bin/parse.rs:491:18 [INFO] [stderr] | [INFO] [stderr] 491 | user:user::User::new("EleGiggle","#008000","加",true,"1337"), [INFO] [stderr] | ^^^^ use of undeclared type or module `user` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Time` [INFO] [stderr] --> src/bin/util.rs:94:20 [INFO] [stderr] | [INFO] [stderr] 94 | let time = Time::new(100000); [INFO] [stderr] | ^^^^ use of undeclared type or module `Time` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Nyaa` [INFO] [stderr] --> src/bin/nyaa.rs:159:9 [INFO] [stderr] | [INFO] [stderr] 159 | Nyaa::new(None).unwrap(); [INFO] [stderr] | ^^^^ use of undeclared type or module `Nyaa` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `http` [INFO] [stderr] --> src/lib/bttv.rs:71:27 [INFO] [stderr] | [INFO] [stderr] 71 | let http_client = http::Http::new().unwrap(); [INFO] [stderr] | ^^^^ use of undeclared type or module `http` [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Color` [INFO] [stderr] --> src/bin/colors.rs:48:22 [INFO] [stderr] | [INFO] [stderr] 48 | let colors = Color::new("colors.txt").unwrap(); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Color` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Emote` [INFO] [stderr] --> src/lib/bttv.rs:72:20 [INFO] [stderr] | [INFO] [stderr] 72 | let bttv = Emote::new(&http_client).unwrap(); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Emote` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `http` [INFO] [stderr] --> src/lib/ffz.rs:90:27 [INFO] [stderr] | [INFO] [stderr] 90 | let http_client = http::Http::new().unwrap(); [INFO] [stderr] | ^^^^ use of undeclared type or module `http` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Emote` [INFO] [stderr] --> src/lib/ffz.rs:91:19 [INFO] [stderr] | [INFO] [stderr] 91 | let ffz = Emote::new(&http_client).unwrap(); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Emote` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `http` [INFO] [stderr] --> src/lib/twitch.rs:65:27 [INFO] [stderr] | [INFO] [stderr] 65 | let http_client = http::Http::new().unwrap(); [INFO] [stderr] | ^^^^ use of undeclared type or module `http` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Emote` [INFO] [stderr] --> src/lib/twitch.rs:66:26 [INFO] [stderr] | [INFO] [stderr] 66 | let mut twitch = Emote::new(&http_client).unwrap(); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Emote` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Loader` [INFO] [stderr] --> src/lib/redis_handler.rs:71:28 [INFO] [stderr] | [INFO] [stderr] 71 | let mut commands = Loader::new().unwrap(); [INFO] [stderr] | ^^^^^^ use of undeclared type or module `Loader` [INFO] [stderr] [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `User` [INFO] [stderr] --> src/bin/user.rs:46:20 [INFO] [stderr] | [INFO] [stderr] 46 | let user = User::new("billy","#000000","billy_h",false,"54321"); [INFO] [stderr] | ^^^^ use of undeclared type or module `User` [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Logger` [INFO] [stderr] --> src/lib/log.rs:56:24 [INFO] [stderr] | [INFO] [stderr] 56 | let mut file = Logger::new("tests/log_test.txt").unwrap(); [INFO] [stderr] | ^^^^^^ use of undeclared type or module `Logger` [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Privmsg` in this scope [INFO] [stderr] --> src/bin/parse.rs:428:20 [INFO] [stderr] | [INFO] [stderr] 428 | assert_eq!(Privmsg{message:"name just subscribed!".to_owned(), [INFO] [stderr] | ^^^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Connection` [INFO] [stderr] --> src/lib/connection.rs:125:19 [INFO] [stderr] | [INFO] [stderr] 125 | let con = Connection::connect(None).unwrap(); [INFO] [stderr] | ^^^^^^^^^^ use of undeclared type or module `Connection` [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Privmsg; [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Type::Privmsg; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `handle_privmsg_tags` in this scope [INFO] [stderr] --> src/bin/parse.rs:433:27 [INFO] [stderr] | [INFO] [stderr] 433 | }, handle_privmsg_tags(&":twitchnotify!twitchnotify@twitchnotify\ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::handle_privmsg_tags; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Privmsg` in this scope [INFO] [stderr] --> src/bin/parse.rs:438:20 [INFO] [stderr] | [INFO] [stderr] 438 | assert_eq!(Privmsg{message:"xD".to_owned(), [INFO] [stderr] | ^^^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Privmsg; [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Type::Privmsg; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `handle_privmsg_tags` in this scope [INFO] [stderr] --> src/bin/parse.rs:443:27 [INFO] [stderr] | [INFO] [stderr] 443 | }, handle_privmsg_tags(&"@badges=admin/1;\ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::handle_privmsg_tags; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Server` in this scope [INFO] [stderr] --> src/bin/parse.rs:462:20 [INFO] [stderr] | [INFO] [stderr] 462 | assert_eq!(Server{message:"Welcome, GLHF!".to_owned(),code:1,name:"name".to_owned() }, [INFO] [stderr] | ^^^^^^ not found in this scope [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Server; [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Type::Server; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `handle_server` in this scope [INFO] [stderr] --> src/bin/parse.rs:463:20 [INFO] [stderr] | [INFO] [stderr] 463 | handle_server(&":tmi.twitch.tv 001 name :Welcome, GLHF!".to_owned()).unwrap()); [INFO] [stderr] | ^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::handle_server; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Unknown` in this scope [INFO] [stderr] --> src/bin/parse.rs:468:20 [INFO] [stderr] | [INFO] [stderr] 468 | assert_eq!(Unknown{raw_message:"PING".to_owned()},handle_unknown(&"PING".to_owned())); [INFO] [stderr] | ^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Type::Unknown; [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Unknown; [INFO] [stderr] | [INFO] [stderr] 1 | use std::fmt::rt::v1::Alignment::Unknown; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `handle_unknown` in this scope [INFO] [stderr] --> src/bin/parse.rs:468:59 [INFO] [stderr] | [INFO] [stderr] 468 | assert_eq!(Unknown{raw_message:"PING".to_owned()},handle_unknown(&"PING".to_owned())); [INFO] [stderr] | ^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::handle_unknown; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `find_type` in this scope [INFO] [stderr] --> src/bin/parse.rs:478:20 [INFO] [stderr] | [INFO] [stderr] 478 | assert_eq!(find_type( [INFO] [stderr] | ^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::find_type; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Usernotice` in this scope [INFO] [stderr] --> src/bin/parse.rs:485:20 [INFO] [stderr] | [INFO] [stderr] 485 | assert_eq!(Usernotice{ [INFO] [stderr] | ^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidates are found in other modules, you can import them into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Type::Usernotice; [INFO] [stderr] | [INFO] [stderr] 1 | use parse::Usernotice; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `handle_usernotice` in this scope [INFO] [stderr] --> src/bin/parse.rs:493:19 [INFO] [stderr] | [INFO] [stderr] 493 | ,handle_usernotice("badges=staff/1,broadcaster/1,turbo/1;\ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use parse::handle_usernotice; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `splitn` in this scope [INFO] [stderr] --> src/bin/util.rs:73:19 [INFO] [stderr] | [INFO] [stderr] 73 | let vec = splitn("my name is",3," ").unwrap(); [INFO] [stderr] | ^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use util::splitn; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `rsplitn` in this scope [INFO] [stderr] --> src/bin/util.rs:81:19 [INFO] [stderr] | [INFO] [stderr] 81 | let vec = rsplitn("Hello;I;Am",2,";").unwrap(); [INFO] [stderr] | ^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use util::rsplitn; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_between` in this scope [INFO] [stderr] --> src/bin/util.rs:88:22 [INFO] [stderr] | [INFO] [stderr] 88 | let secret = parse_between("firstsecretsecond","first","second").unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use util::parse_between; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:160:20 [INFO] [stderr] | [INFO] [stderr] 160 | assert_eq!(Title{anime:"One Room".to_owned(),episode:10},parse_title("[HorribleSubs] One Room - 10 [1080p].mkv".to_owned()).unwrap()); [INFO] [stderr] | ^^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:160:66 [INFO] [stderr] | [INFO] [stderr] 160 | assert_eq!(Title{anime:"One Room".to_owned(),episode:10},parse_title("[HorribleSubs] One Room - 10 [1080p].mkv".to_owned()).unwrap()); [INFO] [stderr] | ^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use nyaa::parse_title; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:161:25 [INFO] [stderr] | [INFO] [stderr] 161 | assert_eq!(true,parse_title("[HorribleSubs] Test - 01 [777p].mkv".to_owned()).is_some()); [INFO] [stderr] | ^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use nyaa::parse_title; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:162:26 [INFO] [stderr] | [INFO] [stderr] 162 | assert_eq!(false,parse_title("[Horri One Room - 10 [1080p].mkv".to_owned()).is_some()); [INFO] [stderr] | ^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use nyaa::parse_title; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:163:26 [INFO] [stderr] | [INFO] [stderr] 163 | assert_eq!(false,parse_title("[Subs] One Room - 10 [1080p].mkv".to_owned()).is_some()); [INFO] [stderr] | ^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use nyaa::parse_title; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `parse_title` in this scope [INFO] [stderr] --> src/bin/nyaa.rs:164:26 [INFO] [stderr] | [INFO] [stderr] 164 | assert_eq!(false,parse_title("[Horri One Room - 10 [108mkv".to_owned()).is_some()); [INFO] [stderr] | ^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use nyaa::parse_title; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `MessageHandler` [INFO] [stderr] --> src/bin/irc.rs:4:45 [INFO] [stderr] | [INFO] [stderr] 4 | use message_handler::{MessageHandlerBuilder,MessageHandler}; [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Connection` [INFO] [stderr] --> src/lib/connection.rs:129:19 [INFO] [stderr] | [INFO] [stderr] 129 | let con = Connection::connect(Some(stream)).unwrap(); [INFO] [stderr] | ^^^^^^^^^^ use of undeclared type or module `Connection` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Timer` [INFO] [stderr] --> src/lib/timer.rs:49:21 [INFO] [stderr] | [INFO] [stderr] 49 | let timer = Timer::new(30); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Timer` [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `Timer` [INFO] [stderr] --> src/lib/timer.rs:57:21 [INFO] [stderr] | [INFO] [stderr] 57 | let timer = Timer::new(30); [INFO] [stderr] | ^^^^^ use of undeclared type or module `Timer` [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `TWITCH_SERVER` in this scope [INFO] [stderr] --> src/lib/connection.rs:127:51 [INFO] [stderr] | [INFO] [stderr] 127 | let stream = std::net::TcpStream::connect(TWITCH_SERVER).unwrap(); [INFO] [stderr] | ^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 1 | use connection::TWITCH_SERVER; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde` [INFO] [stderr] --> src/lib/bttv.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use serde; [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variant `png` should have an upper camel case name [INFO] [stderr] --> src/lib/bttv.rs:30:5 [INFO] [stderr] | [INFO] [stderr] 30 | png, [INFO] [stderr] | ^^^ help: convert the identifier to upper camel case: `Png` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(non_camel_case_types)]` on by default [INFO] [stderr] [INFO] [stderr] warning: variant `gif` should have an upper camel case name [INFO] [stderr] --> src/lib/bttv.rs:31:5 [INFO] [stderr] | [INFO] [stderr] 31 | gif, [INFO] [stderr] | ^^^ help: convert the identifier to upper camel case: `Gif` [INFO] [stderr] [INFO] [stderr] warning: unused import: `std` [INFO] [stderr] --> src/lib/ffz.rs:1:5 [INFO] [stderr] | [INFO] [stderr] 1 | use std; [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `serde` [INFO] [stderr] --> src/lib/ffz.rs:3:5 [INFO] [stderr] | [INFO] [stderr] 3 | use serde; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::Read` [INFO] [stderr] --> src/lib/ffz.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::Read; [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type `Ffz_json` should have an upper camel case name [INFO] [stderr] --> src/lib/ffz.rs:18:12 [INFO] [stderr] | [INFO] [stderr] 18 | pub struct Ffz_json{ [INFO] [stderr] | ^^^^^^^^ help: convert the identifier to upper camel case: `FfzJson` [INFO] [stderr] [INFO] [stderr] warning: type `Set_id` should have an upper camel case name [INFO] [stderr] --> src/lib/ffz.rs:23:8 [INFO] [stderr] | [INFO] [stderr] 23 | struct Set_id{ [INFO] [stderr] | ^^^^^^ help: convert the identifier to upper camel case: `SetId` [INFO] [stderr] [INFO] [stderr] warning: the item `chrono` is imported redundantly [INFO] [stderr] --> src/lib/log.rs:22:13 [INFO] [stderr] | [INFO] [stderr] 22 | use chrono; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] | [INFO] [stderr] ::: src/lib/lib.rs:18:1 [INFO] [stderr] | [INFO] [stderr] 18 | extern crate chrono; [INFO] [stderr] | -------------------- the item `chrono` is already imported here [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:194:30 [INFO] [stderr] | [INFO] [stderr] 194 | let name = name_split[0].trim_left_matches(":").to_owned(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(deprecated)]` on by default [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:236:30 [INFO] [stderr] | [INFO] [stderr] 236 | let name = name_split[0].trim_left_matches(":"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_left_matches': superseded by `trim_start_matches` [INFO] [stderr] --> src/bin/parse.rs:319:30 [INFO] [stderr] | [INFO] [stderr] 319 | let name = name_split[0].trim_left_matches(":"); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_start_matches` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:193:40 [INFO] [stderr] | [INFO] [stderr] 193 | let key = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:194:40 [INFO] [stderr] | [INFO] [stderr] 194 | let val = split[2].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:214:40 [INFO] [stderr] | [INFO] [stderr] 214 | let key = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:279:36 [INFO] [stderr] | [INFO] [stderr] 279 | let cmd = split[1].trim_right().to_owned(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] warning: use of deprecated item 'core::str::::trim_right': superseded by `trim_end` [INFO] [stderr] --> src/bin/message_handler.rs:302:36 [INFO] [stderr] | [INFO] [stderr] 302 | let cmd = split[1].trim_right(); [INFO] [stderr] | ^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end` [INFO] [stderr] [INFO] [stderr] error: aborting due to 29 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0422, E0425, E0433. [INFO] [stderr] For more information about an error, try `rustc --explain E0422`. [INFO] [stderr] error: aborting due to 13 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0425, E0433. [INFO] [stderr] For more information about an error, try `rustc --explain E0425`. [INFO] [stderr] error: Could not compile `rust-bot`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: Could not compile `rust-bot`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "41815698c83f3f308c9cbb86da2da6b2efa5af80326d1dc029924c4fb6d73354"` [INFO] running `"docker" "rm" "-f" "41815698c83f3f308c9cbb86da2da6b2efa5af80326d1dc029924c4fb6d73354"` [INFO] [stdout] 41815698c83f3f308c9cbb86da2da6b2efa5af80326d1dc029924c4fb6d73354