[INFO] fetching crate timeline_rs 0.1.3...
[INFO] checking timeline_rs-0.1.3 against try#b1f2594eac607c1f051534800237eeedb5590a49 for pr-139493-3
[INFO] extracting crate timeline_rs 0.1.3 into /workspace/builds/worker-7-tc2/source
[INFO] started tweaking crates.io crate timeline_rs 0.1.3
[INFO] removed 0 missing examples
[INFO] finished tweaking crates.io crate timeline_rs 0.1.3
[INFO] tweaked toml for crates.io crate timeline_rs 0.1.3 written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate timeline_rs 0.1.3 on toolchain b1f2594eac607c1f051534800237eeedb5590a49
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate timeline_rs 0.1.3 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] df6ad21f4fffceeff8d2a5c304bc8542c9b76ef13752f1e006b874f2f8ca95e3
[INFO] running `Command { std: "docker" "start" "-a" "df6ad21f4fffceeff8d2a5c304bc8542c9b76ef13752f1e006b874f2f8ca95e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "df6ad21f4fffceeff8d2a5c304bc8542c9b76ef13752f1e006b874f2f8ca95e3", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "df6ad21f4fffceeff8d2a5c304bc8542c9b76ef13752f1e006b874f2f8ca95e3", kill_on_drop: false }`
[INFO] [stdout] df6ad21f4fffceeff8d2a5c304bc8542c9b76ef13752f1e006b874f2f8ca95e3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+b1f2594eac607c1f051534800237eeedb5590a49" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 580c7ee19fee8d2cd3afe8ed289f1bb25be6a9780dfa761b443659525d62e4e5
[INFO] running `Command { std: "docker" "start" "-a" "580c7ee19fee8d2cd3afe8ed289f1bb25be6a9780dfa761b443659525d62e4e5", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.80
[INFO] [stderr]     Checking quick-xml v0.17.2
[INFO] [stderr]     Checking assert_float_eq v1.1.3
[INFO] [stderr]     Checking anstream v0.6.13
[INFO] [stderr]     Checking env_filter v0.1.0
[INFO] [stderr]     Checking env_logger v0.11.3
[INFO] [stderr]     Checking minidom v0.12.0
[INFO] [stderr]    Compiling quote v1.0.36
[INFO] [stderr]    Compiling syn v2.0.58
[INFO] [stderr]    Compiling serde_derive v1.0.197
[INFO] [stderr]     Checking serde v1.0.197
[INFO] [stderr]     Checking serde_json v1.0.115
[INFO] [stderr]     Checking quickxml_to_serde v0.6.0
[INFO] [stderr]     Checking timeline_rs v0.1.3 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `TimelineTrackImpl`
[INFO] [stdout]  --> src/loader.rs:8:51
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::{xml_to_json, Timeline, TimelineTrack, TimelineTrackImpl, Track, TrackVariant};
[INFO] [stdout]   |                                                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::Any`
[INFO] [stdout]   --> src/lib.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::any::Any;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TimelineTrackImpl`
[INFO] [stdout]  --> src/loader.rs:8:51
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::{xml_to_json, Timeline, TimelineTrack, TimelineTrackImpl, Track, TrackVariant};
[INFO] [stdout]   |                                                   ^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::any::Any`
[INFO] [stdout]   --> src/lib.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use std::any::Any;
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]    --> src/lib.rs:330:9
[INFO] [stdout]     |
[INFO] [stdout] 330 |         time: f32, start_value: bool, next_value: bool,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_value`
[INFO] [stdout]    --> src/lib.rs:330:39
[INFO] [stdout]     |
[INFO] [stdout] 330 |         time: f32, start_value: bool, next_value: bool,
[INFO] [stdout]     |                                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duration`
[INFO] [stdout]    --> src/lib.rs:331:9
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `easing_function`
[INFO] [stdout]    --> src/lib.rs:331:24
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_easing_function`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `easing_type`
[INFO] [stdout]    --> src/lib.rs:331:57
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_easing_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `InteroperableValue<T>` is more private than the item `get_easing_value`
[INFO] [stdout]    --> src/lib.rs:393:1
[INFO] [stdout]     |
[INFO] [stdout] 393 | / pub fn get_easing_value<T>(
[INFO] [stdout] 394 | |     time: f32, start_value: T, next_value: T,
[INFO] [stdout] 395 | |     duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> T
[INFO] [stdout] 396 | | where T: InteroperableValue<T>
[INFO] [stdout]     | |______________________________^ function `get_easing_value` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `InteroperableValue<T>` is only usable at visibility `pub(crate)`
[INFO] [stdout]    --> src/lib.rs:263:1
[INFO] [stdout]     |
[INFO] [stdout] 263 | trait InteroperableValue<T> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_bounds)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineXMLLoader::load_xml`
[INFO] [stdout]    --> src/loader.rs:12:5
[INFO] [stdout]     |
[INFO] [stdout]  12 | /     fn load_xml<T>(&mut self, track_name: &str, xml_path: &str) -> Result<()>
[INFO] [stdout]  13 | |     where
[INFO] [stdout]  14 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  15 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineXMLLoader::load_xml` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineXMLLoader::load_xml_str`
[INFO] [stdout]    --> src/loader.rs:16:5
[INFO] [stdout]     |
[INFO] [stdout]  16 | /     fn load_xml_str<T>(&mut self, track_name: &str, xml: &str) -> Result<()>
[INFO] [stdout]  17 | |     where
[INFO] [stdout]  18 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  19 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineXMLLoader::load_xml_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineJsonLoader::load_json`
[INFO] [stdout]    --> src/loader.rs:22:5
[INFO] [stdout]     |
[INFO] [stdout]  22 | /     fn load_json<T>(&mut self, track_name: &str, json_path: &str) -> Result<()>
[INFO] [stdout]  23 | |     where
[INFO] [stdout]  24 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  25 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineJsonLoader::load_json` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineJsonLoader::load_json_str`
[INFO] [stdout]    --> src/loader.rs:26:5
[INFO] [stdout]     |
[INFO] [stdout]  26 | /     fn load_json_str<T>(&mut self, track_name: &str, json: &str) -> Result<()>
[INFO] [stdout]  27 | |     where
[INFO] [stdout]  28 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  29 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineJsonLoader::load_json_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `XMLTrackLoader`
[INFO] [stdout]    --> src/loader.rs:32:1
[INFO] [stdout]     |
[INFO] [stdout]  32 | pub trait XMLTrackLoader<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ trait `XMLTrackLoader` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `JsonTrackLoader`
[INFO] [stdout]    --> src/loader.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | pub trait JsonTrackLoader<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ trait `JsonTrackLoader` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineXMLLoader>::load_xml`
[INFO] [stdout]    --> src/loader.rs:52:5
[INFO] [stdout]     |
[INFO] [stdout]  52 | /     fn load_xml<T>(&mut self, track_name: &str, xml_path: &str) -> Result<()>
[INFO] [stdout]  53 | |     where
[INFO] [stdout]  54 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  55 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineXMLLoader>::load_xml` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineXMLLoader>::load_xml_str`
[INFO] [stdout]    --> src/loader.rs:61:5
[INFO] [stdout]     |
[INFO] [stdout]  61 | /     fn load_xml_str<T>(&mut self, track_name: &str, xml: &str) -> Result<()>
[INFO] [stdout]  62 | |     where
[INFO] [stdout]  63 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  64 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineXMLLoader>::load_xml_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineJsonLoader>::load_json`
[INFO] [stdout]    --> src/loader.rs:72:5
[INFO] [stdout]     |
[INFO] [stdout]  72 | /     fn load_json<T>(&mut self, track_name: &str, json_path: &str) -> Result<()>
[INFO] [stdout]  73 | |     where
[INFO] [stdout]  74 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  75 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineJsonLoader>::load_json` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineJsonLoader>::load_json_str`
[INFO] [stdout]    --> src/loader.rs:82:5
[INFO] [stdout]     |
[INFO] [stdout]  82 | /     fn load_json_str<T>(&mut self, track_name: &str, json: &str) -> Result<()>
[INFO] [stdout]  83 | |     where
[INFO] [stdout]  84 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  85 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineJsonLoader>::load_json_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `xml_string_to_json` is never used
[INFO] [stdout]   --> src/xml_to_json.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn xml_string_to_json(xml: String) -> Result<serde_json::Value, minidom::error::Error> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `time`
[INFO] [stdout]    --> src/lib.rs:330:9
[INFO] [stdout]     |
[INFO] [stdout] 330 |         time: f32, start_value: bool, next_value: bool,
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_time`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_value`
[INFO] [stdout]    --> src/lib.rs:330:39
[INFO] [stdout]     |
[INFO] [stdout] 330 |         time: f32, start_value: bool, next_value: bool,
[INFO] [stdout]     |                                       ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `duration`
[INFO] [stdout]    --> src/lib.rs:331:9
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_duration`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `easing_function`
[INFO] [stdout]    --> src/lib.rs:331:24
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_easing_function`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `easing_type`
[INFO] [stdout]    --> src/lib.rs:331:57
[INFO] [stdout]     |
[INFO] [stdout] 331 |         duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> bool
[INFO] [stdout]     |                                                         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_easing_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `InteroperableValue<T>` is more private than the item `get_easing_value`
[INFO] [stdout]    --> src/lib.rs:393:1
[INFO] [stdout]     |
[INFO] [stdout] 393 | / pub fn get_easing_value<T>(
[INFO] [stdout] 394 | |     time: f32, start_value: T, next_value: T,
[INFO] [stdout] 395 | |     duration: f32, easing_function: EasingFunction, easing_type: EasingType) -> T
[INFO] [stdout] 396 | | where T: InteroperableValue<T>
[INFO] [stdout]     | |______________________________^ function `get_easing_value` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `InteroperableValue<T>` is only usable at visibility `pub(crate)`
[INFO] [stdout]    --> src/lib.rs:263:1
[INFO] [stdout]     |
[INFO] [stdout] 263 | trait InteroperableValue<T> {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     = note: `#[warn(private_bounds)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `loader::TimelineXMLLoader::load_xml`
[INFO] [stdout]    --> src/loader.rs:12:5
[INFO] [stdout]     |
[INFO] [stdout]  12 | /     fn load_xml<T>(&mut self, track_name: &str, xml_path: &str) -> Result<()>
[INFO] [stdout]  13 | |     where
[INFO] [stdout]  14 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  15 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `loader::TimelineXMLLoader::load_xml` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `loader::TimelineXMLLoader::load_xml_str`
[INFO] [stdout]    --> src/loader.rs:16:5
[INFO] [stdout]     |
[INFO] [stdout]  16 | /     fn load_xml_str<T>(&mut self, track_name: &str, xml: &str) -> Result<()>
[INFO] [stdout]  17 | |     where
[INFO] [stdout]  18 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  19 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `loader::TimelineXMLLoader::load_xml_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineJsonLoader::load_json`
[INFO] [stdout]    --> src/loader.rs:22:5
[INFO] [stdout]     |
[INFO] [stdout]  22 | /     fn load_json<T>(&mut self, track_name: &str, json_path: &str) -> Result<()>
[INFO] [stdout]  23 | |     where
[INFO] [stdout]  24 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  25 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineJsonLoader::load_json` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `TimelineJsonLoader::load_json_str`
[INFO] [stdout]    --> src/loader.rs:26:5
[INFO] [stdout]     |
[INFO] [stdout]  26 | /     fn load_json_str<T>(&mut self, track_name: &str, json: &str) -> Result<()>
[INFO] [stdout]  27 | |     where
[INFO] [stdout]  28 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  29 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>;
[INFO] [stdout]     | |__________________________________________________________^ method `TimelineJsonLoader::load_json_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `loader::XMLTrackLoader`
[INFO] [stdout]    --> src/loader.rs:32:1
[INFO] [stdout]     |
[INFO] [stdout]  32 | pub trait XMLTrackLoader<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ trait `loader::XMLTrackLoader` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `JsonTrackLoader`
[INFO] [stdout]    --> src/loader.rs:41:1
[INFO] [stdout]     |
[INFO] [stdout]  41 | pub trait JsonTrackLoader<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ trait `JsonTrackLoader` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as loader::TimelineXMLLoader>::load_xml`
[INFO] [stdout]    --> src/loader.rs:52:5
[INFO] [stdout]     |
[INFO] [stdout]  52 | /     fn load_xml<T>(&mut self, track_name: &str, xml_path: &str) -> Result<()>
[INFO] [stdout]  53 | |     where
[INFO] [stdout]  54 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  55 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as loader::TimelineXMLLoader>::load_xml` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as loader::TimelineXMLLoader>::load_xml_str`
[INFO] [stdout]    --> src/loader.rs:61:5
[INFO] [stdout]     |
[INFO] [stdout]  61 | /     fn load_xml_str<T>(&mut self, track_name: &str, xml: &str) -> Result<()>
[INFO] [stdout]  62 | |     where
[INFO] [stdout]  63 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  64 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as loader::TimelineXMLLoader>::load_xml_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineJsonLoader>::load_json`
[INFO] [stdout]    --> src/loader.rs:72:5
[INFO] [stdout]     |
[INFO] [stdout]  72 | /     fn load_json<T>(&mut self, track_name: &str, json_path: &str) -> Result<()>
[INFO] [stdout]  73 | |     where
[INFO] [stdout]  74 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  75 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineJsonLoader>::load_json` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `JsonLoaderWrapper<T>` is more private than the item `<Timeline as TimelineJsonLoader>::load_json_str`
[INFO] [stdout]    --> src/loader.rs:82:5
[INFO] [stdout]     |
[INFO] [stdout]  82 | /     fn load_json_str<T>(&mut self, track_name: &str, json: &str) -> Result<()>
[INFO] [stdout]  83 | |     where
[INFO] [stdout]  84 | |         TrackVariant: From<Track<T>>,
[INFO] [stdout]  85 | |         T: Copy + DeserializeOwned + JsonLoaderWrapper<T>
[INFO] [stdout]     | |_________________________________________________________^ method `<Timeline as TimelineJsonLoader>::load_json_str` is reachable at visibility `pub`
[INFO] [stdout]     |
[INFO] [stdout] note: but trait `JsonLoaderWrapper<T>` is only usable at visibility `pub(self)`
[INFO] [stdout]    --> src/loader.rs:111:1
[INFO] [stdout]     |
[INFO] [stdout] 111 | trait JsonLoaderWrapper<T>
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `xml_string_to_json` is never used
[INFO] [stdout]   --> src/xml_to_json.rs:14:8
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub fn xml_string_to_json(xml: String) -> Result<serde_json::Value, minidom::error::Error> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:605:15
[INFO] [stdout]     |
[INFO] [stdout] 605 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 605 -         const precision: f32 = 0.001;
[INFO] [stdout] 605 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:633:15
[INFO] [stdout]     |
[INFO] [stdout] 633 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 633 -         const precision: f32 = 0.001;
[INFO] [stdout] 633 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `start` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:634:15
[INFO] [stdout]     |
[INFO] [stdout] 634 |         const start: f32 = 10.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 634 -         const start: f32 = 10.0;
[INFO] [stdout] 634 +         const START: f32 = 10.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `width` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:635:15
[INFO] [stdout]     |
[INFO] [stdout] 635 |         const width: f32 = 70.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 635 -         const width: f32 = 70.0;
[INFO] [stdout] 635 +         const WIDTH: f32 = 70.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `offset` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:636:15
[INFO] [stdout]     |
[INFO] [stdout] 636 |         const offset: f32 = 100.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 636 -         const offset: f32 = 100.0;
[INFO] [stdout] 636 +         const OFFSET: f32 = 100.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:668:15
[INFO] [stdout]     |
[INFO] [stdout] 668 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 668 -         const precision: f32 = 0.001;
[INFO] [stdout] 668 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `start` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:669:15
[INFO] [stdout]     |
[INFO] [stdout] 669 |         const start: f32 = 10.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 669 -         const start: f32 = 10.0;
[INFO] [stdout] 669 +         const START: f32 = 10.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `width` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:670:15
[INFO] [stdout]     |
[INFO] [stdout] 670 |         const width: f32 = 70.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 670 -         const width: f32 = 70.0;
[INFO] [stdout] 670 +         const WIDTH: f32 = 70.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `offset` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:671:15
[INFO] [stdout]     |
[INFO] [stdout] 671 |         const offset: f32 = 100.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 671 -         const offset: f32 = 100.0;
[INFO] [stdout] 671 +         const OFFSET: f32 = 100.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:703:15
[INFO] [stdout]     |
[INFO] [stdout] 703 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 703 -         const precision: f32 = 0.001;
[INFO] [stdout] 703 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `start` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:704:15
[INFO] [stdout]     |
[INFO] [stdout] 704 |         const start: f32 = 0.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 704 -         const start: f32 = 0.0;
[INFO] [stdout] 704 +         const START: f32 = 0.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `width` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:705:15
[INFO] [stdout]     |
[INFO] [stdout] 705 |         const width: f32 = 70.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 705 -         const width: f32 = 70.0;
[INFO] [stdout] 705 +         const WIDTH: f32 = 70.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `scale` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:706:15
[INFO] [stdout]     |
[INFO] [stdout] 706 |         const scale: f32 = 2.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 706 -         const scale: f32 = 2.0;
[INFO] [stdout] 706 +         const SCALE: f32 = 2.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:738:15
[INFO] [stdout]     |
[INFO] [stdout] 738 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 738 -         const precision: f32 = 0.001;
[INFO] [stdout] 738 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `start` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:739:15
[INFO] [stdout]     |
[INFO] [stdout] 739 |         const start: f32 = 0.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 739 -         const start: f32 = 0.0;
[INFO] [stdout] 739 +         const START: f32 = 0.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `width` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:740:15
[INFO] [stdout]     |
[INFO] [stdout] 740 |         const width: f32 = 70.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 740 -         const width: f32 = 70.0;
[INFO] [stdout] 740 +         const WIDTH: f32 = 70.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `scale` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:741:15
[INFO] [stdout]     |
[INFO] [stdout] 741 |         const scale: f32 = 2.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 741 -         const scale: f32 = 2.0;
[INFO] [stdout] 741 +         const SCALE: f32 = 2.0;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `precision` should have an upper case name
[INFO] [stdout]    --> src/easing.rs:774:15
[INFO] [stdout]     |
[INFO] [stdout] 774 |         const precision: f32 = 0.001;
[INFO] [stdout]     |               ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 774 -         const precision: f32 = 0.001;
[INFO] [stdout] 774 +         const PRECISION: f32 = 0.001;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5.85s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: quick-xml v0.17.2
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 16`
[INFO] running `Command { std: "docker" "inspect" "580c7ee19fee8d2cd3afe8ed289f1bb25be6a9780dfa761b443659525d62e4e5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "580c7ee19fee8d2cd3afe8ed289f1bb25be6a9780dfa761b443659525d62e4e5", kill_on_drop: false }`
[INFO] [stdout] 580c7ee19fee8d2cd3afe8ed289f1bb25be6a9780dfa761b443659525d62e4e5
