[INFO] crate tokio-interceptor 0.1.0 is already in cache [INFO] testing tokio-interceptor-0.1.0 against beta-2020-06-03 for beta-1.45-1 [INFO] extracting crate tokio-interceptor 0.1.0 into /workspace/builds/worker-6/source [INFO] validating manifest of crates.io crate tokio-interceptor 0.1.0 on toolchain beta-2020-06-03 [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started tweaking crates.io crate tokio-interceptor 0.1.0 [INFO] finished tweaking crates.io crate tokio-interceptor 0.1.0 [INFO] tweaked toml for crates.io crate tokio-interceptor 0.1.0 written to /workspace/builds/worker-6/source/Cargo.toml [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"` [INFO] running `"/workspace/cargo-home/bin/cargo" "+beta-2020-06-03" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "build" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 0566b72492357e302e3aec78e853d182b871c9f519fc19bac718e8e4ae7043f6 [INFO] running `"docker" "start" "-a" "0566b72492357e302e3aec78e853d182b871c9f519fc19bac718e8e4ae7043f6"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling anymap v0.12.1 [INFO] [stderr] Compiling tokio-core v0.1.17 [INFO] [stderr] Compiling tokio-interceptor v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:40:51 [INFO] [stderr] | [INFO] [stderr] 40 | pub fn default_interceptors(&self) -> Vec>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:51:93 [INFO] [stderr] | [INFO] [stderr] 51 | pub fn register_event_with>(&mut self, mut interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/coeffects.rs:53:64 [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] | ________________________________________________________________^ [INFO] [stderr] 54 | | Error = Self::Error>> { [INFO] [stderr] | |__________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] 54 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/effects.rs:43:63 [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] | _______________________________________________________________^ [INFO] [stderr] 44 | | Error = Self::Error>> { [INFO] [stderr] | |_________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] 44 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:29:60 [INFO] [stderr] | [INFO] [stderr] 29 | fn handle(self: Box, context: Context) -> Box, Error = E>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:42:60 [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 43 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 43 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:62:50 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn dispatch(&self, event: Ev) -> Box [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:121:48 [INFO] [stderr] | [INFO] [stderr] 121 | event_handlers: HashMap>>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:131:84 [INFO] [stderr] | [INFO] [stderr] 131 | pub fn register_event>(&mut self, interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | let mut interceptors: Vec>>> = interceptors.iter().map(Rc::clone).collect(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:139:85 [INFO] [stderr] | [INFO] [stderr] 139 | interceptors.push(Rc::new(Box::new(EventInterceptor::new(event)) as Box>)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:22:48 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct InterceptorQueue(VecDeque>>>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:26:26 [INFO] [stderr] | [INFO] [stderr] 26 | where T: Into>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:31:50 [INFO] [stderr] | [INFO] [stderr] 31 | pub fn pop_front(&mut self) -> Option>>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:40:29 [INFO] [stderr] | [INFO] [stderr] 40 | impl FromIterator>>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:42:41 [INFO] [stderr] | [INFO] [stderr] 42 | where T: IntoIterator>>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | impl Extend>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:50:38 [INFO] [stderr] | [INFO] [stderr] 50 | where T: IntoIterator>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:51:26 [INFO] [stderr] | [INFO] [stderr] 51 | pub effects: Vec>, [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:53:27 [INFO] [stderr] | [INFO] [stderr] 53 | pub stack: Vec>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:57:41 [INFO] [stderr] | [INFO] [stderr] 57 | pub fn new(interceptors: Vec>>>) -> Context { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:70:30 [INFO] [stderr] | [INFO] [stderr] 70 | pub fn next(self) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:80:60 [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 81 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 81 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:85:59 [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 86 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 86 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:94:60 [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 95 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 95 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:99:59 [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 100 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 100 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:108:60 [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 109 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 109 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:113:59 [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 114 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 114 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:43 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:97 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:175:19 [INFO] [stderr] | [INFO] [stderr] 175 | next_ctx: Box, Error = E>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:179:30 [INFO] [stderr] | [INFO] [stderr] 179 | pub fn new(next_ctx: Box, Error = E>>) -> Dispatched { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/events.rs:140:17 [INFO] [stderr] | [INFO] [stderr] 140 | let mut context = Context::new(interceptors); [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: 33 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 1.71s [INFO] running `"docker" "inspect" "0566b72492357e302e3aec78e853d182b871c9f519fc19bac718e8e4ae7043f6"` [INFO] running `"docker" "rm" "-f" "0566b72492357e302e3aec78e853d182b871c9f519fc19bac718e8e4ae7043f6"` [INFO] [stdout] 0566b72492357e302e3aec78e853d182b871c9f519fc19bac718e8e4ae7043f6 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen" "--no-run"` [INFO] [stdout] b05afecd142f88da7f7df0cb814e1120e2823c58a86b526094ba6f254ed46652 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `"docker" "start" "-a" "b05afecd142f88da7f7df0cb814e1120e2823c58a86b526094ba6f254ed46652"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] Compiling tokio-interceptor v0.1.0 (/opt/rustwide/workdir) [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:40:51 [INFO] [stderr] | [INFO] [stderr] 40 | pub fn default_interceptors(&self) -> Vec>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:51:93 [INFO] [stderr] | [INFO] [stderr] 51 | pub fn register_event_with>(&mut self, mut interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/coeffects.rs:53:64 [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] | ________________________________________________________________^ [INFO] [stderr] 54 | | Error = Self::Error>> { [INFO] [stderr] | |__________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] 54 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/effects.rs:43:63 [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] | _______________________________________________________________^ [INFO] [stderr] 44 | | Error = Self::Error>> { [INFO] [stderr] | |_________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] 44 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:29:60 [INFO] [stderr] | [INFO] [stderr] 29 | fn handle(self: Box, context: Context) -> Box, Error = E>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:42:60 [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 43 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 43 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:62:50 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn dispatch(&self, event: Ev) -> Box [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:121:48 [INFO] [stderr] | [INFO] [stderr] 121 | event_handlers: HashMap>>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:131:84 [INFO] [stderr] | [INFO] [stderr] 131 | pub fn register_event>(&mut self, interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | let mut interceptors: Vec>>> = interceptors.iter().map(Rc::clone).collect(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:139:85 [INFO] [stderr] | [INFO] [stderr] 139 | interceptors.push(Rc::new(Box::new(EventInterceptor::new(event)) as Box>)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:22:48 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct InterceptorQueue(VecDeque>>>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:26:26 [INFO] [stderr] | [INFO] [stderr] 26 | where T: Into>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:31:50 [INFO] [stderr] | [INFO] [stderr] 31 | pub fn pop_front(&mut self) -> Option>>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:40:29 [INFO] [stderr] | [INFO] [stderr] 40 | impl FromIterator>>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:42:41 [INFO] [stderr] | [INFO] [stderr] 42 | where T: IntoIterator>>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | impl Extend>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:50:38 [INFO] [stderr] | [INFO] [stderr] 50 | where T: IntoIterator>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:51:26 [INFO] [stderr] | [INFO] [stderr] 51 | pub effects: Vec>, [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:53:27 [INFO] [stderr] | [INFO] [stderr] 53 | pub stack: Vec>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:57:41 [INFO] [stderr] | [INFO] [stderr] 57 | pub fn new(interceptors: Vec>>>) -> Context { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:70:30 [INFO] [stderr] | [INFO] [stderr] 70 | pub fn next(self) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:80:60 [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 81 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 81 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:85:59 [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 86 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 86 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:94:60 [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 95 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 95 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:99:59 [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 100 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 100 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:108:60 [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 109 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 109 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:113:59 [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 114 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 114 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:43 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:97 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:175:19 [INFO] [stderr] | [INFO] [stderr] 175 | next_ctx: Box, Error = E>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:179:30 [INFO] [stderr] | [INFO] [stderr] 179 | pub fn new(next_ctx: Box, Error = E>>) -> Dispatched { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/events.rs:140:17 [INFO] [stderr] | [INFO] [stderr] 140 | let mut context = Context::new(interceptors); [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: 33 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:70:65 [INFO] [stderr] | [INFO] [stderr] 70 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:88:65 [INFO] [stderr] | [INFO] [stderr] 88 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:93:47 [INFO] [stderr] | [INFO] [stderr] 93 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:100:47 [INFO] [stderr] | [INFO] [stderr] 100 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:107:47 [INFO] [stderr] | [INFO] [stderr] 107 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:115:47 [INFO] [stderr] | [INFO] [stderr] 115 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:122:107 [INFO] [stderr] | [INFO] [stderr] 122 | Mode::Quitting => context.queue.push_back(Box::new(EventInterceptor::new(Quit(0))) as Box>), [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:138:55 [INFO] [stderr] | [INFO] [stderr] 138 | fn before(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:164:55 [INFO] [stderr] | [INFO] [stderr] 164 | fn before(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:187:65 [INFO] [stderr] | [INFO] [stderr] 187 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:211:65 [INFO] [stderr] | [INFO] [stderr] 211 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:232:65 [INFO] [stderr] | [INFO] [stderr] 232 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:251:65 [INFO] [stderr] | [INFO] [stderr] 251 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:273:65 [INFO] [stderr] | [INFO] [stderr] 273 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:296:65 [INFO] [stderr] | [INFO] [stderr] 296 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:312:93 [INFO] [stderr] | [INFO] [stderr] 312 | context.queue.push_back(Box::new(EventInterceptor::new(Quit(0))) as Box>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:323:54 [INFO] [stderr] | [INFO] [stderr] 323 | fn after(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:335:62 [INFO] [stderr] | [INFO] [stderr] 335 | fn handle(self: Box, _context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:40:51 [INFO] [stderr] | [INFO] [stderr] 40 | pub fn default_interceptors(&self) -> Vec>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:51:93 [INFO] [stderr] | [INFO] [stderr] 51 | pub fn register_event_with>(&mut self, mut interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/coeffects.rs:53:64 [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] | ________________________________________________________________^ [INFO] [stderr] 54 | | Error = Self::Error>> { [INFO] [stderr] | |__________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] 54 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:78:68 [INFO] [stderr] | [INFO] [stderr] 78 | fn handle(self: Box, mut context: Context) -> Box, Error = E>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:100:51 [INFO] [stderr] | [INFO] [stderr] 100 | let queue = vec![Box::new(i_state) as Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:101:53 [INFO] [stderr] | [INFO] [stderr] 101 | Box::new(i_effects) as Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:102:74 [INFO] [stderr] | [INFO] [stderr] 102 | Box::new(EventInterceptor::new(i_event)) as Box>]; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/effects.rs:43:63 [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] | _______________________________________________________________^ [INFO] [stderr] 44 | | Error = Self::Error>> { [INFO] [stderr] | |_________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] 44 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:29:60 [INFO] [stderr] | [INFO] [stderr] 29 | fn handle(self: Box, context: Context) -> Box, Error = E>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:42:60 [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 43 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 43 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:62:50 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn dispatch(&self, event: Ev) -> Box [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:121:48 [INFO] [stderr] | [INFO] [stderr] 121 | event_handlers: HashMap>>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:131:84 [INFO] [stderr] | [INFO] [stderr] 131 | pub fn register_event>(&mut self, interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | let mut interceptors: Vec>>> = interceptors.iter().map(Rc::clone).collect(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:139:85 [INFO] [stderr] | [INFO] [stderr] 139 | interceptors.push(Rc::new(Box::new(EventInterceptor::new(event)) as Box>)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:22:48 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct InterceptorQueue(VecDeque>>>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:26:26 [INFO] [stderr] | [INFO] [stderr] 26 | where T: Into>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:31:50 [INFO] [stderr] | [INFO] [stderr] 31 | pub fn pop_front(&mut self) -> Option>>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:40:29 [INFO] [stderr] | [INFO] [stderr] 40 | impl FromIterator>>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:42:41 [INFO] [stderr] | [INFO] [stderr] 42 | where T: IntoIterator>>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | impl Extend>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:50:38 [INFO] [stderr] | [INFO] [stderr] 50 | where T: IntoIterator>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:51:26 [INFO] [stderr] | [INFO] [stderr] 51 | pub effects: Vec>, [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:53:27 [INFO] [stderr] | [INFO] [stderr] 53 | pub stack: Vec>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:57:41 [INFO] [stderr] | [INFO] [stderr] 57 | pub fn new(interceptors: Vec>>>) -> Context { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:70:30 [INFO] [stderr] | [INFO] [stderr] 70 | pub fn next(self) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:80:60 [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 81 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 81 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:85:59 [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 86 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 86 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:94:60 [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 95 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 95 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:99:59 [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 100 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 100 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:108:60 [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 109 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 109 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:113:59 [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 114 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 114 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:43 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:97 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:175:19 [INFO] [stderr] | [INFO] [stderr] 175 | next_ctx: Box, Error = E>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:179:30 [INFO] [stderr] | [INFO] [stderr] 179 | pub fn new(next_ctx: Box, Error = E>>) -> Dispatched { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:246:65 [INFO] [stderr] | [INFO] [stderr] 246 | fn handle(self: Box, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:267:55 [INFO] [stderr] | [INFO] [stderr] 267 | fn before(&self, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:276:65 [INFO] [stderr] | [INFO] [stderr] 276 | fn handle(self: Box, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:301:54 [INFO] [stderr] | [INFO] [stderr] 301 | fn after(&self, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/events.rs:140:17 [INFO] [stderr] | [INFO] [stderr] 140 | let mut context = Context::new(interceptors); [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: unused `futures::stream::MapErr` in tuple element 0 that must be used [INFO] [stderr] --> examples/todo.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | / iter_result(stdin_lock.lines()) [INFO] [stderr] 31 | | .map_err(Error::Stdin) [INFO] [stderr] 32 | | .forward(stdin_sink) [INFO] [stderr] 33 | | .wait() [INFO] [stderr] 34 | | .unwrap(); [INFO] [stderr] | |______________________^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: streams do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: unused `futures::sink::SinkMapErr` in tuple element 1 that must be used [INFO] [stderr] --> examples/todo.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | / iter_result(stdin_lock.lines()) [INFO] [stderr] 31 | | .map_err(Error::Stdin) [INFO] [stderr] 32 | | .forward(stdin_sink) [INFO] [stderr] 33 | | .wait() [INFO] [stderr] 34 | | .unwrap(); [INFO] [stderr] | |______________________^ [INFO] [stderr] | [INFO] [stderr] = note: sinks do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: unused boxed `futures::Future` trait object that must be used [INFO] [stderr] --> src/effects.rs:91:9 [INFO] [stderr] | [INFO] [stderr] 91 | i.after(context); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: futures do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/lib.rs:258:9 [INFO] [stderr] | [INFO] [stderr] 258 | app.dispatch(BeforeEvent(Rc::clone(&called))).wait(); [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/lib.rs:290:9 [INFO] [stderr] | [INFO] [stderr] 290 | app.dispatch(BeforeEvent(Rc::clone(&called_second))).wait(); [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/lib.rs:322:9 [INFO] [stderr] | [INFO] [stderr] 322 | app.dispatch(BeforeEvent(Rc::clone(&called_second))).wait(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 45 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: 20 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 3.38s [INFO] running `"docker" "inspect" "b05afecd142f88da7f7df0cb814e1120e2823c58a86b526094ba6f254ed46652"` [INFO] running `"docker" "rm" "-f" "b05afecd142f88da7f7df0cb814e1120e2823c58a86b526094ba6f254ed46652"` [INFO] [stdout] b05afecd142f88da7f7df0cb814e1120e2823c58a86b526094ba6f254ed46652 [INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2020-06-03" "test" "--frozen"` [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] [stdout] 6a52af147a3dbd1533c14113283f4d83ad1ad0862c75e5ddb1d19304aa4ef0a2 [INFO] running `"docker" "start" "-a" "6a52af147a3dbd1533c14113283f4d83ad1ad0862c75e5ddb1d19304aa4ef0a2"` [INFO] [stderr] sudo: setrlimit(RLIMIT_CORE): Operation not permitted [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:40:51 [INFO] [stderr] | [INFO] [stderr] 40 | pub fn default_interceptors(&self) -> Vec>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:51:93 [INFO] [stderr] | [INFO] [stderr] 51 | pub fn register_event_with>(&mut self, mut interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/coeffects.rs:53:64 [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] | ________________________________________________________________^ [INFO] [stderr] 54 | | Error = Self::Error>> { [INFO] [stderr] | |__________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] 54 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/effects.rs:43:63 [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] | _______________________________________________________________^ [INFO] [stderr] 44 | | Error = Self::Error>> { [INFO] [stderr] | |_________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] 44 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:29:60 [INFO] [stderr] | [INFO] [stderr] 29 | fn handle(self: Box, context: Context) -> Box, Error = E>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:40:51 [INFO] [stderr] | [INFO] [stderr] 40 | pub fn default_interceptors(&self) -> Vec>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/app.rs:51:93 [INFO] [stderr] | [INFO] [stderr] 51 | pub fn register_event_with>(&mut self, mut interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:42:60 [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 43 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 43 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:62:50 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn dispatch(&self, event: Ev) -> Box [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/coeffects.rs:53:64 [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] | ________________________________________________________________^ [INFO] [stderr] 54 | | Error = Self::Error>> { [INFO] [stderr] | |__________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 53 | fn before(&self, mut context: Context) -> Box, [INFO] [stderr] 54 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:121:48 [INFO] [stderr] | [INFO] [stderr] 121 | event_handlers: HashMap>>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:78:68 [INFO] [stderr] | [INFO] [stderr] 78 | fn handle(self: Box, mut context: Context) -> Box, Error = E>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:131:84 [INFO] [stderr] | [INFO] [stderr] 131 | pub fn register_event>(&mut self, interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:100:51 [INFO] [stderr] | [INFO] [stderr] 100 | let queue = vec![Box::new(i_state) as Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | let mut interceptors: Vec>>> = interceptors.iter().map(Rc::clone).collect(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:101:53 [INFO] [stderr] | [INFO] [stderr] 101 | Box::new(i_effects) as Box>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:139:85 [INFO] [stderr] | [INFO] [stderr] 139 | interceptors.push(Rc::new(Box::new(EventInterceptor::new(event)) as Box>)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/db.rs:102:74 [INFO] [stderr] | [INFO] [stderr] 102 | Box::new(EventInterceptor::new(i_event)) as Box>]; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:22:48 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct InterceptorQueue(VecDeque>>>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:26:26 [INFO] [stderr] | [INFO] [stderr] 26 | where T: Into>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:31:50 [INFO] [stderr] | [INFO] [stderr] 31 | pub fn pop_front(&mut self) -> Option>>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/effects.rs:43:63 [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] | _______________________________________________________________^ [INFO] [stderr] 44 | | Error = Self::Error>> { [INFO] [stderr] | |_________________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 43 | fn after(&self, mut context: Context) -> Box, [INFO] [stderr] 44 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:40:29 [INFO] [stderr] | [INFO] [stderr] 40 | impl FromIterator>>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:29:60 [INFO] [stderr] | [INFO] [stderr] 29 | fn handle(self: Box, context: Context) -> Box, Error = E>>; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:42:41 [INFO] [stderr] | [INFO] [stderr] 42 | where T: IntoIterator>>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | impl Extend>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:42:60 [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 43 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 42 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 43 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:50:38 [INFO] [stderr] | [INFO] [stderr] 50 | where T: IntoIterator>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:62:50 [INFO] [stderr] | [INFO] [stderr] 62 | pub fn dispatch(&self, event: Ev) -> Box [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:51:26 [INFO] [stderr] | [INFO] [stderr] 51 | pub effects: Vec>, [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:121:48 [INFO] [stderr] | [INFO] [stderr] 121 | event_handlers: HashMap>>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:53:27 [INFO] [stderr] | [INFO] [stderr] 53 | pub stack: Vec>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:57:41 [INFO] [stderr] | [INFO] [stderr] 57 | pub fn new(interceptors: Vec>>>) -> Context { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:70:30 [INFO] [stderr] | [INFO] [stderr] 70 | pub fn next(self) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:80:60 [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 81 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 81 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:85:59 [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 86 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 86 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:94:60 [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 95 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 95 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:99:59 [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 100 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 100 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:108:60 [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 109 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 109 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:113:59 [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 114 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 114 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:43 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:97 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:175:19 [INFO] [stderr] | [INFO] [stderr] 175 | next_ctx: Box, Error = E>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:179:30 [INFO] [stderr] | [INFO] [stderr] 179 | pub fn new(next_ctx: Box, Error = E>>) -> Dispatched { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/events.rs:140:17 [INFO] [stderr] | [INFO] [stderr] 140 | let mut context = Context::new(interceptors); [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: 33 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:131:84 [INFO] [stderr] | [INFO] [stderr] 131 | pub fn register_event>(&mut self, interceptors: Vec>>) { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:138:46 [INFO] [stderr] | [INFO] [stderr] 138 | let mut interceptors: Vec>>> = interceptors.iter().map(Rc::clone).collect(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/events.rs:139:85 [INFO] [stderr] | [INFO] [stderr] 139 | interceptors.push(Rc::new(Box::new(EventInterceptor::new(event)) as Box>)); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:22:48 [INFO] [stderr] | [INFO] [stderr] 22 | pub struct InterceptorQueue(VecDeque>>>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:26:26 [INFO] [stderr] | [INFO] [stderr] 26 | where T: Into>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:31:50 [INFO] [stderr] | [INFO] [stderr] 31 | pub fn pop_front(&mut self) -> Option>>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:40:29 [INFO] [stderr] | [INFO] [stderr] 40 | impl FromIterator>>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:42:41 [INFO] [stderr] | [INFO] [stderr] 42 | where T: IntoIterator>>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:48:20 [INFO] [stderr] | [INFO] [stderr] 48 | impl Extend>> for InterceptorQueue { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/queue.rs:50:38 [INFO] [stderr] | [INFO] [stderr] 50 | where T: IntoIterator>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:51:26 [INFO] [stderr] | [INFO] [stderr] 51 | pub effects: Vec>, [INFO] [stderr] | ^^^^^^ help: use `dyn`: `dyn Effect` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:53:27 [INFO] [stderr] | [INFO] [stderr] 53 | pub stack: Vec>>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:57:41 [INFO] [stderr] | [INFO] [stderr] 57 | pub fn new(interceptors: Vec>>>) -> Context { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:70:30 [INFO] [stderr] | [INFO] [stderr] 70 | pub fn next(self) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:80:60 [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 81 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 80 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 81 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:85:59 [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 86 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 85 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 86 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:94:60 [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 95 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 94 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 95 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:99:59 [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 100 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 99 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 100 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:108:60 [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] | ____________________________________________________________^ [INFO] [stderr] 109 | | Error = Self::Error>> { [INFO] [stderr] | |______________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 108 | fn before(&self, context: Context) -> Box, [INFO] [stderr] 109 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:113:59 [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] | ___________________________________________________________^ [INFO] [stderr] 114 | | Error = Self::Error>> { [INFO] [stderr] | |_____________________________________________________________________________________^ [INFO] [stderr] | [INFO] [stderr] help: use `dyn` [INFO] [stderr] | [INFO] [stderr] 113 | fn after(&self, context: Context) -> Box, [INFO] [stderr] 114 | Error = Self::Error>> { [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:43 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:142:97 [INFO] [stderr] | [INFO] [stderr] 142 | fn call(&self, interceptor: Rc>>, context: Context) -> Box, Error = E>> [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:175:19 [INFO] [stderr] | [INFO] [stderr] 175 | next_ctx: Box, Error = E>>, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:179:30 [INFO] [stderr] | [INFO] [stderr] 179 | pub fn new(next_ctx: Box, Error = E>>) -> Dispatched { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = E>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:246:65 [INFO] [stderr] | [INFO] [stderr] 246 | fn handle(self: Box, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:267:55 [INFO] [stderr] | [INFO] [stderr] 267 | fn before(&self, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:276:65 [INFO] [stderr] | [INFO] [stderr] 276 | fn handle(self: Box, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> src/lib.rs:301:54 [INFO] [stderr] | [INFO] [stderr] 301 | fn after(&self, context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: variable does not need to be mutable [INFO] [stderr] --> src/events.rs:140:17 [INFO] [stderr] | [INFO] [stderr] 140 | let mut context = Context::new(interceptors); [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: unused boxed `futures::Future` trait object that must be used [INFO] [stderr] --> src/effects.rs:91:9 [INFO] [stderr] | [INFO] [stderr] 91 | i.after(context); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: futures do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: unused `std::result::Result` that must be used [INFO] [stderr] --> src/lib.rs:258:9 [INFO] [stderr] | [INFO] [stderr] 258 | app.dispatch(BeforeEvent(Rc::clone(&called))).wait(); [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/lib.rs:290:9 [INFO] [stderr] | [INFO] [stderr] 290 | app.dispatch(BeforeEvent(Rc::clone(&called_second))).wait(); [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/lib.rs:322:9 [INFO] [stderr] | [INFO] [stderr] 322 | app.dispatch(BeforeEvent(Rc::clone(&called_second))).wait(); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: this `Result` may be an `Err` variant, which should be handled [INFO] [stderr] [INFO] [stderr] warning: 45 warnings emitted [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:70:65 [INFO] [stderr] | [INFO] [stderr] 70 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:88:65 [INFO] [stderr] | [INFO] [stderr] 88 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:93:47 [INFO] [stderr] | [INFO] [stderr] 93 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:100:47 [INFO] [stderr] | [INFO] [stderr] 100 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:107:47 [INFO] [stderr] | [INFO] [stderr] 107 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:115:47 [INFO] [stderr] | [INFO] [stderr] 115 | let interceptors: Vec>> = vec![ [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:122:107 [INFO] [stderr] | [INFO] [stderr] 122 | Mode::Quitting => context.queue.push_back(Box::new(EventInterceptor::new(Quit(0))) as Box>), [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:138:55 [INFO] [stderr] | [INFO] [stderr] 138 | fn before(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:164:55 [INFO] [stderr] | [INFO] [stderr] 164 | fn before(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:187:65 [INFO] [stderr] | [INFO] [stderr] 187 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:211:65 [INFO] [stderr] | [INFO] [stderr] 211 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:232:65 [INFO] [stderr] | [INFO] [stderr] 232 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:251:65 [INFO] [stderr] | [INFO] [stderr] 251 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:273:65 [INFO] [stderr] | [INFO] [stderr] 273 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:296:65 [INFO] [stderr] | [INFO] [stderr] 296 | fn handle(self: Box, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:312:93 [INFO] [stderr] | [INFO] [stderr] 312 | context.queue.push_back(Box::new(EventInterceptor::new(Quit(0))) as Box>); [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Interceptor` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:323:54 [INFO] [stderr] | [INFO] [stderr] 323 | fn after(&self, mut context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stderr] --> examples/todo.rs:335:62 [INFO] [stderr] | [INFO] [stderr] 335 | fn handle(self: Box, _context: Context<()>) -> Box, Error = ()>> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future, Error = ()>` [INFO] [stderr] [INFO] [stderr] warning: unused `futures::stream::MapErr` in tuple element 0 that must be used [INFO] [stderr] --> examples/todo.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | / iter_result(stdin_lock.lines()) [INFO] [stderr] 31 | | .map_err(Error::Stdin) [INFO] [stderr] 32 | | .forward(stdin_sink) [INFO] [stderr] 33 | | .wait() [INFO] [stderr] 34 | | .unwrap(); [INFO] [stderr] | |______________________^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_must_use)]` on by default [INFO] [stderr] = note: streams do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: unused `futures::sink::SinkMapErr` in tuple element 1 that must be used [INFO] [stderr] --> examples/todo.rs:30:9 [INFO] [stderr] | [INFO] [stderr] 30 | / iter_result(stdin_lock.lines()) [INFO] [stderr] 31 | | .map_err(Error::Stdin) [INFO] [stderr] 32 | | .forward(stdin_sink) [INFO] [stderr] 33 | | .wait() [INFO] [stderr] 34 | | .unwrap(); [INFO] [stderr] | |______________________^ [INFO] [stderr] | [INFO] [stderr] = note: sinks do nothing unless polled [INFO] [stderr] [INFO] [stderr] warning: 20 warnings emitted [INFO] [stderr] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.15s [INFO] [stderr] Running /opt/rustwide/target/debug/deps/tokio_interceptor-4b035d747c48c601 [INFO] [stdout] [INFO] [stdout] running 7 tests [INFO] [stdout] test effects::tests::test_effect_interceptor ... ok [INFO] [stdout] test db::tests::test_event_as_interceptor ... ok [INFO] [stdout] test tests::test_coeffect_map ... ok [INFO] [stdout] test coeffects::tests::test_coeffect_interceptor ... ok [INFO] [stdout] test tests::test_dispatcher_calls_event_before ... ok [INFO] [stderr] Doc-tests tokio-interceptor [INFO] [stdout] test tests::test_dispatcher_calls_interceptor_after ... ok [INFO] [stdout] test tests::test_dispatcher_calls_interceptor_before ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] running 0 tests [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out [INFO] [stdout] [INFO] running `"docker" "inspect" "6a52af147a3dbd1533c14113283f4d83ad1ad0862c75e5ddb1d19304aa4ef0a2"` [INFO] running `"docker" "rm" "-f" "6a52af147a3dbd1533c14113283f4d83ad1ad0862c75e5ddb1d19304aa4ef0a2"` [INFO] [stdout] 6a52af147a3dbd1533c14113283f4d83ad1ad0862c75e5ddb1d19304aa4ef0a2