[INFO] fetching crate sunk 0.1.2...
[INFO] checking sunk-0.1.2 against master#f1ce0e6a00593493a12e0e3662119786c761f375 for pr-92413
[INFO] extracting crate sunk 0.1.2 into /workspace/builds/worker-98/source
[INFO] validating manifest of crates.io crate sunk 0.1.2 on toolchain f1ce0e6a00593493a12e0e3662119786c761f375
[INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+f1ce0e6a00593493a12e0e3662119786c761f375" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] started tweaking crates.io crate sunk 0.1.2
[INFO] finished tweaking crates.io crate sunk 0.1.2
[INFO] tweaked toml for crates.io crate sunk 0.1.2 written to /workspace/builds/worker-98/source/Cargo.toml
[INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+f1ce0e6a00593493a12e0e3662119786c761f375" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+f1ce0e6a00593493a12e0e3662119786c761f375" "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-98/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-98/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:a429bb59b7a3b4e7270a4b4c243bb115fc561d8f62ec34ef63a0a36cabf65dfd" "/opt/rustwide/cargo-home/bin/cargo" "+f1ce0e6a00593493a12e0e3662119786c761f375" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 5e6ee48767ec51a4aea00d68cfc7fe6581025302ad518d85d17029f288dd6c6a
[INFO] running `Command { std: "docker" "start" "-a" "5e6ee48767ec51a4aea00d68cfc7fe6581025302ad518d85d17029f288dd6c6a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "5e6ee48767ec51a4aea00d68cfc7fe6581025302ad518d85d17029f288dd6c6a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5e6ee48767ec51a4aea00d68cfc7fe6581025302ad518d85d17029f288dd6c6a", kill_on_drop: false }`
[INFO] [stdout] 5e6ee48767ec51a4aea00d68cfc7fe6581025302ad518d85d17029f288dd6c6a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-98/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-98/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" "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:a429bb59b7a3b4e7270a4b4c243bb115fc561d8f62ec34ef63a0a36cabf65dfd" "/opt/rustwide/cargo-home/bin/cargo" "+f1ce0e6a00593493a12e0e3662119786c761f375" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 0c9d57a3b1287317bae19a6e0a92a1ab897d8f92feca8117429007228b84f72f
[INFO] running `Command { std: "docker" "start" "-a" "0c9d57a3b1287317bae19a6e0a92a1ab897d8f92feca8117429007228b84f72f", kill_on_drop: false }`
[INFO] [stderr]    Compiling autocfg v1.0.1
[INFO] [stderr]    Compiling libc v0.2.112
[INFO] [stderr]     Checking cfg-if v1.0.0
[INFO] [stderr]    Compiling log v0.4.14
[INFO] [stderr]     Checking either v1.6.1
[INFO] [stderr]    Compiling proc-macro2 v1.0.36
[INFO] [stderr]    Compiling unicode-xid v0.2.2
[INFO] [stderr]    Compiling autocfg v0.1.7
[INFO] [stderr]    Compiling syn v1.0.85
[INFO] [stderr]     Checking scopeguard v1.1.0
[INFO] [stderr]     Checking slab v0.4.5
[INFO] [stderr]    Compiling version_check v0.9.4
[INFO] [stderr]    Compiling serde_derive v1.0.133
[INFO] [stderr]     Checking itoa v0.4.8
[INFO] [stderr]    Compiling serde v1.0.133
[INFO] [stderr]    Compiling openssl v0.10.38
[INFO] [stderr]     Checking percent-encoding v2.1.0
[INFO] [stderr]     Checking hashbrown v0.11.2
[INFO] [stderr]    Compiling crc32fast v1.3.0
[INFO] [stderr]     Checking bitflags v1.3.2
[INFO] [stderr]    Compiling native-tls v0.2.8
[INFO] [stderr]     Checking once_cell v1.9.0
[INFO] [stderr]     Checking openssl-probe v0.1.4
[INFO] [stderr]    Compiling encoding_rs v0.8.30
[INFO] [stderr]     Checking dtoa v0.4.8
[INFO] [stderr]     Checking md5 v0.6.1
[INFO] [stderr]     Checking rand_core v0.3.1
[INFO] [stderr]     Checking tokio-sync v0.1.8
[INFO] [stderr]     Checking addr2line v0.17.0
[INFO] [stderr]     Checking rand_jitter v0.1.4
[INFO] [stderr]     Checking try_from v0.3.2
[INFO] [stderr]     Checking base64 v0.10.1
[INFO] [stderr]    Compiling parking_lot_core v0.6.2
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]     Checking idna v0.1.5
[INFO] [stderr]     Checking idna v0.2.3
[INFO] [stderr]    Compiling hyper v0.12.36
[INFO] [stderr]     Checking lock_api v0.3.4
[INFO] [stderr]     Checking rand_hc v0.1.0
[INFO] [stderr]     Checking rand_isaac v0.1.1
[INFO] [stderr]     Checking rand_xorshift v0.1.1
[INFO] [stderr]    Compiling rand_chacha v0.1.1
[INFO] [stderr]    Compiling rand_pcg v0.1.2
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling openssl-sys v0.9.72
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling miniz_oxide v0.4.4
[INFO] [stderr]    Compiling indexmap v1.8.0
[INFO] [stderr]     Checking form_urlencoded v1.0.1
[INFO] [stderr]    Compiling unicase v2.6.0
[INFO] [stderr]     Checking url v1.7.2
[INFO] [stderr]    Compiling quote v1.0.14
[INFO] [stderr]     Checking want v0.2.0
[INFO] [stderr]     Checking iovec v0.1.4
[INFO] [stderr]     Checking num_cpus v1.13.1
[INFO] [stderr]     Checking net2 v0.2.37
[INFO] [stderr]     Checking time v0.1.44
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]     Checking tokio-executor v0.1.10
[INFO] [stderr]     Checking crossbeam-queue v0.2.3
[INFO] [stderr]     Checking bytes v0.4.12
[INFO] [stderr]     Checking backtrace v0.3.63
[INFO] [stderr]     Checking url v2.2.2
[INFO] [stderr]     Checking flate2 v1.0.22
[INFO] [stderr]     Checking futures-cpupool v0.1.8
[INFO] [stderr]    Compiling mime_guess v2.0.3
[INFO] [stderr]     Checking mio v0.6.23
[INFO] [stderr]     Checking tokio-current-thread v0.1.7
[INFO] [stderr]     Checking tokio-timer v0.2.13
[INFO] [stderr]     Checking cookie v0.12.0
[INFO] [stderr]     Checking crossbeam-deque v0.7.4
[INFO] [stderr]     Checking tokio-io v0.1.13
[INFO] [stderr]     Checking http v0.1.21
[INFO] [stderr]     Checking tokio-buf v0.1.1
[INFO] [stderr]     Checking string v0.2.1
[INFO] [stderr]     Checking tokio-threadpool v0.1.18
[INFO] [stderr]     Checking publicsuffix v1.5.6
[INFO] [stderr]     Checking tokio-reactor v0.1.12
[INFO] [stderr]     Checking uuid v0.7.4
[INFO] [stderr]     Checking tokio-tcp v0.1.4
[INFO] [stderr]     Checking tokio v0.1.22
[INFO] [stderr]     Checking http-body v0.1.0
[INFO] [stderr]     Checking h2 v0.1.26
[INFO] [stderr]    Compiling synstructure v0.12.6
[INFO] [stderr]    Compiling failure_derive v0.1.8
[INFO] [stderr]     Checking failure v0.1.8
[INFO] [stderr]     Checking hyper-tls v0.3.2
[INFO] [stderr]     Checking serde_json v1.0.74
[INFO] [stderr]     Checking serde_urlencoded v0.5.5
[INFO] [stderr]     Checking cookie_store v0.7.0
[INFO] [stderr]     Checking reqwest v0.9.24
[INFO] [stderr]     Checking sunk v0.1.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `Album`, `Artist`, `Song`
[INFO] [stdout]  --> src/client.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | use {Album, Artist, Error, Genre, Hls, Lyrics, MusicFolder, Result, Song, UrlError, Version};
[INFO] [stdout]   |      ^^^^^  ^^^^^^                                                  ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `md5` is imported redundantly
[INFO] [stdout]    --> src/client.rs:77:17
[INFO] [stdout]     |
[INFO] [stdout] 77  |             use md5;
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/lib.rs:108:1
[INFO] [stdout]     |
[INFO] [stdout] 108 | extern crate md5;
[INFO] [stdout]     | ----------------- the item `md5` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:224:5
[INFO] [stdout]     |
[INFO] [stdout] 224 |     /// Sets the user's username.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:226:5
[INFO] [stdout]     |
[INFO] [stdout] 226 |     /// Sets the user's password.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     /// Set's the user's email.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:230:5
[INFO] [stdout]     |
[INFO] [stdout] 230 |     /// Enables LDAP authentication for the user.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:232:5
[INFO] [stdout]     |
[INFO] [stdout] 232 |     /// Bestows admin rights onto the user.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:234:5
[INFO] [stdout]     |
[INFO] [stdout] 234 |     /// Allows the user to change personal settings and their own password.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:236:5
[INFO] [stdout]     |
[INFO] [stdout] 236 |     /// Allows the user to play files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     /// Allows the user to play files in jukebox mode.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:240:5
[INFO] [stdout]     |
[INFO] [stdout] 240 |     /// Allows the user to download files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:242:5
[INFO] [stdout]     |
[INFO] [stdout] 242 |     /// Allows the user to upload files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:244:5
[INFO] [stdout]     |
[INFO] [stdout] 244 |     /// Allows the user to change cover art and tags.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:246:5
[INFO] [stdout]     |
[INFO] [stdout] 246 |     /// Allows the user to create and edit comments and ratings.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:248:5
[INFO] [stdout]     |
[INFO] [stdout] 248 |     /// Allows the user to administrate podcasts.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:250:5
[INFO] [stdout]     |
[INFO] [stdout] 250 |     /// Allows the user to share files with others.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:252:5
[INFO] [stdout]     |
[INFO] [stdout] 252 |     /// Allows the user to start video coversions.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:254:5
[INFO] [stdout]     |
[INFO] [stdout] 254 |     /// IDs of the music folders the user is allowed to access.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:256:5
[INFO] [stdout]     |
[INFO] [stdout] 256 | /     /// The maximum bit rate (in Kbps) the user is allowed to stream at. Higher
[INFO] [stdout] 257 | |     /// bit rate streams will be downsampled to their limit.
[INFO] [stdout]     | |_____-------------------------------------------------------^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RandomSongs`
[INFO] [stdout]    --> src/lib.rs:147:26
[INFO] [stdout]     |
[INFO] [stdout] 147 | use self::song::{Lyrics, RandomSongs, Song};
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::video::Video`
[INFO] [stdout]    --> src/lib.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 | use self::video::Video;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Album`, `Artist`, `Song`
[INFO] [stdout]  --> src/client.rs:9:6
[INFO] [stdout]   |
[INFO] [stdout] 9 | use {Album, Artist, Error, Genre, Hls, Lyrics, MusicFolder, Result, Song, UrlError, Version};
[INFO] [stdout]   |      ^^^^^  ^^^^^^                                                  ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: the item `md5` is imported redundantly
[INFO] [stdout]    --> src/client.rs:77:17
[INFO] [stdout]     |
[INFO] [stdout] 77  |             use md5;
[INFO] [stdout]     |                 ^^^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/lib.rs:108:1
[INFO] [stdout]     |
[INFO] [stdout] 108 | extern crate md5;
[INFO] [stdout]     | ----------------- the item `md5` is already imported here
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:224:5
[INFO] [stdout]     |
[INFO] [stdout] 224 |     /// Sets the user's username.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_doc_comments)]` on by default
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:226:5
[INFO] [stdout]     |
[INFO] [stdout] 226 |     /// Sets the user's password.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:228:5
[INFO] [stdout]     |
[INFO] [stdout] 228 |     /// Set's the user's email.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:230:5
[INFO] [stdout]     |
[INFO] [stdout] 230 |     /// Enables LDAP authentication for the user.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:232:5
[INFO] [stdout]     |
[INFO] [stdout] 232 |     /// Bestows admin rights onto the user.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:234:5
[INFO] [stdout]     |
[INFO] [stdout] 234 |     /// Allows the user to change personal settings and their own password.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:236:5
[INFO] [stdout]     |
[INFO] [stdout] 236 |     /// Allows the user to play files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:238:5
[INFO] [stdout]     |
[INFO] [stdout] 238 |     /// Allows the user to play files in jukebox mode.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:240:5
[INFO] [stdout]     |
[INFO] [stdout] 240 |     /// Allows the user to download files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:242:5
[INFO] [stdout]     |
[INFO] [stdout] 242 |     /// Allows the user to upload files.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:244:5
[INFO] [stdout]     |
[INFO] [stdout] 244 |     /// Allows the user to change cover art and tags.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:246:5
[INFO] [stdout]     |
[INFO] [stdout] 246 |     /// Allows the user to create and edit comments and ratings.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:248:5
[INFO] [stdout]     |
[INFO] [stdout] 248 |     /// Allows the user to administrate podcasts.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:250:5
[INFO] [stdout]     |
[INFO] [stdout] 250 |     /// Allows the user to share files with others.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:252:5
[INFO] [stdout]     |
[INFO] [stdout] 252 |     /// Allows the user to start video coversions.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:254:5
[INFO] [stdout]     |
[INFO] [stdout] 254 |     /// IDs of the music folders the user is allowed to access.
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused doc comment
[INFO] [stdout]    --> src/user.rs:256:5
[INFO] [stdout]     |
[INFO] [stdout] 256 | /     /// The maximum bit rate (in Kbps) the user is allowed to stream at. Higher
[INFO] [stdout] 257 | |     /// bit rate streams will be downsampled to their limit.
[INFO] [stdout]     | |_____-------------------------------------------------------^
[INFO] [stdout]     |       |
[INFO] [stdout]     |       rustdoc does not generate documentation for macro invocations
[INFO] [stdout]     |
[INFO] [stdout]     = help: to document an item produced by a macro, the macro must produce the documentation as part of its expansion
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `RandomSongs`
[INFO] [stdout]    --> src/lib.rs:147:26
[INFO] [stdout]     |
[INFO] [stdout] 147 | use self::song::{Lyrics, RandomSongs, Song};
[INFO] [stdout]     |                          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::video::Video`
[INFO] [stdout]    --> src/lib.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 | use self::video::Video;
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `failure::core::str::<impl str>::trim_right_matches`: superseded by `trim_end_matches`
[INFO] [stdout]    --> src/media/mod.rs:258:18
[INFO] [stdout]     |
[INFO] [stdout] 258 |                 .trim_right_matches(",")
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_end_matches`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `failure::core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/media/mod.rs:236:29
[INFO] [stdout]     |
[INFO] [stdout] 236 |                 return Ok(s.trim_left_matches(head));
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_start_matches`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `failure::core::str::<impl str>::trim_right_matches`: superseded by `trim_end_matches`
[INFO] [stdout]    --> src/media/mod.rs:258:18
[INFO] [stdout]     |
[INFO] [stdout] 258 |                 .trim_right_matches(",")
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_end_matches`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/collections/album.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |     artist_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/collections/album.rs:134:13
[INFO] [stdout]     |
[INFO] [stdout] 134 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `name`
[INFO] [stdout]   --> src/collections/playlist.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `duration`
[INFO] [stdout]   --> src/collections/playlist.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     duration: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `comment`
[INFO] [stdout]   --> src/collections/playlist.rs:40:13
[INFO] [stdout]    |
[INFO] [stdout] 40 |             comment: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated associated function `failure::core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/media/mod.rs:236:29
[INFO] [stdout]     |
[INFO] [stdout] 236 |                 return Ok(s.trim_left_matches(head));
[INFO] [stdout]     |                             ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_start_matches`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `owner`
[INFO] [stdout]   --> src/collections/playlist.rs:41:13
[INFO] [stdout]    |
[INFO] [stdout] 41 |             owner: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/collections/playlist.rs:44:13
[INFO] [stdout]    |
[INFO] [stdout] 44 |             created: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `changed`
[INFO] [stdout]   --> src/collections/playlist.rs:45:13
[INFO] [stdout]    |
[INFO] [stdout] 45 |             changed: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `get_playlists`
[INFO] [stdout]   --> src/collections/playlist.rs:92:4
[INFO] [stdout]    |
[INFO] [stdout] 92 | fn get_playlists(client: &Client, user: Option<String>) -> Result<Vec<Playlist>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `create_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:106:4
[INFO] [stdout]     |
[INFO] [stdout] 106 | fn create_playlist(client: &Client, name: String, songs: &[u64]) -> Result<Option<Playlist>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `update_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:123:4
[INFO] [stdout]     |
[INFO] [stdout] 123 | fn update_playlist<'a, B, S>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `delete_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:149:4
[INFO] [stdout]     |
[INFO] [stdout] 149 | fn delete_playlist(client: &Client, id: u64) -> Result<()> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `id`
[INFO] [stdout]  --> src/media/podcast.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     id: usize,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `url`
[INFO] [stdout]   --> src/media/podcast.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     url: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]   --> src/media/podcast.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     title: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `description`
[INFO] [stdout]   --> src/media/podcast.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `cover_art`
[INFO] [stdout]   --> src/media/podcast.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     cover_art: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `image_url`
[INFO] [stdout]   --> src/media/podcast.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     image_url: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/media/podcast.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `episodes`
[INFO] [stdout]   --> src/media/podcast.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     episodes: Vec<Episode>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `error`
[INFO] [stdout]   --> src/media/podcast.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     error: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `id`
[INFO] [stdout]   --> src/media/podcast.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     id: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]   --> src/media/podcast.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     parent: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]   --> src/media/podcast.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     is_dir: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]   --> src/media/podcast.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     title: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `album`
[INFO] [stdout]   --> src/media/podcast.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     album: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist`
[INFO] [stdout]   --> src/media/podcast.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     artist: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `year`
[INFO] [stdout]   --> src/media/podcast.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     year: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `cover_art`
[INFO] [stdout]   --> src/media/podcast.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     cover_art: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `size`
[INFO] [stdout]   --> src/media/podcast.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     size: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `content_type`
[INFO] [stdout]   --> src/media/podcast.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     content_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/podcast.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `duration`
[INFO] [stdout]   --> src/media/podcast.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     duration: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bitrate`
[INFO] [stdout]   --> src/media/podcast.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     bitrate: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]   --> src/media/podcast.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     is_video: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/media/podcast.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     created: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/media/podcast.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     artist_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]   --> src/media/podcast.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     media_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `stream_id`
[INFO] [stdout]   --> src/media/podcast.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     stream_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `channel_id`
[INFO] [stdout]   --> src/media/podcast.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     channel_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `description`
[INFO] [stdout]   --> src/media/podcast.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/media/podcast.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `publish_date`
[INFO] [stdout]   --> src/media/podcast.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     publish_date: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `album_id`
[INFO] [stdout]   --> src/media/song.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     album_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/media/song.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     artist_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/song.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]   --> src/media/song.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     transcoded_suffix: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]   --> src/media/song.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     path: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]   --> src/media/song.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     media_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]    --> src/media/song.rs:257:13
[INFO] [stdout]     |
[INFO] [stdout] 257 |             parent: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]    --> src/media/song.rs:258:13
[INFO] [stdout]     |
[INFO] [stdout] 258 |             is_dir: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bit_rate`
[INFO] [stdout]    --> src/media/song.rs:272:13
[INFO] [stdout]     |
[INFO] [stdout] 272 |             bit_rate: Option<u64>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]    --> src/media/song.rs:274:13
[INFO] [stdout]     |
[INFO] [stdout] 274 |             is_video: Option<bool>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `play_count`
[INFO] [stdout]    --> src/media/song.rs:275:13
[INFO] [stdout]     |
[INFO] [stdout] 275 |             play_count: u64,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `disc_number`
[INFO] [stdout]    --> src/media/song.rs:276:13
[INFO] [stdout]     |
[INFO] [stdout] 276 |             disc_number: Option<u64>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/media/song.rs:277:13
[INFO] [stdout]     |
[INFO] [stdout] 277 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]   --> src/media/video.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     parent: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]   --> src/media/video.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     is_dir: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/video.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]   --> src/media/video.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     transcoded_suffix: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bitrate`
[INFO] [stdout]   --> src/media/video.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     bitrate: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]   --> src/media/video.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     path: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]   --> src/media/video.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     is_video: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/media/video.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     created: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `play_count`
[INFO] [stdout]   --> src/media/video.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     play_count: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bookmark_position`
[INFO] [stdout]   --> src/media/video.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     bookmark_position: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `original_height`
[INFO] [stdout]   --> src/media/video.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     original_height: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `original_width`
[INFO] [stdout]   --> src/media/video.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     original_width: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]    --> src/media/mod.rs:302:13
[INFO] [stdout]     |
[INFO] [stdout] 302 |             is_dir: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]    --> src/media/mod.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |             title: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `size`
[INFO] [stdout]    --> src/media/mod.rs:304:13
[INFO] [stdout]     |
[INFO] [stdout] 304 |             size: usize,
[INFO] [stdout]     |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `content_type`
[INFO] [stdout]    --> src/media/mod.rs:305:13
[INFO] [stdout]     |
[INFO] [stdout] 305 |             content_type: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]    --> src/media/mod.rs:306:13
[INFO] [stdout]     |
[INFO] [stdout] 306 |             suffix: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_content_type`
[INFO] [stdout]    --> src/media/mod.rs:307:13
[INFO] [stdout]     |
[INFO] [stdout] 307 |             transcoded_content_type: Option<String>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]    --> src/media/mod.rs:308:13
[INFO] [stdout]     |
[INFO] [stdout] 308 |             transcoded_suffix: Option<String>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]    --> src/media/mod.rs:309:13
[INFO] [stdout]     |
[INFO] [stdout] 309 |             path: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/media/mod.rs:311:13
[INFO] [stdout]     |
[INFO] [stdout] 311 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]    --> src/media/mod.rs:313:13
[INFO] [stdout]     |
[INFO] [stdout] 313 |             media_type: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/response.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `version`
[INFO] [stdout]   --> src/response.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     version: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function is never used: `is_err`
[INFO] [stdout]    --> src/response.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 |     pub fn is_err(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/collections/album.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |     artist_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/collections/album.rs:134:13
[INFO] [stdout]     |
[INFO] [stdout] 134 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `name`
[INFO] [stdout]   --> src/collections/playlist.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `duration`
[INFO] [stdout]   --> src/collections/playlist.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     duration: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `comment`
[INFO] [stdout]   --> src/collections/playlist.rs:40:13
[INFO] [stdout]    |
[INFO] [stdout] 40 |             comment: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `owner`
[INFO] [stdout]   --> src/collections/playlist.rs:41:13
[INFO] [stdout]    |
[INFO] [stdout] 41 |             owner: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/collections/playlist.rs:44:13
[INFO] [stdout]    |
[INFO] [stdout] 44 |             created: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `changed`
[INFO] [stdout]   --> src/collections/playlist.rs:45:13
[INFO] [stdout]    |
[INFO] [stdout] 45 |             changed: String,
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `get_playlists`
[INFO] [stdout]   --> src/collections/playlist.rs:92:4
[INFO] [stdout]    |
[INFO] [stdout] 92 | fn get_playlists(client: &Client, user: Option<String>) -> Result<Vec<Playlist>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `create_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:106:4
[INFO] [stdout]     |
[INFO] [stdout] 106 | fn create_playlist(client: &Client, name: String, songs: &[u64]) -> Result<Option<Playlist>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `update_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:123:4
[INFO] [stdout]     |
[INFO] [stdout] 123 | fn update_playlist<'a, B, S>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function is never used: `delete_playlist`
[INFO] [stdout]    --> src/collections/playlist.rs:149:4
[INFO] [stdout]     |
[INFO] [stdout] 149 | fn delete_playlist(client: &Client, id: u64) -> Result<()> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `id`
[INFO] [stdout]  --> src/media/podcast.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 |     id: usize,
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `url`
[INFO] [stdout]   --> src/media/podcast.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     url: String,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]   --> src/media/podcast.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     title: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `description`
[INFO] [stdout]   --> src/media/podcast.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `cover_art`
[INFO] [stdout]   --> src/media/podcast.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     cover_art: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `image_url`
[INFO] [stdout]   --> src/media/podcast.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     image_url: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/media/podcast.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `episodes`
[INFO] [stdout]   --> src/media/podcast.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     episodes: Vec<Episode>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `error`
[INFO] [stdout]   --> src/media/podcast.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     error: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `id`
[INFO] [stdout]   --> src/media/podcast.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     id: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]   --> src/media/podcast.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     parent: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]   --> src/media/podcast.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     is_dir: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]   --> src/media/podcast.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     title: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `album`
[INFO] [stdout]   --> src/media/podcast.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     album: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist`
[INFO] [stdout]   --> src/media/podcast.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     artist: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `year`
[INFO] [stdout]   --> src/media/podcast.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     year: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `cover_art`
[INFO] [stdout]   --> src/media/podcast.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     cover_art: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `size`
[INFO] [stdout]   --> src/media/podcast.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     size: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `content_type`
[INFO] [stdout]   --> src/media/podcast.rs:31:5
[INFO] [stdout]    |
[INFO] [stdout] 31 |     content_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/podcast.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `duration`
[INFO] [stdout]   --> src/media/podcast.rs:33:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |     duration: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bitrate`
[INFO] [stdout]   --> src/media/podcast.rs:34:5
[INFO] [stdout]    |
[INFO] [stdout] 34 |     bitrate: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]   --> src/media/podcast.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     is_video: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/media/podcast.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     created: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/media/podcast.rs:37:5
[INFO] [stdout]    |
[INFO] [stdout] 37 |     artist_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]   --> src/media/podcast.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     media_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `stream_id`
[INFO] [stdout]   --> src/media/podcast.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     stream_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `channel_id`
[INFO] [stdout]   --> src/media/podcast.rs:40:5
[INFO] [stdout]    |
[INFO] [stdout] 40 |     channel_id: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `description`
[INFO] [stdout]   --> src/media/podcast.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 |     description: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/media/podcast.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `publish_date`
[INFO] [stdout]   --> src/media/podcast.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     publish_date: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `album_id`
[INFO] [stdout]   --> src/media/song.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     album_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `artist_id`
[INFO] [stdout]   --> src/media/song.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     artist_id: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/song.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]   --> src/media/song.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     transcoded_suffix: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]   --> src/media/song.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     path: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]   --> src/media/song.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     media_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]    --> src/media/song.rs:257:13
[INFO] [stdout]     |
[INFO] [stdout] 257 |             parent: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]    --> src/media/song.rs:258:13
[INFO] [stdout]     |
[INFO] [stdout] 258 |             is_dir: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bit_rate`
[INFO] [stdout]    --> src/media/song.rs:272:13
[INFO] [stdout]     |
[INFO] [stdout] 272 |             bit_rate: Option<u64>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]    --> src/media/song.rs:274:13
[INFO] [stdout]     |
[INFO] [stdout] 274 |             is_video: Option<bool>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `play_count`
[INFO] [stdout]    --> src/media/song.rs:275:13
[INFO] [stdout]     |
[INFO] [stdout] 275 |             play_count: u64,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `disc_number`
[INFO] [stdout]    --> src/media/song.rs:276:13
[INFO] [stdout]     |
[INFO] [stdout] 276 |             disc_number: Option<u64>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/media/song.rs:277:13
[INFO] [stdout]     |
[INFO] [stdout] 277 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `parent`
[INFO] [stdout]   --> src/media/video.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     parent: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]   --> src/media/video.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     is_dir: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]   --> src/media/video.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     suffix: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]   --> src/media/video.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 |     transcoded_suffix: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bitrate`
[INFO] [stdout]   --> src/media/video.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |     bitrate: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]   --> src/media/video.rs:23:5
[INFO] [stdout]    |
[INFO] [stdout] 23 |     path: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_video`
[INFO] [stdout]   --> src/media/video.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 |     is_video: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]   --> src/media/video.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 25 |     created: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `play_count`
[INFO] [stdout]   --> src/media/video.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 |     play_count: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `bookmark_position`
[INFO] [stdout]   --> src/media/video.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 |     bookmark_position: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `original_height`
[INFO] [stdout]   --> src/media/video.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     original_height: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `original_width`
[INFO] [stdout]   --> src/media/video.rs:30:5
[INFO] [stdout]    |
[INFO] [stdout] 30 |     original_width: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `is_dir`
[INFO] [stdout]    --> src/media/mod.rs:302:13
[INFO] [stdout]     |
[INFO] [stdout] 302 |             is_dir: bool,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `title`
[INFO] [stdout]    --> src/media/mod.rs:303:13
[INFO] [stdout]     |
[INFO] [stdout] 303 |             title: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `size`
[INFO] [stdout]    --> src/media/mod.rs:304:13
[INFO] [stdout]     |
[INFO] [stdout] 304 |             size: usize,
[INFO] [stdout]     |             ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `content_type`
[INFO] [stdout]    --> src/media/mod.rs:305:13
[INFO] [stdout]     |
[INFO] [stdout] 305 |             content_type: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `suffix`
[INFO] [stdout]    --> src/media/mod.rs:306:13
[INFO] [stdout]     |
[INFO] [stdout] 306 |             suffix: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_content_type`
[INFO] [stdout]    --> src/media/mod.rs:307:13
[INFO] [stdout]     |
[INFO] [stdout] 307 |             transcoded_content_type: Option<String>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `transcoded_suffix`
[INFO] [stdout]    --> src/media/mod.rs:308:13
[INFO] [stdout]     |
[INFO] [stdout] 308 |             transcoded_suffix: Option<String>,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `path`
[INFO] [stdout]    --> src/media/mod.rs:309:13
[INFO] [stdout]     |
[INFO] [stdout] 309 |             path: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `created`
[INFO] [stdout]    --> src/media/mod.rs:311:13
[INFO] [stdout]     |
[INFO] [stdout] 311 |             created: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `media_type`
[INFO] [stdout]    --> src/media/mod.rs:313:13
[INFO] [stdout]     |
[INFO] [stdout] 313 |             media_type: String,
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `status`
[INFO] [stdout]   --> src/response.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     status: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field is never read: `version`
[INFO] [stdout]   --> src/response.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     version: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function is never used: `is_err`
[INFO] [stdout]    --> src/response.rs:148:12
[INFO] [stdout]     |
[INFO] [stdout] 148 |     pub fn is_err(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an enum
[INFO] [stdout]   --> src/collections/album.rs:10:1
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum ListType {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout] note: the lint level is defined here
[INFO] [stdout]   --> src/lib.rs:1:9
[INFO] [stdout]    |
[INFO] [stdout] 1  | #![warn(missing_docs)]
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     AlphaByArtist,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     AlphaByName,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     Frequent,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     Highest,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 |     Newest,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     Random,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Recent,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a variant
[INFO] [stdout]   --> src/collections/album.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     Starred,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> src/collections/album.rs:51:1
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct Album {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 52 |     pub id: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:54:5
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub artist: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:57:5
[INFO] [stdout]    |
[INFO] [stdout] 57 |     pub duration: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub year: Option<u64>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:59:5
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub genre: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/album.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     pub song_count: u64,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]    --> src/collections/album.rs:187:1
[INFO] [stdout]     |
[INFO] [stdout] 187 | pub struct AlbumInfo {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/collections/album.rs:188:5
[INFO] [stdout]     |
[INFO] [stdout] 188 |     pub notes: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/collections/album.rs:189:5
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub lastfm_url: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/collections/album.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     pub musicbrainz_id: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/collections/album.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 191 |     pub image_urls: (String, String, String),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/artist.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub id: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/artist.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/collections/artist.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub album_count: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/collections/artist.rs:35:5
[INFO] [stdout]    |
[INFO] [stdout] 35 |     pub fn get(client: &Client, id: usize) -> Result<Artist> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> src/collections/playlist.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Playlist {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]  --> src/media/mod.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub mod podcast;
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> src/media/podcast.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct Podcast {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]   --> src/media/podcast.rs:21:1
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct Episode {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> src/media/radio.rs:8:1
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct RadioStation {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/radio.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub name: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/radio.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 |     pub stream_url: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/radio.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 |     pub homepage_url: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/radio.rs:39:5
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub fn id(&self) -> usize {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/radio.rs:43:5
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub fn list(client: &Client) -> Result<Vec<RadioStation>> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/radio.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     pub fn create(client: &Client, name: &str, url: &str, homepage: Option<&str>) -> Result<()> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/radio.rs:58:5
[INFO] [stdout]    |
[INFO] [stdout] 58 |     pub fn update(&self, client: &Client) -> Result<()> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/radio.rs:71:5
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub fn delete(&self, client: &Client) -> Result<()> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]   --> src/media/mod.rs:11:1
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub mod song;
[INFO] [stdout]    | ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a module
[INFO] [stdout]   --> src/media/mod.rs:12:1
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub mod video;
[INFO] [stdout]    | ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> src/media/video.rs:9:1
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct Video {
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |     pub id: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 |     pub title: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 |     pub album: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 |     pub size: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     pub duration: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/media/video.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 27 |     pub media_type: String,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/video.rs:38:5
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub fn get(client: &Client, id: usize) -> Result<Video> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/video.rs:45:5
[INFO] [stdout]    |
[INFO] [stdout] 45 |     pub fn list(client: &Client) -> Result<Vec<Video>> {
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]   --> src/media/video.rs:50:5
[INFO] [stdout]    |
[INFO] [stdout] 50 | /     pub fn info<'a, S>(&self, client: &Client, format: S) -> Result<VideoInfo>
[INFO] [stdout] 51 | |     where
[INFO] [stdout] 52 | |         S: Into<Option<&'a str>>,
[INFO] [stdout] 53 | |     {
[INFO] [stdout] ...  |
[INFO] [stdout] 58 | |         Ok(serde_json::from_value(res)?)
[INFO] [stdout] 59 | |     }
[INFO] [stdout]    | |_____^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]    --> src/media/video.rs:229:1
[INFO] [stdout]     |
[INFO] [stdout] 229 | pub struct VideoInfo {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:230:5
[INFO] [stdout]     |
[INFO] [stdout] 230 |     pub id: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:231:5
[INFO] [stdout]     |
[INFO] [stdout] 231 |     pub captions: Option<Captions>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:232:5
[INFO] [stdout]     |
[INFO] [stdout] 232 |     pub audio_tracks: Vec<AudioTrack>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:233:5
[INFO] [stdout]     |
[INFO] [stdout] 233 |     pub conversion: Option<Conversion>,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]    --> src/media/video.rs:261:1
[INFO] [stdout]     |
[INFO] [stdout] 261 | pub struct AudioTrack {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:262:5
[INFO] [stdout]     |
[INFO] [stdout] 262 |     pub id: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:263:5
[INFO] [stdout]     |
[INFO] [stdout] 263 |     pub name: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:264:5
[INFO] [stdout]     |
[INFO] [stdout] 264 |     pub language_code: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]    --> src/media/video.rs:289:1
[INFO] [stdout]     |
[INFO] [stdout] 289 | pub struct Captions {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:290:5
[INFO] [stdout]     |
[INFO] [stdout] 290 |     pub id: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:291:5
[INFO] [stdout]     |
[INFO] [stdout] 291 |     pub name: String,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]    --> src/media/video.rs:313:1
[INFO] [stdout]     |
[INFO] [stdout] 313 | pub struct Conversion {
[INFO] [stdout]     | ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:314:5
[INFO] [stdout]     |
[INFO] [stdout] 314 |     pub id: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]    --> src/media/video.rs:315:5
[INFO] [stdout]     |
[INFO] [stdout] 315 |     pub bitrate: usize,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct field
[INFO] [stdout]   --> src/jukebox.rs:29:5
[INFO] [stdout]    |
[INFO] [stdout] 29 |     pub position: usize,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 225 |     build!(username: &str);
[INFO] [stdout]     |     ---------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 227 |     build!(password: &str);
[INFO] [stdout]     |     ---------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     build!(email: &str);
[INFO] [stdout]     |     ------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 231 |     build!(ldap_authenticated: bool);
[INFO] [stdout]     |     -------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     build!(admin_role: bool);
[INFO] [stdout]     |     ------------------------ in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 235 |     build!(settings_role: bool);
[INFO] [stdout]     |     --------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 237 |     build!(stream_role: bool);
[INFO] [stdout]     |     ------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 239 |     build!(jukebox_role: bool);
[INFO] [stdout]     |     -------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     build!(download_role: bool);
[INFO] [stdout]     |     --------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 243 |     build!(upload_role: bool);
[INFO] [stdout]     |     ------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 245 |     build!(cover_art_role: bool);
[INFO] [stdout]     |     ---------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 247 |     build!(comment_role: bool);
[INFO] [stdout]     |     -------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 249 |     build!(podcast_role: bool);
[INFO] [stdout]     |     -------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 251 |     build!(share_role: bool);
[INFO] [stdout]     |     ------------------------ in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 253 |     build!(video_conversion_role: bool);
[INFO] [stdout]     |     ----------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 255 |     build!(folders: &[u64]);
[INFO] [stdout]     |     ----------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for an associated function
[INFO] [stdout]    --> src/user.rs:206:9
[INFO] [stdout]     |
[INFO] [stdout] 206 |         pub fn $f(&mut self, $f: $t) -> &mut UserBuilder {
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 258 |     build!(max_bit_rate: u64);
[INFO] [stdout]     |     ------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = note: this warning originates in the macro `build` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: missing documentation for a struct
[INFO] [stdout]  --> src/version.rs:4:1
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Version(u8, u8, u8);
[INFO] [stdout]   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 104 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: 189 warnings emitted
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished dev [unoptimized + debuginfo] target(s) in 2m 55s
[INFO] running `Command { std: "docker" "inspect" "0c9d57a3b1287317bae19a6e0a92a1ab897d8f92feca8117429007228b84f72f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0c9d57a3b1287317bae19a6e0a92a1ab897d8f92feca8117429007228b84f72f", kill_on_drop: false }`
[INFO] [stdout] 0c9d57a3b1287317bae19a6e0a92a1ab897d8f92feca8117429007228b84f72f