Oct 12 13:35:01.080 INFO checking sirkibsirkib/spellcraft against try#4021bd0b3c5815b087d6db10ce461e7e4854ade7 for pr-54977 Oct 12 13:35:01.080 INFO running `"docker" "create" "-v" "/mnt/big/crater/./work/local/target-dirs/pr-54977/worker-3/try#4021bd0b3c5815b087d6db10ce461e7e4854ade7:/target:rw,Z" "-v" "/mnt/big/crater/./work/local/test-source/worker-3/pr-54977/try#4021bd0b3c5815b087d6db10ce461e7e4854ade7:/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 +4021bd0b3c5815b087d6db10ce461e7e4854ade7-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"` Oct 12 13:35:01.663 INFO blam! d44882be5e935f697a3b5056a55baa1019be9918177632e0216887b0086f9b49 Oct 12 13:35:01.664 INFO running `"docker" "start" "-a" "d44882be5e935f697a3b5056a55baa1019be9918177632e0216887b0086f9b49"` Oct 12 13:35:03.428 INFO kablam! usermod: no changes Oct 12 13:35:03.760 INFO kablam! Compiling num-traits v0.1.42 Oct 12 13:35:03.768 INFO kablam! Compiling rand v0.3.20 Oct 12 13:35:03.776 INFO kablam! Checking tempfile v2.2.0 Oct 12 13:35:03.776 INFO kablam! Checking rayon-core v1.3.0 Oct 12 13:35:03.776 INFO kablam! Checking piston2d-graphics v0.21.1 Oct 12 13:35:03.776 INFO kablam! Checking rusttype v0.2.3 Oct 12 13:35:03.776 INFO kablam! Compiling gl_generator v0.7.0 Oct 12 13:35:06.818 INFO kablam! Compiling gl_generator v0.5.5 Oct 12 13:35:09.644 INFO kablam! Compiling gl_generator v0.6.1 Oct 12 13:35:11.772 INFO kablam! Checking gfx_core v0.7.2 Oct 12 13:35:12.045 INFO kablam! Checking rayon v0.8.2 Oct 12 13:35:15.822 INFO kablam! Checking num-integer v0.1.35 Oct 12 13:35:16.875 INFO kablam! Checking enum_primitive v0.1.1 Oct 12 13:35:26.122 INFO kablam! Checking pistoncore-input v0.19.0 Oct 12 13:35:26.241 INFO kablam! Compiling serde_json v0.9.10 Oct 12 13:35:26.274 INFO kablam! Checking num-iter v0.1.34 Oct 12 13:35:26.276 INFO kablam! Checking num-rational v0.1.41 Oct 12 13:35:26.622 INFO kablam! Compiling phf_generator v0.7.21 Oct 12 13:35:27.509 INFO kablam! Compiling glutin v0.9.2 Oct 12 13:35:28.198 INFO kablam! Compiling gfx_gl v0.4.0 Oct 12 13:35:29.132 INFO kablam! Compiling gl v0.6.5 Oct 12 13:35:29.272 INFO kablam! Checking png v0.9.0 Oct 12 13:35:44.048 INFO kablam! Compiling phf_codegen v0.7.21 Oct 12 13:35:44.072 INFO kablam! Checking jpeg-decoder v0.1.13 Oct 12 13:35:45.952 INFO kablam! Compiling target_build_utils v0.3.1 Oct 12 13:35:46.105 INFO kablam! Checking pistoncore-window v0.28.0 Oct 12 13:35:49.876 INFO kablam! Checking pistoncore-event_loop v0.33.0 Oct 12 13:35:53.609 INFO kablam! Checking image v0.15.0 Oct 12 13:35:55.206 INFO kablam! Checking piston v0.33.0 Oct 12 13:36:22.852 INFO kablam! Compiling libloading v0.3.4 Oct 12 13:36:26.394 INFO kablam! Checking dlib v0.3.1 Oct 12 13:36:26.873 INFO kablam! Checking wayland-sys v0.9.10 Oct 12 13:36:27.584 INFO kablam! Checking wayland-client v0.9.10 Oct 12 13:36:30.473 INFO kablam! Checking wayland-protocols v0.9.10 Oct 12 13:36:30.473 INFO kablam! Checking wayland-kbd v0.9.1 Oct 12 13:36:35.236 INFO kablam! Checking wayland-window v0.7.0 Oct 12 13:36:36.412 INFO kablam! Checking winit v0.7.6 Oct 12 13:36:41.770 INFO kablam! Checking pistoncore-glutin_window v0.39.1 Oct 12 13:36:47.027 INFO kablam! Checking gfx v0.16.3 Oct 12 13:36:47.027 INFO kablam! Checking gfx_device_gl v0.14.6 Oct 12 13:36:54.661 INFO kablam! Checking piston-gfx_texture v0.26.0 Oct 12 13:36:56.073 INFO kablam! Checking piston2d-gfx_graphics v0.43.0 Oct 12 13:36:58.943 INFO kablam! Checking piston_window v0.70.0 Oct 12 13:37:00.374 INFO kablam! Checking spellcraft v0.1.0 (/source) Oct 12 13:37:02.821 INFO kablam! warning: unused import: `HashSet` Oct 12 13:37:02.821 INFO kablam! --> src/play.rs:1:34 Oct 12 13:37:02.821 INFO kablam! | Oct 12 13:37:02.821 INFO kablam! 1 | use ::std::collections::{HashMap,HashSet}; Oct 12 13:37:02.821 INFO kablam! | ^^^^^^^ Oct 12 13:37:02.822 INFO kablam! | Oct 12 13:37:02.822 INFO kablam! = note: #[warn(unused_imports)] on by default Oct 12 13:37:02.822 INFO kablam! Oct 12 13:37:02.823 INFO kablam! warning: unused import: `SeedableRng` Oct 12 13:37:02.823 INFO kablam! --> src/play.rs:5:27 Oct 12 13:37:02.823 INFO kablam! | Oct 12 13:37:02.824 INFO kablam! 5 | use rand::{Rng,Isaac64Rng,SeedableRng}; Oct 12 13:37:02.824 INFO kablam! | ^^^^^^^^^^^ Oct 12 13:37:02.824 INFO kablam! Oct 12 13:37:02.831 INFO kablam! warning: unused import: `self::Setting::*` Oct 12 13:37:02.831 INFO kablam! --> src/wasd_set.rs:70:13 Oct 12 13:37:02.832 INFO kablam! | Oct 12 13:37:02.832 INFO kablam! 70 | use self::Setting::*; Oct 12 13:37:02.832 INFO kablam! | ^^^^^^^^^^^^^^^^ Oct 12 13:37:02.832 INFO kablam! Oct 12 13:37:03.031 INFO kablam! warning: unused import: `HashSet` Oct 12 13:37:03.031 INFO kablam! --> src/play.rs:1:34 Oct 12 13:37:03.032 INFO kablam! | Oct 12 13:37:03.033 INFO kablam! 1 | use ::std::collections::{HashMap,HashSet}; Oct 12 13:37:03.033 INFO kablam! | ^^^^^^^ Oct 12 13:37:03.034 INFO kablam! | Oct 12 13:37:03.034 INFO kablam! = note: #[warn(unused_imports)] on by default Oct 12 13:37:03.034 INFO kablam! Oct 12 13:37:03.035 INFO kablam! warning: unused import: `SeedableRng` Oct 12 13:37:03.035 INFO kablam! --> src/play.rs:5:27 Oct 12 13:37:03.035 INFO kablam! | Oct 12 13:37:03.035 INFO kablam! 5 | use rand::{Rng,Isaac64Rng,SeedableRng}; Oct 12 13:37:03.035 INFO kablam! | ^^^^^^^^^^^ Oct 12 13:37:03.036 INFO kablam! Oct 12 13:37:03.053 INFO kablam! warning: unused import: `self::Setting::*` Oct 12 13:37:03.053 INFO kablam! --> src/wasd_set.rs:70:13 Oct 12 13:37:03.054 INFO kablam! | Oct 12 13:37:03.055 INFO kablam! 70 | use self::Setting::*; Oct 12 13:37:03.055 INFO kablam! | ^^^^^^^^^^^^^^^^ Oct 12 13:37:03.056 INFO kablam! Oct 12 13:37:04.182 INFO kablam! warning: private type `play::ConcreteResource` in public interface (error E0446) Oct 12 13:37:04.183 INFO kablam! --> src/play.rs:765:5 Oct 12 13:37:04.184 INFO kablam! | Oct 12 13:37:04.184 INFO kablam! 765 | / pub fn try_remove_resources(&mut self, r_left: &[ConcreteResource]) -> bool { Oct 12 13:37:04.185 INFO kablam! 766 | | let mut total_mana = 0; Oct 12 13:37:04.186 INFO kablam! 767 | | let mut total_health = 0; Oct 12 13:37:04.186 INFO kablam! 768 | | let mut total_buffs = HashMap::new(); Oct 12 13:37:04.187 INFO kablam! ... | Oct 12 13:37:04.187 INFO kablam! 802 | | } else { false } Oct 12 13:37:04.196 INFO kablam! 803 | | } Oct 12 13:37:04.197 INFO kablam! | |_____^ Oct 12 13:37:04.197 INFO kablam! | Oct 12 13:37:04.198 INFO kablam! = note: #[warn(private_in_public)] on by default Oct 12 13:37:04.198 INFO kablam! = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release! Oct 12 13:37:04.198 INFO kablam! = note: for more information, see issue #34537 Oct 12 13:37:04.198 INFO kablam! Oct 12 13:37:04.207 INFO kablam! warning: value assigned to `screen_pt` is never read Oct 12 13:37:04.207 INFO kablam! --> src/play.rs:887:13 Oct 12 13:37:04.207 INFO kablam! | Oct 12 13:37:04.207 INFO kablam! 887 | let mut screen_pt: [f64;2] = [0., 0.]; Oct 12 13:37:04.207 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.207 INFO kablam! | Oct 12 13:37:04.207 INFO kablam! = note: #[warn(unused_assignments)] on by default Oct 12 13:37:04.207 INFO kablam! Oct 12 13:37:04.207 INFO kablam! warning: unused variable: `x` Oct 12 13:37:04.207 INFO kablam! --> src/play.rs:963:17 Oct 12 13:37:04.208 INFO kablam! | Oct 12 13:37:04.208 INFO kablam! 963 | x => (),//TODO Oct 12 13:37:04.208 INFO kablam! | ^ help: consider using `_x` instead Oct 12 13:37:04.208 INFO kablam! | Oct 12 13:37:04.210 INFO kablam! = note: #[warn(unused_variables)] on by default Oct 12 13:37:04.210 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `x` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:973:17 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 973 | x => (),//TODO Oct 12 13:37:04.211 INFO kablam! | ^ help: consider using `_x` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:1021:15 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 1021 | for (&tok, &(ref pt, ref player)) in space.players.iter() { Oct 12 13:37:04.211 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `player` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:1021:34 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 1021 | for (&tok, &(ref pt, ref player)) in space.players.iter() { Oct 12 13:37:04.211 INFO kablam! | ^^^^^^ help: consider using `_player` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:1028:15 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 1028 | for (&tok, &(ref pt, ref player)) in space.projectiles.iter() { Oct 12 13:37:04.211 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `player` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:1028:34 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 1028 | for (&tok, &(ref pt, ref player)) in space.projectiles.iter() { Oct 12 13:37:04.211 INFO kablam! | ^^^^^^ help: consider using `_player` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: value assigned to `z` is never read Oct 12 13:37:04.211 INFO kablam! --> src/generate.rs:132:33 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 132 | let mut z = discrete(rng, counter, depth_left-1, slots, DiscreteContext::Threeish); Oct 12 13:37:04.211 INFO kablam! | ^ Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: value assigned to `est` is never read Oct 12 13:37:04.211 INFO kablam! --> src/generate.rs:133:33 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 133 | let mut est = 0.; Oct 12 13:37:04.211 INFO kablam! | ^^^ Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:71:15 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 71 | for (&tok, &mut (ref mut pt, ref mut player)) in self.players.iter_mut() { Oct 12 13:37:04.211 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `stacks` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:72:39 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 72 | for (&buff, &mut (ref mut stacks, ref mut left)) in player.buffs.iter_mut() { Oct 12 13:37:04.211 INFO kablam! | ^^^^^^ help: consider using `_stacks` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `rsrc` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:311:39 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 311 | &AddResource(ref ent, ref rsrc) => { Oct 12 13:37:04.211 INFO kablam! | ^^^^ help: consider using `_rsrc` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `token` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:312:21 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 312 | let token = self.eval_entity(rng, ctx, ent); Oct 12 13:37:04.211 INFO kablam! | ^^^^^ help: consider using `_token` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `trigger_event` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:332:41 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 332 | fn destroy(&mut self, token: Token, trigger_event: bool) -> bool { Oct 12 13:37:04.211 INFO kablam! | ^^^^^^^^^^^^^ help: consider using `_trigger_event` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.211 INFO kablam! warning: unused variable: `projectile` Oct 12 13:37:04.211 INFO kablam! --> src/play.rs:429:36 Oct 12 13:37:04.211 INFO kablam! | Oct 12 13:37:04.211 INFO kablam! 429 | } else if let Some(projectile) = self.projectiles.get(&tok) { Oct 12 13:37:04.211 INFO kablam! | ^^^^^^^^^^ help: consider using `_projectile` instead Oct 12 13:37:04.211 INFO kablam! Oct 12 13:37:04.260 INFO kablam! warning: private type `play::ConcreteResource` in public interface (error E0446) Oct 12 13:37:04.260 INFO kablam! --> src/play.rs:765:5 Oct 12 13:37:04.260 INFO kablam! | Oct 12 13:37:04.260 INFO kablam! 765 | / pub fn try_remove_resources(&mut self, r_left: &[ConcreteResource]) -> bool { Oct 12 13:37:04.260 INFO kablam! 766 | | let mut total_mana = 0; Oct 12 13:37:04.260 INFO kablam! 767 | | let mut total_health = 0; Oct 12 13:37:04.260 INFO kablam! 768 | | let mut total_buffs = HashMap::new(); Oct 12 13:37:04.260 INFO kablam! ... | Oct 12 13:37:04.260 INFO kablam! 802 | | } else { false } Oct 12 13:37:04.260 INFO kablam! 803 | | } Oct 12 13:37:04.260 INFO kablam! | |_____^ Oct 12 13:37:04.260 INFO kablam! | Oct 12 13:37:04.260 INFO kablam! = note: #[warn(private_in_public)] on by default Oct 12 13:37:04.260 INFO kablam! = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release! Oct 12 13:37:04.260 INFO kablam! = note: for more information, see issue #34537 Oct 12 13:37:04.261 INFO kablam! Oct 12 13:37:04.285 INFO kablam! warning: value assigned to `screen_pt` is never read Oct 12 13:37:04.285 INFO kablam! --> src/play.rs:887:13 Oct 12 13:37:04.285 INFO kablam! | Oct 12 13:37:04.285 INFO kablam! 887 | let mut screen_pt: [f64;2] = [0., 0.]; Oct 12 13:37:04.285 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.285 INFO kablam! | Oct 12 13:37:04.292 INFO kablam! = note: #[warn(unused_assignments)] on by default Oct 12 13:37:04.292 INFO kablam! Oct 12 13:37:04.292 INFO kablam! warning: unused variable: `x` Oct 12 13:37:04.292 INFO kablam! --> src/play.rs:963:17 Oct 12 13:37:04.292 INFO kablam! | Oct 12 13:37:04.292 INFO kablam! 963 | x => (),//TODO Oct 12 13:37:04.292 INFO kablam! | ^ help: consider using `_x` instead Oct 12 13:37:04.292 INFO kablam! | Oct 12 13:37:04.292 INFO kablam! = note: #[warn(unused_variables)] on by default Oct 12 13:37:04.295 INFO kablam! Oct 12 13:37:04.295 INFO kablam! warning: unused variable: `x` Oct 12 13:37:04.295 INFO kablam! --> src/play.rs:973:17 Oct 12 13:37:04.295 INFO kablam! | Oct 12 13:37:04.295 INFO kablam! 973 | x => (),//TODO Oct 12 13:37:04.295 INFO kablam! | ^ help: consider using `_x` instead Oct 12 13:37:04.295 INFO kablam! Oct 12 13:37:04.308 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:1021:15 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 1021 | for (&tok, &(ref pt, ref player)) in space.players.iter() { Oct 12 13:37:04.309 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `player` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:1021:34 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 1021 | for (&tok, &(ref pt, ref player)) in space.players.iter() { Oct 12 13:37:04.309 INFO kablam! | ^^^^^^ help: consider using `_player` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:1028:15 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 1028 | for (&tok, &(ref pt, ref player)) in space.projectiles.iter() { Oct 12 13:37:04.309 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `player` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:1028:34 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 1028 | for (&tok, &(ref pt, ref player)) in space.projectiles.iter() { Oct 12 13:37:04.309 INFO kablam! | ^^^^^^ help: consider using `_player` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: value assigned to `z` is never read Oct 12 13:37:04.309 INFO kablam! --> src/generate.rs:132:33 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 132 | let mut z = discrete(rng, counter, depth_left-1, slots, DiscreteContext::Threeish); Oct 12 13:37:04.309 INFO kablam! | ^ Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: value assigned to `est` is never read Oct 12 13:37:04.309 INFO kablam! --> src/generate.rs:133:33 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 133 | let mut est = 0.; Oct 12 13:37:04.309 INFO kablam! | ^^^ Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `tok` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:71:15 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 71 | for (&tok, &mut (ref mut pt, ref mut player)) in self.players.iter_mut() { Oct 12 13:37:04.309 INFO kablam! | ^^^ help: consider using `_tok` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `stacks` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:72:39 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 72 | for (&buff, &mut (ref mut stacks, ref mut left)) in player.buffs.iter_mut() { Oct 12 13:37:04.309 INFO kablam! | ^^^^^^ help: consider using `_stacks` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `rsrc` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:311:39 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 311 | &AddResource(ref ent, ref rsrc) => { Oct 12 13:37:04.309 INFO kablam! | ^^^^ help: consider using `_rsrc` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `token` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:312:21 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 312 | let token = self.eval_entity(rng, ctx, ent); Oct 12 13:37:04.309 INFO kablam! | ^^^^^ help: consider using `_token` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `trigger_event` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:332:41 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 332 | fn destroy(&mut self, token: Token, trigger_event: bool) -> bool { Oct 12 13:37:04.309 INFO kablam! | ^^^^^^^^^^^^^ help: consider using `_trigger_event` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.309 INFO kablam! warning: unused variable: `projectile` Oct 12 13:37:04.309 INFO kablam! --> src/play.rs:429:36 Oct 12 13:37:04.309 INFO kablam! | Oct 12 13:37:04.309 INFO kablam! 429 | } else if let Some(projectile) = self.projectiles.get(&tok) { Oct 12 13:37:04.309 INFO kablam! | ^^^^^^^^^^ help: consider using `_projectile` instead Oct 12 13:37:04.309 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: field is never used: `bp` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:19:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 19 | bp: Rc, Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! = note: #[warn(dead_code)] on by default Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: field is never used: `caster` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:20:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 20 | caster: Token, Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: field is never used: `pos` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:21:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 21 | pos: Point, Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: method is never used: `pt_of_player` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:129:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 129 | pub fn pt_of_player(&self, token: Token) -> Option { Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: method is never used: `player_leave` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:241:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 241 | pub fn player_leave(&mut self, token: Token) -> Option<(Point, Player)> { Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: method is never used: `is_player` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:247:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 247 | pub fn is_player(&self, token: Token) -> bool { Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: method is never used: `is_projectile` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:251:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 251 | pub fn is_projectile(&self, token: Token) -> bool { Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.715 INFO kablam! warning: method is never used: `apply_stacks` Oct 12 13:37:04.715 INFO kablam! --> src/play.rs:829:5 Oct 12 13:37:04.715 INFO kablam! | Oct 12 13:37:04.715 INFO kablam! 829 | pub fn apply_stacks(&mut self, buff: Buff, stacks: u8, duration: f32) { Oct 12 13:37:04.715 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.715 INFO kablam! Oct 12 13:37:04.721 INFO kablam! warning: variant is never constructed: `TowardLocation` Oct 12 13:37:04.721 INFO kablam! --> src/magic.rs:41:5 Oct 12 13:37:04.721 INFO kablam! | Oct 12 13:37:04.721 INFO kablam! 41 | TowardLocation(Location, Location), Oct 12 13:37:04.721 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.721 INFO kablam! Oct 12 13:37:04.732 INFO kablam! warning: variant is never constructed: `Mute` Oct 12 13:37:04.732 INFO kablam! --> src/buffs.rs:5:5 Oct 12 13:37:04.732 INFO kablam! | Oct 12 13:37:04.732 INFO kablam! 5 | Mute, // can't cast spells Oct 12 13:37:04.732 INFO kablam! | ^^^^ Oct 12 13:37:04.732 INFO kablam! Oct 12 13:37:04.732 INFO kablam! warning: variant is never constructed: `Wet` Oct 12 13:37:04.732 INFO kablam! --> src/buffs.rs:6:5 Oct 12 13:37:04.732 INFO kablam! | Oct 12 13:37:04.732 INFO kablam! 6 | Wet, // electric damage taken increased Oct 12 13:37:04.732 INFO kablam! | ^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Stealth` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:7:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 7 | Stealth, // Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Wary` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:10:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 10 | Wary, // applies `Tired` when removed. reduces projectile damage Oct 12 13:37:04.733 INFO kablam! | ^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Wise` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:11:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 11 | Wise, // increased max mana Oct 12 13:37:04.733 INFO kablam! | ^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Unpredictable` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:12:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 12 | Unpredictable, // Cancels stacks with any other buff Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Resolute` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:13:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 13 | Resolute, // forces applied dampened. `Tired` has no effect. Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Calm` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:14:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 14 | Calm, // Panic will not apply tired. Movement increased if below 100% Oct 12 13:37:04.733 INFO kablam! | ^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Steady` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:15:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 15 | Steady, // removes Panicked if it has < stacks Oct 12 13:37:04.733 INFO kablam! | ^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Panicked` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:16:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 16 | Panicked, // movement speed increased. applies `Tired` when removed Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Dizzy` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:19:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 19 | Dizzy, // spell positions randomized slightly Oct 12 13:37:04.733 INFO kablam! | ^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Tired` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:20:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 20 | Tired, // movement slowed. ticks down ONLY when not moving Oct 12 13:37:04.733 INFO kablam! | ^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Confused` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:21:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 21 | Confused, // spell cast effects INSTEAD remove one stack of confused Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Drained` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:22:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 22 | Drained, // Max mana reduced by 30 Oct 12 13:37:04.733 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Weary` Oct 12 13:37:04.733 INFO kablam! --> src/buffs.rs:23:5 Oct 12 13:37:04.733 INFO kablam! | Oct 12 13:37:04.733 INFO kablam! 23 | Weary, // spell casts take 20% more time Oct 12 13:37:04.733 INFO kablam! | ^^^^^ Oct 12 13:37:04.733 INFO kablam! Oct 12 13:37:04.733 INFO kablam! warning: variant is never constructed: `Bleeding` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:26:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 26 | Bleeding, // takes DoT. every 5 stacks of Bleeding are replaced with 1 stack of hemorrhage. Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Hemorrhage` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:27:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 27 | Hemorrhage, // take DoT. maintains equivalent Bleed stacks. Cap is 3. Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Bruised` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:28:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 28 | Bruised, // Tough.S + Bruised.S <= 5. Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Limping` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:29:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 29 | Limping, // movement controls become intermittently slowed Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Delicate` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:30:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 30 | Delicate, // increased DoT taken Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Tough` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:33:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 33 | Tough, // damage taken > 20% of health is reduced by 10% Oct 12 13:37:04.734 INFO kablam! | ^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Hot` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:35:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 35 | Hot, Oct 12 13:37:04.734 INFO kablam! | ^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Burning` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:36:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 36 | Burning, // DoT Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Warm` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:38:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 38 | Warm, // cancels COLD buffs Oct 12 13:37:04.734 INFO kablam! | ^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Shivering` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:41:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 41 | Shivering, // Periodically interrupts spellcasting Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Cool` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:43:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 43 | Cool, // Cancels HOT buffs Oct 12 13:37:04.734 INFO kablam! | ^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Poisoned` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:48:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 48 | Poisoned, Oct 12 13:37:04.734 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.734 INFO kablam! Oct 12 13:37:04.734 INFO kablam! warning: variant is never constructed: `Refreshed` Oct 12 13:37:04.734 INFO kablam! --> src/buffs.rs:52:5 Oct 12 13:37:04.734 INFO kablam! | Oct 12 13:37:04.734 INFO kablam! 52 | Refreshed, // cancels drained Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: variant is never constructed: `Energized` Oct 12 13:37:04.735 INFO kablam! --> src/buffs.rs:53:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 53 | Energized, // cancels tired. Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: enum is never used: `StackingBehaviour` Oct 12 13:37:04.735 INFO kablam! --> src/buffs.rs:59:1 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 59 | pub enum StackingBehaviour { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: function is never used: `stacking_method` Oct 12 13:37:04.735 INFO kablam! --> src/buffs.rs:67:1 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 67 | pub fn stacking_method(buff: Buff) -> StackingBehaviour { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `xy_to_directional` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:15:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 15 | pub fn xy_to_directional(x: f32, y: f32) -> (f32, f32) { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `rotated` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:34:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 34 | pub fn rotated(&self, rotation: f32) -> Vector { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `try_set_speed` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:48:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 48 | pub fn try_set_speed(&mut self, speed: f32, startup_direction: Option) -> bool { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `accelerate_xy` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:77:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 77 | pub fn accelerate_xy(&mut self, x: f32, y:f32) { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `accelerate_dirspe` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:82:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 82 | pub fn accelerate_dirspe(&mut self, direction: f32, speed: f32) { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `act_on` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:88:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 88 | pub fn act_on(&self, pt: &mut Point) { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.735 INFO kablam! warning: method is never used: `vector_to` Oct 12 13:37:04.735 INFO kablam! --> src/movement_2d.rs:186:5 Oct 12 13:37:04.735 INFO kablam! | Oct 12 13:37:04.735 INFO kablam! 186 | pub fn vector_to(&self, other: &Point) -> Vector { Oct 12 13:37:04.735 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.735 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: field is never used: `bp` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:19:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 19 | bp: Rc, Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! = note: #[warn(dead_code)] on by default Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: field is never used: `caster` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:20:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 20 | caster: Token, Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: field is never used: `pos` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:21:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 21 | pos: Point, Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: method is never used: `pt_of_player` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:129:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 129 | pub fn pt_of_player(&self, token: Token) -> Option { Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: method is never used: `player_leave` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:241:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 241 | pub fn player_leave(&mut self, token: Token) -> Option<(Point, Player)> { Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: method is never used: `is_player` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:247:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 247 | pub fn is_player(&self, token: Token) -> bool { Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: method is never used: `is_projectile` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:251:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 251 | pub fn is_projectile(&self, token: Token) -> bool { Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: method is never used: `apply_stacks` Oct 12 13:37:04.859 INFO kablam! --> src/play.rs:829:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 829 | pub fn apply_stacks(&mut self, buff: Buff, stacks: u8, duration: f32) { Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: variant is never constructed: `TowardLocation` Oct 12 13:37:04.859 INFO kablam! --> src/magic.rs:41:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 41 | TowardLocation(Location, Location), Oct 12 13:37:04.859 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: variant is never constructed: `Mute` Oct 12 13:37:04.859 INFO kablam! --> src/buffs.rs:5:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 5 | Mute, // can't cast spells Oct 12 13:37:04.859 INFO kablam! | ^^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.859 INFO kablam! warning: variant is never constructed: `Wet` Oct 12 13:37:04.859 INFO kablam! --> src/buffs.rs:6:5 Oct 12 13:37:04.859 INFO kablam! | Oct 12 13:37:04.859 INFO kablam! 6 | Wet, // electric damage taken increased Oct 12 13:37:04.859 INFO kablam! | ^^^ Oct 12 13:37:04.859 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Stealth` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:7:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 7 | Stealth, // Oct 12 13:37:04.860 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Wary` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:10:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 10 | Wary, // applies `Tired` when removed. reduces projectile damage Oct 12 13:37:04.860 INFO kablam! | ^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Wise` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:11:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 11 | Wise, // increased max mana Oct 12 13:37:04.860 INFO kablam! | ^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Unpredictable` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:12:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 12 | Unpredictable, // Cancels stacks with any other buff Oct 12 13:37:04.860 INFO kablam! | ^^^^^^^^^^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Resolute` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:13:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 13 | Resolute, // forces applied dampened. `Tired` has no effect. Oct 12 13:37:04.860 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Calm` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:14:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 14 | Calm, // Panic will not apply tired. Movement increased if below 100% Oct 12 13:37:04.860 INFO kablam! | ^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.860 INFO kablam! warning: variant is never constructed: `Steady` Oct 12 13:37:04.860 INFO kablam! --> src/buffs.rs:15:5 Oct 12 13:37:04.860 INFO kablam! | Oct 12 13:37:04.860 INFO kablam! 15 | Steady, // removes Panicked if it has < stacks Oct 12 13:37:04.860 INFO kablam! | ^^^^^^ Oct 12 13:37:04.860 INFO kablam! Oct 12 13:37:04.861 INFO kablam! warning: variant is never constructed: `Panicked` Oct 12 13:37:04.861 INFO kablam! --> src/buffs.rs:16:5 Oct 12 13:37:04.861 INFO kablam! | Oct 12 13:37:04.861 INFO kablam! 16 | Panicked, // movement speed increased. applies `Tired` when removed Oct 12 13:37:04.861 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.861 INFO kablam! Oct 12 13:37:04.861 INFO kablam! warning: variant is never constructed: `Dizzy` Oct 12 13:37:04.861 INFO kablam! --> src/buffs.rs:19:5 Oct 12 13:37:04.861 INFO kablam! | Oct 12 13:37:04.861 INFO kablam! 19 | Dizzy, // spell positions randomized slightly Oct 12 13:37:04.861 INFO kablam! | ^^^^^ Oct 12 13:37:04.862 INFO kablam! Oct 12 13:37:04.862 INFO kablam! warning: variant is never constructed: `Tired` Oct 12 13:37:04.862 INFO kablam! --> src/buffs.rs:20:5 Oct 12 13:37:04.862 INFO kablam! | Oct 12 13:37:04.862 INFO kablam! 20 | Tired, // movement slowed. ticks down ONLY when not moving Oct 12 13:37:04.862 INFO kablam! | ^^^^^ Oct 12 13:37:04.862 INFO kablam! Oct 12 13:37:04.862 INFO kablam! warning: variant is never constructed: `Confused` Oct 12 13:37:04.862 INFO kablam! --> src/buffs.rs:21:5 Oct 12 13:37:04.862 INFO kablam! | Oct 12 13:37:04.862 INFO kablam! 21 | Confused, // spell cast effects INSTEAD remove one stack of confused Oct 12 13:37:04.862 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.862 INFO kablam! Oct 12 13:37:04.862 INFO kablam! warning: variant is never constructed: `Drained` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:22:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 22 | Drained, // Max mana reduced by 30 Oct 12 13:37:04.863 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.863 INFO kablam! warning: variant is never constructed: `Weary` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:23:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 23 | Weary, // spell casts take 20% more time Oct 12 13:37:04.863 INFO kablam! | ^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.863 INFO kablam! warning: variant is never constructed: `Bleeding` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:26:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 26 | Bleeding, // takes DoT. every 5 stacks of Bleeding are replaced with 1 stack of hemorrhage. Oct 12 13:37:04.863 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.863 INFO kablam! warning: variant is never constructed: `Hemorrhage` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:27:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 27 | Hemorrhage, // take DoT. maintains equivalent Bleed stacks. Cap is 3. Oct 12 13:37:04.863 INFO kablam! | ^^^^^^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.863 INFO kablam! warning: variant is never constructed: `Bruised` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:28:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 28 | Bruised, // Tough.S + Bruised.S <= 5. Oct 12 13:37:04.863 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.863 INFO kablam! warning: variant is never constructed: `Limping` Oct 12 13:37:04.863 INFO kablam! --> src/buffs.rs:29:5 Oct 12 13:37:04.863 INFO kablam! | Oct 12 13:37:04.863 INFO kablam! 29 | Limping, // movement controls become intermittently slowed Oct 12 13:37:04.863 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.863 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Delicate` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:30:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 30 | Delicate, // increased DoT taken Oct 12 13:37:04.864 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Tough` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:33:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 33 | Tough, // damage taken > 20% of health is reduced by 10% Oct 12 13:37:04.864 INFO kablam! | ^^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Hot` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:35:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 35 | Hot, Oct 12 13:37:04.864 INFO kablam! | ^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Burning` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:36:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 36 | Burning, // DoT Oct 12 13:37:04.864 INFO kablam! | ^^^^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Warm` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:38:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 38 | Warm, // cancels COLD buffs Oct 12 13:37:04.864 INFO kablam! | ^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Shivering` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:41:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 41 | Shivering, // Periodically interrupts spellcasting Oct 12 13:37:04.864 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Cool` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:43:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.864 INFO kablam! 43 | Cool, // Cancels HOT buffs Oct 12 13:37:04.864 INFO kablam! | ^^^^ Oct 12 13:37:04.864 INFO kablam! Oct 12 13:37:04.864 INFO kablam! warning: variant is never constructed: `Poisoned` Oct 12 13:37:04.864 INFO kablam! --> src/buffs.rs:48:5 Oct 12 13:37:04.864 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 48 | Poisoned, Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: variant is never constructed: `Refreshed` Oct 12 13:37:04.865 INFO kablam! --> src/buffs.rs:52:5 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 52 | Refreshed, // cancels drained Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: variant is never constructed: `Energized` Oct 12 13:37:04.865 INFO kablam! --> src/buffs.rs:53:5 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 53 | Energized, // cancels tired. Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: enum is never used: `StackingBehaviour` Oct 12 13:37:04.865 INFO kablam! --> src/buffs.rs:59:1 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 59 | pub enum StackingBehaviour { Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: function is never used: `stacking_method` Oct 12 13:37:04.865 INFO kablam! --> src/buffs.rs:67:1 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 67 | pub fn stacking_method(buff: Buff) -> StackingBehaviour { Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: method is never used: `xy_to_directional` Oct 12 13:37:04.865 INFO kablam! --> src/movement_2d.rs:15:5 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.865 INFO kablam! 15 | pub fn xy_to_directional(x: f32, y: f32) -> (f32, f32) { Oct 12 13:37:04.865 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.865 INFO kablam! Oct 12 13:37:04.865 INFO kablam! warning: method is never used: `rotated` Oct 12 13:37:04.865 INFO kablam! --> src/movement_2d.rs:34:5 Oct 12 13:37:04.865 INFO kablam! | Oct 12 13:37:04.866 INFO kablam! 34 | pub fn rotated(&self, rotation: f32) -> Vector { Oct 12 13:37:04.866 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.866 INFO kablam! Oct 12 13:37:04.866 INFO kablam! warning: method is never used: `try_set_speed` Oct 12 13:37:04.866 INFO kablam! --> src/movement_2d.rs:48:5 Oct 12 13:37:04.866 INFO kablam! | Oct 12 13:37:04.866 INFO kablam! 48 | pub fn try_set_speed(&mut self, speed: f32, startup_direction: Option) -> bool { Oct 12 13:37:04.866 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.866 INFO kablam! Oct 12 13:37:04.866 INFO kablam! warning: method is never used: `accelerate_xy` Oct 12 13:37:04.866 INFO kablam! --> src/movement_2d.rs:77:5 Oct 12 13:37:04.866 INFO kablam! | Oct 12 13:37:04.866 INFO kablam! 77 | pub fn accelerate_xy(&mut self, x: f32, y:f32) { Oct 12 13:37:04.866 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.866 INFO kablam! Oct 12 13:37:04.866 INFO kablam! warning: method is never used: `accelerate_dirspe` Oct 12 13:37:04.866 INFO kablam! --> src/movement_2d.rs:82:5 Oct 12 13:37:04.866 INFO kablam! | Oct 12 13:37:04.866 INFO kablam! 82 | pub fn accelerate_dirspe(&mut self, direction: f32, speed: f32) { Oct 12 13:37:04.866 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.866 INFO kablam! Oct 12 13:37:04.872 INFO kablam! warning: method is never used: `act_on` Oct 12 13:37:04.872 INFO kablam! --> src/movement_2d.rs:88:5 Oct 12 13:37:04.872 INFO kablam! | Oct 12 13:37:04.872 INFO kablam! 88 | pub fn act_on(&self, pt: &mut Point) { Oct 12 13:37:04.872 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.872 INFO kablam! Oct 12 13:37:04.872 INFO kablam! warning: method is never used: `vector_to` Oct 12 13:37:04.872 INFO kablam! --> src/movement_2d.rs:186:5 Oct 12 13:37:04.872 INFO kablam! | Oct 12 13:37:04.872 INFO kablam! 186 | pub fn vector_to(&self, other: &Point) -> Vector { Oct 12 13:37:04.872 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 12 13:37:04.872 INFO kablam! Oct 12 13:37:05.012 INFO kablam! Finished dev [unoptimized + debuginfo] target(s) in 2m 01s Oct 12 13:37:05.040 INFO kablam! su: No module specific data is present Oct 12 13:37:06.511 INFO running `"docker" "rm" "-f" "d44882be5e935f697a3b5056a55baa1019be9918177632e0216887b0086f9b49"` Oct 12 13:37:06.832 INFO blam! d44882be5e935f697a3b5056a55baa1019be9918177632e0216887b0086f9b49