Dec 04 12:17:21.249 INFO checking planet0104/spaceout against try#1df97983eb2057dc6a8f7eb364e263b51ae23230 for pr-56481 Dec 04 12:17:21.250 INFO running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-56481/worker-6/try#1df97983eb2057dc6a8f7eb364e263b51ae23230:/target:rw,Z" "-v" "/mnt/big/crater/work/local/test-source/worker-6/pr-56481/try#1df97983eb2057dc6a8f7eb364e263b51ae23230:/source:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/source" "-e" "USER_ID=1000" "-e" "CMD=cargo +1df97983eb2057dc6a8f7eb364e263b51ae23230-alt check --frozen --all --all-targets" "-e" "CARGO_TARGET_DIR=/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/cargo-home" "-e" "RUSTUP_HOME=/rustup-home" "-m" "1536M" "--network" "none" "crater"` Dec 04 12:17:21.515 INFO [stdout] 884e031147452877164f00a88d898daf588dc78166a9a663275e498c265fbf43 Dec 04 12:17:21.523 INFO running `"docker" "start" "-a" "884e031147452877164f00a88d898daf588dc78166a9a663275e498c265fbf43"` Dec 04 12:17:22.631 INFO [stderr] usermod: no changes Dec 04 12:17:22.667 INFO [stderr] Checking spaceout v0.1.0 (/source) Dec 04 12:17:22.907 INFO [stderr] warning: unused imports: `log_int`, `log_string` Dec 04 12:17:22.907 INFO [stderr] --> src/engine.rs:3:34 Dec 04 12:17:22.907 INFO [stderr] | Dec 04 12:17:22.907 INFO [stderr] 3 | use ::{play_sound, write_string, log_string, log_int, play_music, pause_music}; Dec 04 12:17:22.907 INFO [stderr] | ^^^^^^^^^^ ^^^^^^^ Dec 04 12:17:22.907 INFO [stderr] | Dec 04 12:17:22.907 INFO [stderr] = note: #[warn(unused_imports)] on by default Dec 04 12:17:22.907 INFO [stderr] Dec 04 12:17:23.003 INFO [stderr] warning: unused variable: `canvas_style_height` Dec 04 12:17:23.003 INFO [stderr] --> src/game.rs:359:42 Dec 04 12:17:23.003 INFO [stderr] | Dec 04 12:17:23.003 INFO [stderr] 359 | let (canvas_style_width, canvas_style_height) = Dec 04 12:17:23.003 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ help: consider using `_canvas_style_height` instead Dec 04 12:17:23.003 INFO [stderr] | Dec 04 12:17:23.003 INFO [stderr] = note: #[warn(unused_variables)] on by default Dec 04 12:17:23.003 INFO [stderr] Dec 04 12:17:23.003 INFO [stderr] warning: unused variable: `y` Dec 04 12:17:23.003 INFO [stderr] --> src/game.rs:329:52 Dec 04 12:17:23.003 INFO [stderr] | Dec 04 12:17:23.003 INFO [stderr] 329 | fn on_touch_event(&mut self, event:i32, x:i32, y:i32){ Dec 04 12:17:23.003 INFO [stderr] | ^ help: consider using `_y` instead Dec 04 12:17:23.003 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `contain` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:84:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 84 | pub fn contain(&self, x:i32, y:i32)->bool{ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] = note: #[warn(dead_code)] on by default Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `set_velocity_point` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:305:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 305 | pub fn set_velocity_point(&mut self, velocity:&Point){ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `velocity` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:310:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 310 | pub fn velocity(&self)->&Point{ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `is_point_inside` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:339:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 339 | pub fn is_point_inside(&self, x:i32, y:i32)->bool{ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `hidden` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:363:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 363 | pub fn hidden(&self)->bool{ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: method is never used: `dying` Dec 04 12:17:23.037 INFO [stderr] --> src/sprite.rs:395:5 Dec 04 12:17:23.037 INFO [stderr] | Dec 04 12:17:23.037 INFO [stderr] 395 | pub fn dying(&self)->bool{ Dec 04 12:17:23.037 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.037 INFO [stderr] Dec 04 12:17:23.037 INFO [stderr] warning: field is never used: `fps` Dec 04 12:17:23.038 INFO [stderr] --> src/timer.rs:6:5 Dec 04 12:17:23.038 INFO [stderr] | Dec 04 12:17:23.038 INFO [stderr] 6 | fps:u64, Dec 04 12:17:23.038 INFO [stderr] | ^^^^^^^ Dec 04 12:17:23.038 INFO [stderr] Dec 04 12:17:23.038 INFO [stderr] warning: method is never used: `fps` Dec 04 12:17:23.038 INFO [stderr] --> src/timer.rs:28:5 Dec 04 12:17:23.038 INFO [stderr] | Dec 04 12:17:23.038 INFO [stderr] 28 | pub fn fps(&self)->u64{ Dec 04 12:17:23.038 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.038 INFO [stderr] Dec 04 12:17:23.038 INFO [stderr] warning: method is never used: `start` Dec 04 12:17:23.038 INFO [stderr] --> src/timer.rs:32:5 Dec 04 12:17:23.038 INFO [stderr] | Dec 04 12:17:23.038 INFO [stderr] 32 | pub fn start(&mut self){ Dec 04 12:17:23.038 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.038 INFO [stderr] Dec 04 12:17:23.038 INFO [stderr] warning: field is never used: `width` Dec 04 12:17:23.038 INFO [stderr] --> src/engine.rs:17:5 Dec 04 12:17:23.038 INFO [stderr] | Dec 04 12:17:23.038 INFO [stderr] 17 | width:i32, Dec 04 12:17:23.038 INFO [stderr] | ^^^^^^^^^ Dec 04 12:17:23.038 INFO [stderr] Dec 04 12:17:23.038 INFO [stderr] warning: field is never used: `height` Dec 04 12:17:23.038 INFO [stderr] --> src/engine.rs:18:5 Dec 04 12:17:23.038 INFO [stderr] | Dec 04 12:17:23.038 INFO [stderr] 18 | height:i32, Dec 04 12:17:23.038 INFO [stderr] | ^^^^^^^^^^ Dec 04 12:17:23.038 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: method is never used: `is_point_in_sprite` Dec 04 12:17:23.043 INFO [stderr] --> src/engine.rs:113:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 113 | pub fn is_point_in_sprite(&self, x:i32, y:i32)->Option<&Sprite>{ Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: method is never used: `initialize` Dec 04 12:17:23.043 INFO [stderr] --> src/engine.rs:131:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 131 | pub fn initialize(&mut self)->bool{ Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: method is never used: `end` Dec 04 12:17:23.043 INFO [stderr] --> src/engine.rs:135:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 135 | pub fn end(&self){ Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: field is never used: `last_touch` Dec 04 12:17:23.043 INFO [stderr] --> src/game.rs:68:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 68 | last_touch: Option, Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: field is never used: `drive_left` Dec 04 12:17:23.043 INFO [stderr] --> src/game.rs:69:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 69 | drive_left:i32, Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: field is never used: `drive_right` Dec 04 12:17:23.043 INFO [stderr] --> src/game.rs:70:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 70 | drive_right:i32, Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.043 INFO [stderr] warning: field is never used: `start_time` Dec 04 12:17:23.043 INFO [stderr] --> src/game.rs:71:5 Dec 04 12:17:23.043 INFO [stderr] | Dec 04 12:17:23.043 INFO [stderr] 71 | start_time: f64, Dec 04 12:17:23.043 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 04 12:17:23.043 INFO [stderr] Dec 04 12:17:23.183 INFO [stderr] warning: unused imports: `log_int`, `log_string` Dec 04 12:17:23.183 INFO [stderr] --> src/engine.rs:3:34 Dec 04 12:17:23.183 INFO [stderr] | Dec 04 12:17:23.183 INFO [stderr] 3 | use ::{play_sound, write_string, log_string, log_int, play_music, pause_music}; Dec 04 12:17:23.183 INFO [stderr] | ^^^^^^^^^^ ^^^^^^^ Dec 04 12:17:23.183 INFO [stderr] | Dec 04 12:17:23.183 INFO [stderr] = note: #[warn(unused_imports)] on by default Dec 04 12:17:23.183 INFO [stderr] Dec 04 12:17:23.315 INFO [stderr] warning: unused variable: `canvas_style_height` Dec 04 12:17:23.315 INFO [stderr] --> src/game.rs:359:42 Dec 04 12:17:23.315 INFO [stderr] | Dec 04 12:17:23.315 INFO [stderr] 359 | let (canvas_style_width, canvas_style_height) = Dec 04 12:17:23.315 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^ help: consider using `_canvas_style_height` instead Dec 04 12:17:23.315 INFO [stderr] | Dec 04 12:17:23.315 INFO [stderr] = note: #[warn(unused_variables)] on by default Dec 04 12:17:23.315 INFO [stderr] Dec 04 12:17:23.315 INFO [stderr] warning: unused variable: `y` Dec 04 12:17:23.315 INFO [stderr] --> src/game.rs:329:52 Dec 04 12:17:23.315 INFO [stderr] | Dec 04 12:17:23.315 INFO [stderr] 329 | fn on_touch_event(&mut self, event:i32, x:i32, y:i32){ Dec 04 12:17:23.315 INFO [stderr] | ^ help: consider using `_y` instead Dec 04 12:17:23.315 INFO [stderr] Dec 04 12:17:23.357 INFO [stderr] warning: method is never used: `contain` Dec 04 12:17:23.357 INFO [stderr] --> src/sprite.rs:84:5 Dec 04 12:17:23.358 INFO [stderr] | Dec 04 12:17:23.358 INFO [stderr] 84 | pub fn contain(&self, x:i32, y:i32)->bool{ Dec 04 12:17:23.358 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.358 INFO [stderr] | Dec 04 12:17:23.358 INFO [stderr] = note: #[warn(dead_code)] on by default Dec 04 12:17:23.358 INFO [stderr] Dec 04 12:17:23.358 INFO [stderr] warning: method is never used: `set_velocity_point` Dec 04 12:17:23.359 INFO [stderr] --> src/sprite.rs:305:5 Dec 04 12:17:23.359 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 305 | pub fn set_velocity_point(&mut self, velocity:&Point){ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `velocity` Dec 04 12:17:23.360 INFO [stderr] --> src/sprite.rs:310:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 310 | pub fn velocity(&self)->&Point{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `is_point_inside` Dec 04 12:17:23.360 INFO [stderr] --> src/sprite.rs:339:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 339 | pub fn is_point_inside(&self, x:i32, y:i32)->bool{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `hidden` Dec 04 12:17:23.360 INFO [stderr] --> src/sprite.rs:363:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 363 | pub fn hidden(&self)->bool{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `dying` Dec 04 12:17:23.360 INFO [stderr] --> src/sprite.rs:395:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 395 | pub fn dying(&self)->bool{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `fps` Dec 04 12:17:23.360 INFO [stderr] --> src/timer.rs:6:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 6 | fps:u64, Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `fps` Dec 04 12:17:23.360 INFO [stderr] --> src/timer.rs:28:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 28 | pub fn fps(&self)->u64{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `start` Dec 04 12:17:23.360 INFO [stderr] --> src/timer.rs:32:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 32 | pub fn start(&mut self){ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `width` Dec 04 12:17:23.360 INFO [stderr] --> src/engine.rs:17:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 17 | width:i32, Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `height` Dec 04 12:17:23.360 INFO [stderr] --> src/engine.rs:18:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 18 | height:i32, Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `is_point_in_sprite` Dec 04 12:17:23.360 INFO [stderr] --> src/engine.rs:113:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 113 | pub fn is_point_in_sprite(&self, x:i32, y:i32)->Option<&Sprite>{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `initialize` Dec 04 12:17:23.360 INFO [stderr] --> src/engine.rs:131:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 131 | pub fn initialize(&mut self)->bool{ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: method is never used: `end` Dec 04 12:17:23.360 INFO [stderr] --> src/engine.rs:135:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 135 | pub fn end(&self){ Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `last_touch` Dec 04 12:17:23.360 INFO [stderr] --> src/game.rs:68:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 68 | last_touch: Option, Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `drive_left` Dec 04 12:17:23.360 INFO [stderr] --> src/game.rs:69:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.360 INFO [stderr] 69 | drive_left:i32, Dec 04 12:17:23.360 INFO [stderr] | ^^^^^^^^^^^^^^ Dec 04 12:17:23.360 INFO [stderr] Dec 04 12:17:23.360 INFO [stderr] warning: field is never used: `drive_right` Dec 04 12:17:23.360 INFO [stderr] --> src/game.rs:70:5 Dec 04 12:17:23.360 INFO [stderr] | Dec 04 12:17:23.361 INFO [stderr] 70 | drive_right:i32, Dec 04 12:17:23.361 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 04 12:17:23.361 INFO [stderr] Dec 04 12:17:23.361 INFO [stderr] warning: field is never used: `start_time` Dec 04 12:17:23.361 INFO [stderr] --> src/game.rs:71:5 Dec 04 12:17:23.361 INFO [stderr] | Dec 04 12:17:23.361 INFO [stderr] 71 | start_time: f64, Dec 04 12:17:23.361 INFO [stderr] | ^^^^^^^^^^^^^^^ Dec 04 12:17:23.361 INFO [stderr] Dec 04 12:17:23.415 INFO [stderr] Finished dev [unoptimized + debuginfo] target(s) in 0.76s Dec 04 12:17:23.415 INFO [stderr] su: No module specific data is present Dec 04 12:17:23.816 INFO running `"docker" "inspect" "884e031147452877164f00a88d898daf588dc78166a9a663275e498c265fbf43"` Dec 04 12:17:24.022 INFO running `"docker" "rm" "-f" "884e031147452877164f00a88d898daf588dc78166a9a663275e498c265fbf43"` Dec 04 12:17:24.238 INFO [stdout] 884e031147452877164f00a88d898daf588dc78166a9a663275e498c265fbf43