[INFO] cloning repository https://github.com/Aloento/RustySpine
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Aloento/RustySpine" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAloento%2FRustySpine", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAloento%2FRustySpine'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] b2ca13b1b37628e4a951e17a6ab7a9fd511f492f
[INFO] documenting Aloento/RustySpine against 1.91.0 for beta-1.92-rustdoc-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAloento%2FRustySpine" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Aloento/RustySpine
[INFO] finished tweaking git repo https://github.com/Aloento/RustySpine
[INFO] tweaked toml for git repo https://github.com/Aloento/RustySpine written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Aloento/RustySpine on toolchain 1.91.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Aloento/RustySpine 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" "+1.91.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded parking_lot_core v0.7.2
[INFO] [stderr]   Downloaded object-pool v0.5.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 4b1a04276b61bb1723ede6ebfe23e23af2a4f587c67e838738cf190be65c90b5
[INFO] running `Command { std: "docker" "start" "-a" "4b1a04276b61bb1723ede6ebfe23e23af2a4f587c67e838738cf190be65c90b5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "4b1a04276b61bb1723ede6ebfe23e23af2a4f587c67e838738cf190be65c90b5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "4b1a04276b61bb1723ede6ebfe23e23af2a4f587c67e838738cf190be65c90b5", kill_on_drop: false }`
[INFO] [stdout] 4b1a04276b61bb1723ede6ebfe23e23af2a4f587c67e838738cf190be65c90b5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/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" "RUSTDOCFLAGS=--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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "doc" "--frozen" "--no-deps" "--document-private-items" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 881e589924024271609cbfa95e3db8d941c4e1ed062fbe8474323035ac36074d
[INFO] running `Command { std: "docker" "start" "-a" "881e589924024271609cbfa95e3db8d941c4e1ed062fbe8474323035ac36074d", kill_on_drop: false }`
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]     Checking parking_lot_core v0.7.2
[INFO] [stderr]     Checking parking_lot v0.10.2
[INFO] [stderr]     Checking object-pool v0.5.3
[INFO] [stderr]  Documenting RustySpine v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] error: expected one of `!`, `.`, `::`, `;`, `?`, `{`, `}`, or an operator, found `,`
[INFO] [stdout]    --> src/animation_state.rs:116:25
[INFO] [stdout]     |
[INFO] [stdout] 116 |         self.next = None,
[INFO] [stdout]     |                         ^ expected one of 8 possible tokens
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0726]: implicit elided lifetime not allowed here
[INFO] [stdout]   --> src/attachments/path_attachment.rs:12:6
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl PathAttachment {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^ expected lifetime parameter
[INFO] [stdout]    |
[INFO] [stdout] help: indicate the anonymous lifetime
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl PathAttachment<'_> {
[INFO] [stdout]    |                    ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0726]: implicit elided lifetime not allowed here
[INFO] [stdout]   --> src/attachments/vertex_attachment.rs:13:6
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl VertexAttachment {
[INFO] [stdout]    |      ^^^^^^^^^^^^^^^^ expected lifetime parameter
[INFO] [stdout]    |
[INFO] [stdout] help: indicate the anonymous lifetime
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl VertexAttachment<'_> {
[INFO] [stdout]    |                      ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0106]: missing lifetime specifier
[INFO] [stdout]   --> src/animation_state.rs:19:17
[INFO] [stdout]    |
[INFO] [stdout] 19 |     events: Vec<Event>,
[INFO] [stdout]    |                 ^^^^^ expected named lifetime parameter
[INFO] [stdout]    |
[INFO] [stdout] help: consider using the `'a` lifetime
[INFO] [stdout]    |
[INFO] [stdout] 19 |     events: Vec<Event<'a>>,
[INFO] [stdout]    |                      ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0726]: implicit elided lifetime not allowed here
[INFO] [stdout]   --> src/animation_state.rs:79:6
[INFO] [stdout]    |
[INFO] [stdout] 79 | impl TrackEntry {
[INFO] [stdout]    |      ^^^^^^^^^^ expected lifetime parameter
[INFO] [stdout]    |
[INFO] [stdout] help: indicate the anonymous lifetime
[INFO] [stdout]    |
[INFO] [stdout] 79 | impl TrackEntry<'_> {
[INFO] [stdout]    |                ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0412]: cannot find type `Format` in this scope
[INFO] [stdout]   --> src/attachments/texture_atlas.rs:49:13
[INFO] [stdout]    |
[INFO] [stdout] 49 |     format: Format,
[INFO] [stdout]    |             ^^^^^^ not found in this scope
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0554]: `#![feature]` may not be used on the stable release channel
[INFO] [stdout]  --> src/lib.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | #![feature(assoc_char_funcs)]
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0554]: `#![feature]` may not be used on the stable release channel
[INFO] [stdout]  --> src/lib.rs:3:1
[INFO] [stdout]   |
[INFO] [stdout] 3 | #![feature(allocator_api)]
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `animation_state::AnimationStateListener` is not dyn compatible
[INFO] [stdout]    --> src/animation_state.rs:17:24
[INFO] [stdout]     |
[INFO] [stdout]  17 |     listeners: Vec<Box<dyn AnimationStateListener>>,
[INFO] [stdout]     |                        ^^^^^^^^^^^^^^^^^^^^^^^^^^ `animation_state::AnimationStateListener` is not dyn compatible
[INFO] [stdout]     |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]    --> src/animation_state.rs:128:8
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub trait AnimationStateListener {
[INFO] [stdout]     |           ---------------------- this trait is not dyn compatible...
[INFO] [stdout] 128 |     fn start(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^ ...because associated function `start` has no `self` parameter
[INFO] [stdout] 129 |     fn interrupt(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^^^ ...because associated function `interrupt` has no `self` parameter
[INFO] [stdout] 130 |     fn end(entry: TrackEntry);
[INFO] [stdout]     |        ^^^ ...because associated function `end` has no `self` parameter
[INFO] [stdout] 131 |     fn dispose(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^ ...because associated function `dispose` has no `self` parameter
[INFO] [stdout] 132 |     fn complete(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `complete` has no `self` parameter
[INFO] [stdout] 133 |     fn event(entry: TrackEntry, event: Event);
[INFO] [stdout]     |        ^^^^^ ...because associated function `event` has no `self` parameter
[INFO] [stdout] 134 |
[INFO] [stdout] 135 |     fn eventInt(trackIndex: i32, event: Event);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `eventInt` has no `self` parameter
[INFO] [stdout] 136 |     fn completeInt(trackIndex: i32, loopCount: i32);
[INFO] [stdout]     |        ^^^^^^^^^^^ ...because associated function `completeInt` has no `self` parameter
[INFO] [stdout] 137 |     fn startInt(trackIndex: i32);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `startInt` has no `self` parameter
[INFO] [stdout] 138 |     fn endInt(trackIndex: i32);
[INFO] [stdout]     |        ^^^^^^ ...because associated function `endInt` has no `self` parameter
[INFO] [stdout] help: consider turning `end` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn end(&self, entry: TrackEntry);
[INFO] [stdout]     |            ++++++
[INFO] [stdout] help: alternatively, consider constraining `end` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn end(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                               +++++++++++++++++
[INFO] [stdout] help: consider turning `start` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 128 |     fn start(&self, entry: TrackEntry);
[INFO] [stdout]     |              ++++++
[INFO] [stdout] help: alternatively, consider constraining `start` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 128 |     fn start(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                 +++++++++++++++++
[INFO] [stdout] help: consider turning `event` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 133 |     fn event(&self, entry: TrackEntry, event: Event);
[INFO] [stdout]     |              ++++++
[INFO] [stdout] help: alternatively, consider constraining `event` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 133 |     fn event(entry: TrackEntry, event: Event) where Self: Sized;
[INFO] [stdout]     |                                               +++++++++++++++++
[INFO] [stdout] help: consider turning `interrupt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 129 |     fn interrupt(&self, entry: TrackEntry);
[INFO] [stdout]     |                  ++++++
[INFO] [stdout] help: alternatively, consider constraining `interrupt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 129 |     fn interrupt(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                     +++++++++++++++++
[INFO] [stdout] help: consider turning `dispose` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 131 |     fn dispose(&self, entry: TrackEntry);
[INFO] [stdout]     |                ++++++
[INFO] [stdout] help: alternatively, consider constraining `dispose` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 131 |     fn dispose(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                   +++++++++++++++++
[INFO] [stdout] help: consider turning `complete` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn complete(&self, entry: TrackEntry);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `complete` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn complete(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                    +++++++++++++++++
[INFO] [stdout] help: consider turning `eventInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn eventInt(&self, trackIndex: i32, event: Event);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `eventInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn eventInt(trackIndex: i32, event: Event) where Self: Sized;
[INFO] [stdout]     |                                                +++++++++++++++++
[INFO] [stdout] help: consider turning `completeInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 136 |     fn completeInt(&self, trackIndex: i32, loopCount: i32);
[INFO] [stdout]     |                    ++++++
[INFO] [stdout] help: alternatively, consider constraining `completeInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 136 |     fn completeInt(trackIndex: i32, loopCount: i32) where Self: Sized;
[INFO] [stdout]     |                                                     +++++++++++++++++
[INFO] [stdout] help: consider turning `startInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 137 |     fn startInt(&self, trackIndex: i32);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `startInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 137 |     fn startInt(trackIndex: i32) where Self: Sized;
[INFO] [stdout]     |                                  +++++++++++++++++
[INFO] [stdout] help: consider turning `endInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 138 |     fn endInt(&self, trackIndex: i32);
[INFO] [stdout]     |               ++++++
[INFO] [stdout] help: alternatively, consider constraining `endInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 138 |     fn endInt(trackIndex: i32) where Self: Sized;
[INFO] [stdout]     |                                +++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0038]: the trait `animation_state::AnimationStateListener` is not dyn compatible
[INFO] [stdout]    --> src/animation_state.rs:54:15
[INFO] [stdout]     |
[INFO] [stdout]  54 |     listener: dyn AnimationStateListener,
[INFO] [stdout]     |               ^^^^^^^^^^^^^^^^^^^^^^^^^^ `animation_state::AnimationStateListener` is not dyn compatible
[INFO] [stdout]     |
[INFO] [stdout] note: for a trait to be dyn compatible it needs to allow building a vtable
[INFO] [stdout]       for more information, visit <https://doc.rust-lang.org/reference/items/traits.html#dyn-compatibility>
[INFO] [stdout]    --> src/animation_state.rs:128:8
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub trait AnimationStateListener {
[INFO] [stdout]     |           ---------------------- this trait is not dyn compatible...
[INFO] [stdout] 128 |     fn start(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^ ...because associated function `start` has no `self` parameter
[INFO] [stdout] 129 |     fn interrupt(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^^^ ...because associated function `interrupt` has no `self` parameter
[INFO] [stdout] 130 |     fn end(entry: TrackEntry);
[INFO] [stdout]     |        ^^^ ...because associated function `end` has no `self` parameter
[INFO] [stdout] 131 |     fn dispose(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^ ...because associated function `dispose` has no `self` parameter
[INFO] [stdout] 132 |     fn complete(entry: TrackEntry);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `complete` has no `self` parameter
[INFO] [stdout] 133 |     fn event(entry: TrackEntry, event: Event);
[INFO] [stdout]     |        ^^^^^ ...because associated function `event` has no `self` parameter
[INFO] [stdout] 134 |
[INFO] [stdout] 135 |     fn eventInt(trackIndex: i32, event: Event);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `eventInt` has no `self` parameter
[INFO] [stdout] 136 |     fn completeInt(trackIndex: i32, loopCount: i32);
[INFO] [stdout]     |        ^^^^^^^^^^^ ...because associated function `completeInt` has no `self` parameter
[INFO] [stdout] 137 |     fn startInt(trackIndex: i32);
[INFO] [stdout]     |        ^^^^^^^^ ...because associated function `startInt` has no `self` parameter
[INFO] [stdout] 138 |     fn endInt(trackIndex: i32);
[INFO] [stdout]     |        ^^^^^^ ...because associated function `endInt` has no `self` parameter
[INFO] [stdout] help: consider turning `end` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn end(&self, entry: TrackEntry);
[INFO] [stdout]     |            ++++++
[INFO] [stdout] help: alternatively, consider constraining `end` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 130 |     fn end(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                               +++++++++++++++++
[INFO] [stdout] help: consider turning `start` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 128 |     fn start(&self, entry: TrackEntry);
[INFO] [stdout]     |              ++++++
[INFO] [stdout] help: alternatively, consider constraining `start` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 128 |     fn start(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                 +++++++++++++++++
[INFO] [stdout] help: consider turning `event` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 133 |     fn event(&self, entry: TrackEntry, event: Event);
[INFO] [stdout]     |              ++++++
[INFO] [stdout] help: alternatively, consider constraining `event` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 133 |     fn event(entry: TrackEntry, event: Event) where Self: Sized;
[INFO] [stdout]     |                                               +++++++++++++++++
[INFO] [stdout] help: consider turning `interrupt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 129 |     fn interrupt(&self, entry: TrackEntry);
[INFO] [stdout]     |                  ++++++
[INFO] [stdout] help: alternatively, consider constraining `interrupt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 129 |     fn interrupt(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                     +++++++++++++++++
[INFO] [stdout] help: consider turning `dispose` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 131 |     fn dispose(&self, entry: TrackEntry);
[INFO] [stdout]     |                ++++++
[INFO] [stdout] help: alternatively, consider constraining `dispose` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 131 |     fn dispose(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                   +++++++++++++++++
[INFO] [stdout] help: consider turning `complete` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn complete(&self, entry: TrackEntry);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `complete` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 132 |     fn complete(entry: TrackEntry) where Self: Sized;
[INFO] [stdout]     |                                    +++++++++++++++++
[INFO] [stdout] help: consider turning `eventInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn eventInt(&self, trackIndex: i32, event: Event);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `eventInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn eventInt(trackIndex: i32, event: Event) where Self: Sized;
[INFO] [stdout]     |                                                +++++++++++++++++
[INFO] [stdout] help: consider turning `completeInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 136 |     fn completeInt(&self, trackIndex: i32, loopCount: i32);
[INFO] [stdout]     |                    ++++++
[INFO] [stdout] help: alternatively, consider constraining `completeInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 136 |     fn completeInt(trackIndex: i32, loopCount: i32) where Self: Sized;
[INFO] [stdout]     |                                                     +++++++++++++++++
[INFO] [stdout] help: consider turning `startInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 137 |     fn startInt(&self, trackIndex: i32);
[INFO] [stdout]     |                 ++++++
[INFO] [stdout] help: alternatively, consider constraining `startInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 137 |     fn startInt(trackIndex: i32) where Self: Sized;
[INFO] [stdout]     |                                  +++++++++++++++++
[INFO] [stdout] help: consider turning `endInt` into a method by giving it a `&self` argument
[INFO] [stdout]     |
[INFO] [stdout] 138 |     fn endInt(&self, trackIndex: i32);
[INFO] [stdout]     |               ++++++
[INFO] [stdout] help: alternatively, consider constraining `endInt` so it does not apply to trait objects
[INFO] [stdout]     |
[INFO] [stdout] 138 |     fn endInt(trackIndex: i32) where Self: Sized;
[INFO] [stdout]     |                                +++++++++++++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0277]: the size for values of type `(dyn animation_state::AnimationStateListener + 'static)` cannot be known at compilation time
[INFO] [stdout]   --> src/animation_state.rs:54:15
[INFO] [stdout]    |
[INFO] [stdout] 54 |     listener: dyn AnimationStateListener,
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^^^^^^^^^ doesn't have a size known at compile-time
[INFO] [stdout]    |
[INFO] [stdout]    = help: the trait `std::marker::Sized` is not implemented for `(dyn animation_state::AnimationStateListener + 'static)`
[INFO] [stdout]    = note: only the last field of a struct may have a dynamically sized type
[INFO] [stdout]    = help: change the field's type to have a statically known size
[INFO] [stdout] help: borrowed types always have a statically known size
[INFO] [stdout]    |
[INFO] [stdout] 54 |     listener: &dyn AnimationStateListener,
[INFO] [stdout]    |               +
[INFO] [stdout] help: the `Box` type always has a statically known size and allocates its contents in the heap
[INFO] [stdout]    |
[INFO] [stdout] 54 |     listener: Box<dyn AnimationStateListener>,
[INFO] [stdout]    |               ++++                          +
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] Some errors have detailed explanations: E0038, E0106, E0277, E0412, E0554, E0726.
[INFO] [stdout] 
[INFO] [stdout] For more information about an error, try `rustc --explain E0038`.
[INFO] [stdout] 
[INFO] [stderr] error: could not document `RustySpine`
[INFO] running `Command { std: "docker" "inspect" "881e589924024271609cbfa95e3db8d941c4e1ed062fbe8474323035ac36074d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "881e589924024271609cbfa95e3db8d941c4e1ed062fbe8474323035ac36074d", kill_on_drop: false }`
[INFO] [stdout] 881e589924024271609cbfa95e3db8d941c4e1ed062fbe8474323035ac36074d
