[INFO] cloning repository https://github.com/JerTH/sim [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/JerTH/sim" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJerTH%2Fsim", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJerTH%2Fsim'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 5b22e09e3a8646110de0c9359691cbfcda8669a7 [INFO] testing JerTH/sim against beta-2022-02-22 for beta-1.60-1 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FJerTH%2Fsim" "/workspace/builds/worker-45/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-45/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/JerTH/sim on toolchain beta-2022-02-22 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2022-02-22" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/JerTH/sim [INFO] finished tweaking git repo https://github.com/JerTH/sim [INFO] tweaked toml for git repo https://github.com/JerTH/sim written to /workspace/builds/worker-45/source/Cargo.toml [INFO] crate git repo https://github.com/JerTH/sim already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+beta-2022-02-22" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-02-22" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 2ae4af1f89100229120ecc360d5db8ceb717d1777a7b2d5197def1bb5369269c [INFO] running `Command { std: "docker" "start" "-a" "2ae4af1f89100229120ecc360d5db8ceb717d1777a7b2d5197def1bb5369269c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "2ae4af1f89100229120ecc360d5db8ceb717d1777a7b2d5197def1bb5369269c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2ae4af1f89100229120ecc360d5db8ceb717d1777a7b2d5197def1bb5369269c", kill_on_drop: false }` [INFO] [stdout] 2ae4af1f89100229120ecc360d5db8ceb717d1777a7b2d5197def1bb5369269c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-02-22" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] ff6ecc97d5a6465f59da1e3bfbc745ad7016e43b6ec9fc1c9f1fba06988f13a6 [INFO] running `Command { std: "docker" "start" "-a" "ff6ecc97d5a6465f59da1e3bfbc745ad7016e43b6ec9fc1c9f1fba06988f13a6", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Compiling libc v0.2.88 [INFO] [stderr] Compiling bitflags v1.2.1 [INFO] [stderr] Compiling unicode-width v0.1.8 [INFO] [stderr] Compiling strsim v0.8.0 [INFO] [stderr] Compiling traitobject v0.1.0 [INFO] [stderr] Compiling ansi_term v0.11.0 [INFO] [stderr] Compiling vec_map v0.8.2 [INFO] [stderr] Compiling textwrap v0.11.0 [INFO] [stderr] Compiling unsafe-any v0.4.2 [INFO] [stderr] Compiling atty v0.2.14 [INFO] [stderr] Compiling clap v2.33.3 [INFO] [stderr] Compiling ssim v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `fmt::Display` [INFO] [stdout] --> src/identity.rs:6:60 [INFO] [stdout] | [INFO] [stdout] 6 | use std::{cell::Cell, cmp::Ordering, collections::HashMap, fmt::Display, hash::Hash, ops::Deref, sync::{atomic::{self, AtomicU64}, RwLock... [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Component`, `GetMut`, `Get`, `LinearId`, `SparseSet`, `SystemExecutionId` [INFO] [stdout] --> src/systems.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{Get, GetMut, SparseSet}, components::{Component, ComponentSetId}, conflictgraph::{ConflictCmp, ConflictGraphError}, identity::{LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GetMut`, `Get`, `world::EntityId` [INFO] [stdout] --> src/components.rs:4:27 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::{collections::{Get, GetMut, SparseSet}, identity::{InternalTypeId, LinearId}, world::EntityId}; [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> src/debug.rs:2:149 [INFO] [stdout] | [INFO] [stdout] 2 | ...der, Receiver }}, thread::{self, JoinHandle, ThreadId}, time::{Duration, SystemTime, UNIX_EPOCH}}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ConflictGraphError`, `InternalTypeId`, `LinearId`, `SystemExecutionId`, `UnsafeAnyExt` [INFO] [stdout] --> src/world.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{UnsafeAnyExt, Get, GetMut, SparseSet}, components::{ComponentSet, ComponentSetId}, conflictgraph::{ConflictGraph, ConflictGraphError}, debug::*, identity::{InternalTypeId, LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Arc`, `Cell`, `MutexGuard`, `Mutex`, `RwLockWriteGuard`, `any::Any`, `error::Error` [INFO] [stdout] --> src/world.rs:5:11 [INFO] [stdout] | [INFO] [stdout] 5 | ...::{any::Any, cell::{Cell, RefCell, UnsafeCell}, error::Error, fmt::{Debug, Display}, sync::{Arc, Mutex, MutexGuard, RwLock, RwLockWriteGuard}, ... [INFO] [stdout] | ^^^^^^^^ ^^^^ ^^^^^^^^^^^^ ^^^ ^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: an associated function with this name may be added to the standard library in the future [INFO] [stdout] --> src/components.rs:132:18 [INFO] [stdout] | [INFO] [stdout] 132 | self.set.downcast_ref_unchecked::>() [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unstable_name_collisions)]` on by default [INFO] [stdout] = warning: once this associated item is added to the standard library, the ambiguity may cause an error or change in behavior! [INFO] [stdout] = note: for more information, see issue #48919 [INFO] [stdout] = help: call with fully qualified syntax `downcast_ref_unchecked(...)` to keep using the current method [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:373:20 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:377:15 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `id` [INFO] [stdout] --> src/world.rs:97:30 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `entity` [INFO] [stdout] --> src/world.rs:104:49 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component` [INFO] [stdout] --> src/world.rs:104:67 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component_id` [INFO] [stdout] --> src/world.rs:269:75 [INFO] [stdout] | [INFO] [stdout] 269 | fn check_mid_frame_dependency(&self, dependency_type: DependencyType, component_id: ComponentSetId) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `free` [INFO] [stdout] --> src/collections.rs:358:5 [INFO] [stdout] | [INFO] [stdout] 358 | free: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/collections.rs:369:8 [INFO] [stdout] | [INFO] [stdout] 369 | fn insert(item: T) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert_with` [INFO] [stdout] --> src/collections.rs:373:8 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `remove` [INFO] [stdout] --> src/collections.rs:377:8 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_immutable` [INFO] [stdout] --> src/systems.rs:150:12 [INFO] [stdout] | [INFO] [stdout] 150 | pub fn group_immutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_mutable` [INFO] [stdout] --> src/systems.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn group_mutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias is never used: `Generation` [INFO] [stdout] --> src/components.rs:6:1 [INFO] [stdout] | [INFO] [stdout] 6 | type Generation = u32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/components.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | fn new() -> Self where T: 'static { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `len` [INFO] [stdout] --> src/components.rs:84:8 [INFO] [stdout] | [INFO] [stdout] 84 | fn len(&self) -> usize { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/components.rs:93:8 [INFO] [stdout] | [INFO] [stdout] 93 | fn insert(&mut self, index: usize, component: T) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `thread` [INFO] [stdout] --> src/debug.rs:54:5 [INFO] [stdout] | [INFO] [stdout] 54 | thread: ThreadId, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `LogMessage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/debug.rs:51:10 [INFO] [stdout] | [INFO] [stdout] 51 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `filter_set` [INFO] [stdout] --> src/query.rs:151:5 [INFO] [stdout] | [INFO] [stdout] 151 | filter_set: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `Query` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/query.rs:147:10 [INFO] [stdout] | [INFO] [stdout] 147 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `destroy_entity` [INFO] [stdout] --> src/world.rs:97:8 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 26 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished dev [unoptimized + debuginfo] target(s) in 17.27s [INFO] running `Command { std: "docker" "inspect" "ff6ecc97d5a6465f59da1e3bfbc745ad7016e43b6ec9fc1c9f1fba06988f13a6", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "ff6ecc97d5a6465f59da1e3bfbc745ad7016e43b6ec9fc1c9f1fba06988f13a6", kill_on_drop: false }` [INFO] [stdout] ff6ecc97d5a6465f59da1e3bfbc745ad7016e43b6ec9fc1c9f1fba06988f13a6 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-02-22" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] a31ae589076769a12ccac70a1a5f475761d937c63f6254ae2c4b5f72a6a30957 [INFO] running `Command { std: "docker" "start" "-a" "a31ae589076769a12ccac70a1a5f475761d937c63f6254ae2c4b5f72a6a30957", kill_on_drop: false }` [INFO] [stdout] warning: unused import: `fmt::Display` [INFO] [stdout] --> src/identity.rs:6:60 [INFO] [stdout] | [INFO] [stdout] 6 | use std::{cell::Cell, cmp::Ordering, collections::HashMap, fmt::Display, hash::Hash, ops::Deref, sync::{atomic::{self, AtomicU64}, RwLock... [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Component`, `GetMut`, `Get`, `LinearId`, `SparseSet`, `SystemExecutionId` [INFO] [stdout] --> src/systems.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{Get, GetMut, SparseSet}, components::{Component, ComponentSetId}, conflictgraph::{ConflictCmp, ConflictGraphError}, identity::{LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GetMut`, `Get`, `world::EntityId` [INFO] [stdout] --> src/components.rs:4:27 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::{collections::{Get, GetMut, SparseSet}, identity::{InternalTypeId, LinearId}, world::EntityId}; [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> src/debug.rs:2:149 [INFO] [stdout] | [INFO] [stdout] 2 | ...der, Receiver }}, thread::{self, JoinHandle, ThreadId}, time::{Duration, SystemTime, UNIX_EPOCH}}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ConflictGraphError`, `InternalTypeId`, `LinearId`, `SystemExecutionId`, `UnsafeAnyExt` [INFO] [stdout] --> src/world.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{UnsafeAnyExt, Get, GetMut, SparseSet}, components::{ComponentSet, ComponentSetId}, conflictgraph::{ConflictGraph, ConflictGraphError}, debug::*, identity::{InternalTypeId, LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Arc`, `Cell`, `MutexGuard`, `Mutex`, `RwLockWriteGuard`, `any::Any`, `error::Error` [INFO] [stdout] --> src/world.rs:5:11 [INFO] [stdout] | [INFO] [stdout] 5 | ...::{any::Any, cell::{Cell, RefCell, UnsafeCell}, error::Error, fmt::{Debug, Display}, sync::{Arc, Mutex, MutexGuard, RwLock, RwLockWriteGuard}, ... [INFO] [stdout] | ^^^^^^^^ ^^^^ ^^^^^^^^^^^^ ^^^ ^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: an associated function with this name may be added to the standard library in the future [INFO] [stdout] --> src/components.rs:132:18 [INFO] [stdout] | [INFO] [stdout] 132 | self.set.downcast_ref_unchecked::>() [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unstable_name_collisions)]` on by default [INFO] [stdout] = warning: once this associated item is added to the standard library, the ambiguity may cause an error or change in behavior! [INFO] [stdout] = note: for more information, see issue #48919 [INFO] [stdout] = help: call with fully qualified syntax `downcast_ref_unchecked(...)` to keep using the current method [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:373:20 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:377:15 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `id` [INFO] [stdout] --> src/world.rs:97:30 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `entity` [INFO] [stdout] --> src/world.rs:104:49 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component` [INFO] [stdout] --> src/world.rs:104:67 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component_id` [INFO] [stdout] --> src/world.rs:269:75 [INFO] [stdout] | [INFO] [stdout] 269 | fn check_mid_frame_dependency(&self, dependency_type: DependencyType, component_id: ComponentSetId) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `free` [INFO] [stdout] --> src/collections.rs:358:5 [INFO] [stdout] | [INFO] [stdout] 358 | free: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/collections.rs:369:8 [INFO] [stdout] | [INFO] [stdout] 369 | fn insert(item: T) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert_with` [INFO] [stdout] --> src/collections.rs:373:8 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `remove` [INFO] [stdout] --> src/collections.rs:377:8 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_immutable` [INFO] [stdout] --> src/systems.rs:150:12 [INFO] [stdout] | [INFO] [stdout] 150 | pub fn group_immutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_mutable` [INFO] [stdout] --> src/systems.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn group_mutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias is never used: `Generation` [INFO] [stdout] --> src/components.rs:6:1 [INFO] [stdout] | [INFO] [stdout] 6 | type Generation = u32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/components.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | fn new() -> Self where T: 'static { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `len` [INFO] [stdout] --> src/components.rs:84:8 [INFO] [stdout] | [INFO] [stdout] 84 | fn len(&self) -> usize { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/components.rs:93:8 [INFO] [stdout] | [INFO] [stdout] 93 | fn insert(&mut self, index: usize, component: T) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `thread` [INFO] [stdout] --> src/debug.rs:54:5 [INFO] [stdout] | [INFO] [stdout] 54 | thread: ThreadId, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `LogMessage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/debug.rs:51:10 [INFO] [stdout] | [INFO] [stdout] 51 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `filter_set` [INFO] [stdout] --> src/query.rs:151:5 [INFO] [stdout] | [INFO] [stdout] 151 | filter_set: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `Query` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/query.rs:147:10 [INFO] [stdout] | [INFO] [stdout] 147 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Compiling ssim v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: associated function is never used: `destroy_entity` [INFO] [stdout] --> src/world.rs:97:8 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 26 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `fmt::Display` [INFO] [stdout] --> src/identity.rs:6:60 [INFO] [stdout] | [INFO] [stdout] 6 | use std::{cell::Cell, cmp::Ordering, collections::HashMap, fmt::Display, hash::Hash, ops::Deref, sync::{atomic::{self, AtomicU64}, RwLock... [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Component`, `GetMut`, `Get`, `LinearId`, `SparseSet`, `SystemExecutionId` [INFO] [stdout] --> src/systems.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{Get, GetMut, SparseSet}, components::{Component, ComponentSetId}, conflictgraph::{ConflictCmp, ConflictGraphError}, identity::{LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `GetMut`, `Get`, `world::EntityId` [INFO] [stdout] --> src/components.rs:4:27 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::{collections::{Get, GetMut, SparseSet}, identity::{InternalTypeId, LinearId}, world::EntityId}; [INFO] [stdout] | ^^^ ^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `Duration` [INFO] [stdout] --> src/debug.rs:2:149 [INFO] [stdout] | [INFO] [stdout] 2 | ...der, Receiver }}, thread::{self, JoinHandle, ThreadId}, time::{Duration, SystemTime, UNIX_EPOCH}}; [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `ConflictGraphError`, `InternalTypeId`, `LinearId`, `SystemExecutionId`, `UnsafeAnyExt` [INFO] [stdout] --> src/world.rs:3:27 [INFO] [stdout] | [INFO] [stdout] 3 | ...::{UnsafeAnyExt, Get, GetMut, SparseSet}, components::{ComponentSet, ComponentSetId}, conflictgraph::{ConflictGraph, ConflictGraphError}, debug::*, identity::{InternalTypeId, LinearId, SystemExecutionId}, ... [INFO] [stdout] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused imports: `Arc`, `Cell`, `MutexGuard`, `Mutex`, `RwLockWriteGuard`, `any::Any`, `error::Error` [INFO] [stdout] --> src/world.rs:5:11 [INFO] [stdout] | [INFO] [stdout] 5 | ...::{any::Any, cell::{Cell, RefCell, UnsafeCell}, error::Error, fmt::{Debug, Display}, sync::{Arc, Mutex, MutexGuard, RwLock, RwLockWriteGuard}, ... [INFO] [stdout] | ^^^^^^^^ ^^^^ ^^^^^^^^^^^^ ^^^ ^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: an associated function with this name may be added to the standard library in the future [INFO] [stdout] --> src/components.rs:132:18 [INFO] [stdout] | [INFO] [stdout] 132 | self.set.downcast_ref_unchecked::>() [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unstable_name_collisions)]` on by default [INFO] [stdout] = warning: once this associated item is added to the standard library, the ambiguity may cause an error or change in behavior! [INFO] [stdout] = note: for more information, see issue #48919 [INFO] [stdout] = help: call with fully qualified syntax `downcast_ref_unchecked(...)` to keep using the current method [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:373:20 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `key` [INFO] [stdout] --> src/collections.rs:377:15 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `id` [INFO] [stdout] --> src/world.rs:97:30 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^ help: if this is intentional, prefix it with an underscore: `_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `entity` [INFO] [stdout] --> src/world.rs:104:49 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component` [INFO] [stdout] --> src/world.rs:104:67 [INFO] [stdout] | [INFO] [stdout] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stdout] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `component_id` [INFO] [stdout] --> src/world.rs:269:75 [INFO] [stdout] | [INFO] [stdout] 269 | fn check_mid_frame_dependency(&self, dependency_type: DependencyType, component_id: ComponentSetId) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component_id` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `free` [INFO] [stdout] --> src/collections.rs:358:5 [INFO] [stdout] | [INFO] [stdout] 358 | free: Vec, [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(dead_code)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/collections.rs:369:8 [INFO] [stdout] | [INFO] [stdout] 369 | fn insert(item: T) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert_with` [INFO] [stdout] --> src/collections.rs:373:8 [INFO] [stdout] | [INFO] [stdout] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `remove` [INFO] [stdout] --> src/collections.rs:377:8 [INFO] [stdout] | [INFO] [stdout] 377 | fn remove(key: K) -> Result { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_immutable` [INFO] [stdout] --> src/systems.rs:150:12 [INFO] [stdout] | [INFO] [stdout] 150 | pub fn group_immutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `group_mutable` [INFO] [stdout] --> src/systems.rs:154:12 [INFO] [stdout] | [INFO] [stdout] 154 | pub fn group_mutable(&self) -> &Vec { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: type alias is never used: `Generation` [INFO] [stdout] --> src/components.rs:6:1 [INFO] [stdout] | [INFO] [stdout] 6 | type Generation = u32; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `new` [INFO] [stdout] --> src/components.rs:75:8 [INFO] [stdout] | [INFO] [stdout] 75 | fn new() -> Self where T: 'static { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `len` [INFO] [stdout] --> src/components.rs:84:8 [INFO] [stdout] | [INFO] [stdout] 84 | fn len(&self) -> usize { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `insert` [INFO] [stdout] --> src/components.rs:93:8 [INFO] [stdout] | [INFO] [stdout] 93 | fn insert(&mut self, index: usize, component: T) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `thread` [INFO] [stdout] --> src/debug.rs:54:5 [INFO] [stdout] | [INFO] [stdout] 54 | thread: ThreadId, [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `LogMessage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/debug.rs:51:10 [INFO] [stdout] | [INFO] [stdout] 51 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field is never read: `filter_set` [INFO] [stdout] --> src/query.rs:151:5 [INFO] [stdout] | [INFO] [stdout] 151 | filter_set: Vec, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: `Query` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] --> src/query.rs:147:10 [INFO] [stdout] | [INFO] [stdout] 147 | #[derive(Debug)] [INFO] [stdout] | ^^^^^ [INFO] [stdout] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function is never used: `destroy_entity` [INFO] [stdout] --> src/world.rs:97:8 [INFO] [stdout] | [INFO] [stdout] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: 26 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 2.43s [INFO] running `Command { std: "docker" "inspect" "a31ae589076769a12ccac70a1a5f475761d937c63f6254ae2c4b5f72a6a30957", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a31ae589076769a12ccac70a1a5f475761d937c63f6254ae2c4b5f72a6a30957", kill_on_drop: false }` [INFO] [stdout] a31ae589076769a12ccac70a1a5f475761d937c63f6254ae2c4b5f72a6a30957 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-45/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:0cd99ca24d8e8c98e67c542213511d985b8778b5bdcbb160e038429496686047" "/opt/rustwide/cargo-home/bin/cargo" "+beta-2022-02-22" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] 2964afcc1b041207b076b124f2b4a19d2ffc6437c8a3ed1eb803aba6f0f248c2 [INFO] running `Command { std: "docker" "start" "-a" "2964afcc1b041207b076b124f2b4a19d2ffc6437c8a3ed1eb803aba6f0f248c2", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] warning: unused import: `fmt::Display` [INFO] [stderr] --> src/identity.rs:6:60 [INFO] [stderr] | [INFO] [stderr] 6 | use std::{cell::Cell, cmp::Ordering, collections::HashMap, fmt::Display, hash::Hash, ops::Deref, sync::{atomic::{self, AtomicU64}, RwLock... [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Component`, `GetMut`, `Get`, `LinearId`, `SparseSet`, `SystemExecutionId` [INFO] [stderr] --> src/systems.rs:3:27 [INFO] [stderr] | [INFO] [stderr] 3 | ...::{Get, GetMut, SparseSet}, components::{Component, ComponentSetId}, conflictgraph::{ConflictCmp, ConflictGraphError}, identity::{LinearId, SystemExecutionId}, ... [INFO] [stderr] | ^^^ ^^^^^^ ^^^^^^^^^ ^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `GetMut`, `Get`, `world::EntityId` [INFO] [stderr] --> src/components.rs:4:27 [INFO] [stderr] | [INFO] [stderr] 4 | use crate::{collections::{Get, GetMut, SparseSet}, identity::{InternalTypeId, LinearId}, world::EntityId}; [INFO] [stderr] | ^^^ ^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `Duration` [INFO] [stderr] --> src/debug.rs:2:149 [INFO] [stderr] | [INFO] [stderr] 2 | ...der, Receiver }}, thread::{self, JoinHandle, ThreadId}, time::{Duration, SystemTime, UNIX_EPOCH}}; [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `ConflictGraphError`, `InternalTypeId`, `LinearId`, `SystemExecutionId`, `UnsafeAnyExt` [INFO] [stderr] --> src/world.rs:3:27 [INFO] [stderr] | [INFO] [stderr] 3 | ...::{UnsafeAnyExt, Get, GetMut, SparseSet}, components::{ComponentSet, ComponentSetId}, conflictgraph::{ConflictGraph, ConflictGraphError}, debug::*, identity::{InternalTypeId, LinearId, SystemExecutionId}, ... [INFO] [stderr] | ^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^ ^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `Arc`, `Cell`, `MutexGuard`, `Mutex`, `RwLockWriteGuard`, `any::Any`, `error::Error` [INFO] [stderr] --> src/world.rs:5:11 [INFO] [stderr] | [INFO] [stderr] 5 | ...::{any::Any, cell::{Cell, RefCell, UnsafeCell}, error::Error, fmt::{Debug, Display}, sync::{Arc, Mutex, MutexGuard, RwLock, RwLockWriteGuard}, ... [INFO] [stderr] | ^^^^^^^^ ^^^^ ^^^^^^^^^^^^ ^^^ ^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: an associated function with this name may be added to the standard library in the future [INFO] [stderr] --> src/components.rs:132:18 [INFO] [stderr] | [INFO] [stderr] 132 | self.set.downcast_ref_unchecked::>() [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unstable_name_collisions)]` on by default [INFO] [stderr] = warning: once this associated item is added to the standard library, the ambiguity may cause an error or change in behavior! [INFO] [stderr] = note: for more information, see issue #48919 [INFO] [stderr] = help: call with fully qualified syntax `downcast_ref_unchecked(...)` to keep using the current method [INFO] [stderr] [INFO] [stderr] warning: unused variable: `key` [INFO] [stderr] --> src/collections.rs:373:20 [INFO] [stderr] | [INFO] [stderr] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `key` [INFO] [stderr] --> src/collections.rs:377:15 [INFO] [stderr] | [INFO] [stderr] 377 | fn remove(key: K) -> Result { [INFO] [stderr] | ^^^ help: if this is intentional, prefix it with an underscore: `_key` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `id` [INFO] [stderr] --> src/world.rs:97:30 [INFO] [stderr] | [INFO] [stderr] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stderr] | ^^ help: if this is intentional, prefix it with an underscore: `_id` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `entity` [INFO] [stderr] --> src/world.rs:104:49 [INFO] [stderr] | [INFO] [stderr] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stderr] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_entity` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `component` [INFO] [stderr] --> src/world.rs:104:67 [INFO] [stderr] | [INFO] [stderr] 104 | fn add_component(&self, entity: EntityId, component: T) { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `component_id` [INFO] [stderr] --> src/world.rs:269:75 [INFO] [stderr] | [INFO] [stderr] 269 | fn check_mid_frame_dependency(&self, dependency_type: DependencyType, component_id: ComponentSetId) -> bool { [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_component_id` [INFO] [stderr] [INFO] [stderr] warning: field is never read: `free` [INFO] [stderr] --> src/collections.rs:358:5 [INFO] [stderr] | [INFO] [stderr] 358 | free: Vec, [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` on by default [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `insert` [INFO] [stderr] --> src/collections.rs:369:8 [INFO] [stderr] | [INFO] [stderr] 369 | fn insert(item: T) -> Result { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `insert_with` [INFO] [stderr] --> src/collections.rs:373:8 [INFO] [stderr] | [INFO] [stderr] 373 | fn insert_with(key: K, item: T) -> Result<(), T> { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `remove` [INFO] [stderr] --> src/collections.rs:377:8 [INFO] [stderr] | [INFO] [stderr] 377 | fn remove(key: K) -> Result { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `group_immutable` [INFO] [stderr] --> src/systems.rs:150:12 [INFO] [stderr] | [INFO] [stderr] 150 | pub fn group_immutable(&self) -> &Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `group_mutable` [INFO] [stderr] --> src/systems.rs:154:12 [INFO] [stderr] | [INFO] [stderr] 154 | pub fn group_mutable(&self) -> &Vec { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: type alias is never used: `Generation` [INFO] [stderr] --> src/components.rs:6:1 [INFO] [stderr] | [INFO] [stderr] 6 | type Generation = u32; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `new` [INFO] [stderr] --> src/components.rs:75:8 [INFO] [stderr] | [INFO] [stderr] 75 | fn new() -> Self where T: 'static { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `len` [INFO] [stderr] --> src/components.rs:84:8 [INFO] [stderr] | [INFO] [stderr] 84 | fn len(&self) -> usize { [INFO] [stderr] | ^^^ [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `insert` [INFO] [stderr] --> src/components.rs:93:8 [INFO] [stderr] | [INFO] [stderr] 93 | fn insert(&mut self, index: usize, component: T) -> Result<(), ()> { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: field is never read: `thread` [INFO] [stderr] --> src/debug.rs:54:5 [INFO] [stderr] | [INFO] [stderr] 54 | thread: ThreadId, [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: `LogMessage` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] --> src/debug.rs:51:10 [INFO] [stderr] | [INFO] [stderr] 51 | #[derive(Debug)] [INFO] [stderr] | ^^^^^ [INFO] [stderr] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: field is never read: `filter_set` [INFO] [stderr] --> src/query.rs:151:5 [INFO] [stderr] | [INFO] [stderr] 151 | filter_set: Vec, [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] note: `Query` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stderr] --> src/query.rs:147:10 [INFO] [stderr] | [INFO] [stderr] 147 | #[derive(Debug)] [INFO] [stderr] | ^^^^^ [INFO] [stderr] = note: this warning originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stderr] [INFO] [stderr] warning: associated function is never used: `destroy_entity` [INFO] [stderr] --> src/world.rs:97:8 [INFO] [stderr] | [INFO] [stderr] 97 | fn destroy_entity(&self, id: EntityId) -> Result<(), ()> { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `ssim` (lib) generated 26 warnings [INFO] [stderr] warning: `ssim` (lib test) generated 26 warnings (26 duplicates) [INFO] [stderr] Finished test [unoptimized + debuginfo] target(s) in 0.49s [INFO] [stderr] Running unittests (/opt/rustwide/target/debug/deps/ssim-95436ae7343b6024) [INFO] [stdout] [INFO] [stdout] running 8 tests [INFO] [stdout] test collections::test::test_sparse_set ... ok [INFO] [stdout] test world::tests::filters ... ok [INFO] [stdout] test identity::test::test_internal_type_ids ... ok [INFO] [stdout] test world::tests::queries ... FAILED [INFO] [stdout] test conflictgraph::tests::test_cliques ... ok [INFO] [stdout] test world::tests::hello_world ... ok [INFO] [stdout] test debug::test::test_debug_log ... ok [INFO] [stdout] test debug::test::test_fatal_log - should panic ... ok [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] [INFO] [stdout] ---- world::tests::queries stdout ---- [INFO] [stdout] thread 'world::tests::queries' panicked at 'not yet implemented', src/world.rs:275:17 [INFO] [stdout] stack backtrace: [INFO] [stdout] 0: 0x555bdc98637c - std::backtrace_rs::backtrace::libunwind::trace::h02555d7ca8aa068a [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/../../backtrace/src/backtrace/libunwind.rs:93:5 [INFO] [stdout] 1: 0x555bdc98637c - std::backtrace_rs::backtrace::trace_unsynchronized::h8555a46024147da8 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/../../backtrace/src/backtrace/mod.rs:66:5 [INFO] [stdout] 2: 0x555bdc98637c - std::sys_common::backtrace::_print_fmt::h4c7f50b4f105da1e [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:66:5 [INFO] [stdout] 3: 0x555bdc98637c - ::fmt::ha305a40dbc030444 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:45:22 [INFO] [stdout] 4: 0x555bdc9ac91c - core::fmt::write::hadd15acf4d6ce273 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/fmt/mod.rs:1190:17 [INFO] [stdout] 5: 0x555bdc981c78 - std::io::Write::write_fmt::h271050faa79d27d2 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/io/mod.rs:1657:15 [INFO] [stdout] 6: 0x555bdc988697 - std::sys_common::backtrace::_print::h0dd5c0810675bd8c [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:48:5 [INFO] [stdout] 7: 0x555bdc988697 - std::sys_common::backtrace::print::h20a2155fa0a22ca6 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:35:9 [INFO] [stdout] 8: 0x555bdc988697 - std::panicking::default_hook::{{closure}}::habb3b6f3ccdfe00a [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:295:22 [INFO] [stdout] 9: 0x555bdc9883cb - std::panicking::default_hook::h1c5cf4d5063a38e4 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:311:9 [INFO] [stdout] 10: 0x555bdc988dea - std::panicking::rust_panic_with_hook::hb5de7a3072d2cf59 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:698:17 [INFO] [stdout] 11: 0x555bdc988a99 - std::panicking::begin_panic_handler::{{closure}}::h5106de2f55f1a411 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:586:13 [INFO] [stdout] 12: 0x555bdc986844 - std::sys_common::backtrace::__rust_end_short_backtrace::h5ad5c2a8a003ca72 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:138:18 [INFO] [stdout] 13: 0x555bdc9887e9 - rust_begin_unwind [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:584:5 [INFO] [stdout] 14: 0x555bdc8a7233 - core::panicking::panic_fmt::hfb4b8460cd493e74 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/panicking.rs:143:14 [INFO] [stdout] 15: 0x555bdc8a70fd - core::panicking::panic::h33838847634b5d2d [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/panicking.rs:48:5 [INFO] [stdout] 16: 0x555bdc8f4180 - ssim::world::World::check_mid_frame_dependency::h0aaee873c1fb5163 [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:275:17 [INFO] [stdout] 17: 0x555bdc8f408e - ssim::world::World::mark_dependency::h0652ccf6d9ed574f [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:256:12 [INFO] [stdout] 18: 0x555bdc8f4572 - ssim::world::LocalWorld::add_component::h88626c7945a5a864 [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:371:9 [INFO] [stdout] 19: 0x555bdc8ece88 - ssim::world::tests::queries::entity_producer_system::h0e310cd99b8c497f [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:479:21 [INFO] [stdout] 20: 0x555bdc916a78 - ssim::systems::WorldSystem::run::h945310bb4e5ebaed [INFO] [stdout] at /opt/rustwide/workdir/src/systems.rs:77:9 [INFO] [stdout] 21: 0x555bdc8f3623 - ssim::world::World::run::h258276b4e61cd5db [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:154:37 [INFO] [stdout] 22: 0x555bdc8ecc23 - ssim::world::tests::queries::he03124f773cf2877 [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:533:9 [INFO] [stdout] 23: 0x555bdc8ecb7a - ssim::world::tests::queries::{{closure}}::hc9185002f0437a72 [INFO] [stdout] at /opt/rustwide/workdir/src/world.rs:467:5 [INFO] [stdout] 24: 0x555bdc8e7dfe - core::ops::function::FnOnce::call_once::h79284d7b06fcd181 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 25: 0x555bdc948a43 - core::ops::function::FnOnce::call_once::h43953c8a8f54893f [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 26: 0x555bdc948a43 - test::__rust_begin_short_backtrace::h163f55298a15df9b [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/test/src/lib.rs:575:5 [INFO] [stdout] 27: 0x555bdc947771 - as core::ops::function::FnOnce>::call_once::hc911782b3cbc7ed5 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/alloc/src/boxed.rs:1854:9 [INFO] [stdout] 28: 0x555bdc947771 - as core::ops::function::FnOnce<()>>::call_once::hc5bb369afbf9cd4e [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/panic/unwind_safe.rs:271:9 [INFO] [stdout] 29: 0x555bdc947771 - std::panicking::try::do_call::he60df4e3e832faff [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:492:40 [INFO] [stdout] 30: 0x555bdc947771 - std::panicking::try::h2633cee89a0767f3 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:456:19 [INFO] [stdout] 31: 0x555bdc947771 - std::panic::catch_unwind::h6e10f7b94ce38b1e [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panic.rs:137:14 [INFO] [stdout] 32: 0x555bdc947771 - test::run_test_in_process::h085ef39049c3b50b [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/test/src/lib.rs:598:18 [INFO] [stdout] 33: 0x555bdc947771 - test::run_test::run_test_inner::{{closure}}::h4e58ce9f68eb43e4 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/test/src/lib.rs:492:39 [INFO] [stdout] 34: 0x555bdc951051 - test::run_test::run_test_inner::{{closure}}::h6d18db28c5e396ee [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/test/src/lib.rs:519:37 [INFO] [stdout] 35: 0x555bdc951051 - std::sys_common::backtrace::__rust_begin_short_backtrace::h32292cb2cd8be620 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys_common/backtrace.rs:122:18 [INFO] [stdout] 36: 0x555bdc91d7af - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::h71ee66b20f7b0482 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/thread/mod.rs:498:17 [INFO] [stdout] 37: 0x555bdc91d7af - as core::ops::function::FnOnce<()>>::call_once::hb6046e1d1a75a4a4 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/panic/unwind_safe.rs:271:9 [INFO] [stdout] 38: 0x555bdc91d7af - std::panicking::try::do_call::h5422165a88309c77 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:492:40 [INFO] [stdout] 39: 0x555bdc91d7af - std::panicking::try::h840a12b54e2c9f5d [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panicking.rs:456:19 [INFO] [stdout] 40: 0x555bdc91d7af - std::panic::catch_unwind::h85910e437c8da180 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/panic.rs:137:14 [INFO] [stdout] 41: 0x555bdc91d7af - std::thread::Builder::spawn_unchecked_::{{closure}}::ha3af3a297bfd51d6 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/thread/mod.rs:497:30 [INFO] [stdout] 42: 0x555bdc91d7af - core::ops::function::FnOnce::call_once{{vtable.shim}}::hff8788f58e0e06a9 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/core/src/ops/function.rs:227:5 [INFO] [stdout] 43: 0x555bdc98ea83 - as core::ops::function::FnOnce>::call_once::h82a18723295373b7 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/alloc/src/boxed.rs:1854:9 [INFO] [stdout] 44: 0x555bdc98ea83 - as core::ops::function::FnOnce>::call_once::h4b9b8634f7a2a5a4 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/alloc/src/boxed.rs:1854:9 [INFO] [stdout] 45: 0x555bdc98ea83 - std::sys::unix::thread::Thread::new::thread_start::h3dc341aa024c6852 [INFO] [stdout] at /rustc/0a4f984a87c7ba6c74ec3e78442fec955a419e32/library/std/src/sys/unix/thread.rs:108:17 [INFO] [stdout] 46: 0x7fa7810a5609 - start_thread [INFO] [stdout] 47: 0x7fa781330293 - clone [INFO] [stdout] 48: 0x0 - [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] failures: [INFO] [stdout] world::tests::queries [INFO] [stdout] [INFO] [stdout] test result: FAILED. 7 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.11s [INFO] [stdout] [INFO] [stderr] error: test failed, to rerun pass '--lib' [INFO] running `Command { std: "docker" "inspect" "2964afcc1b041207b076b124f2b4a19d2ffc6437c8a3ed1eb803aba6f0f248c2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "2964afcc1b041207b076b124f2b4a19d2ffc6437c8a3ed1eb803aba6f0f248c2", kill_on_drop: false }` [INFO] [stdout] 2964afcc1b041207b076b124f2b4a19d2ffc6437c8a3ed1eb803aba6f0f248c2