[INFO] fetching crate rustyll 0.8.4...
[INFO] testing rustyll-0.8.4 against try#db823df02fd0c2cf67b43025ac3fef3f2d743245 for pr-150681
[INFO] extracting crate rustyll 0.8.4 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate rustyll 0.8.4
[INFO] finished tweaking crates.io crate rustyll 0.8.4
[INFO] tweaked toml for crates.io crate rustyll 0.8.4 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate rustyll 0.8.4 on toolchain db823df02fd0c2cf67b43025ac3fef3f2d743245
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate rustyll 0.8.4 already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fd3bff120730016ba8317412878b3d3ad9e0ed180a49fbad819db723efdb29b4
[INFO] running `Command { std: "docker" "start" "-a" "fd3bff120730016ba8317412878b3d3ad9e0ed180a49fbad819db723efdb29b4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fd3bff120730016ba8317412878b3d3ad9e0ed180a49fbad819db723efdb29b4", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fd3bff120730016ba8317412878b3d3ad9e0ed180a49fbad819db723efdb29b4", kill_on_drop: false }`
[INFO] [stdout] fd3bff120730016ba8317412878b3d3ad9e0ed180a49fbad819db723efdb29b4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 61ee5b2b21cab2405304a7220a4a06b73c5b38faf9f62b3e75b8452328f32471
[INFO] running `Command { std: "docker" "start" "-a" "61ee5b2b21cab2405304a7220a4a06b73c5b38faf9f62b3e75b8452328f32471", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]    Compiling smallvec v1.15.0
[INFO] [stderr]    Compiling hashbrown v0.15.3
[INFO] [stderr]    Compiling dunce v1.0.5
[INFO] [stderr]    Compiling fs_extra v1.3.0
[INFO] [stderr]    Compiling tracing-core v0.1.33
[INFO] [stderr]    Compiling num_threads v0.1.7
[INFO] [stderr]    Compiling ucd-trie v0.1.7
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling rustversion v1.0.20
[INFO] [stderr]    Compiling aws-lc-rs v1.13.1
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]    Compiling yaml-rust v0.4.5
[INFO] [stderr]    Compiling miniz_oxide v0.8.8
[INFO] [stderr]    Compiling crc32fast v1.4.2
[INFO] [stderr]    Compiling prettyplease v0.2.32
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling unicase v2.8.1
[INFO] [stderr]    Compiling rustls v0.23.27
[INFO] [stderr]    Compiling tinyvec v1.9.0
[INFO] [stderr]    Compiling hashbrown v0.14.5
[INFO] [stderr]    Compiling anstream v0.6.18
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling itertools v0.14.0
[INFO] [stderr]    Compiling quick-xml v0.32.0
[INFO] [stderr]    Compiling indexmap v2.9.0
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling flate2 v1.1.1
[INFO] [stderr]    Compiling fs-err v3.1.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling anymap2 v0.13.0
[INFO] [stderr]    Compiling sync_wrapper v1.0.2
[INFO] [stderr]    Compiling clap_lex v0.7.4
[INFO] [stderr]    Compiling brotli v8.0.1
[INFO] [stderr]    Compiling encoding_rs v0.8.35
[INFO] [stderr]    Compiling arraydeque v0.5.1
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling terminal_size v0.4.2
[INFO] [stderr]    Compiling jobserver v0.1.33
[INFO] [stderr]    Compiling parking_lot_core v0.9.10
[INFO] [stderr]    Compiling mio v1.0.3
[INFO] [stderr]    Compiling socket2 v0.5.9
[INFO] [stderr]    Compiling signal-hook-registry v1.4.5
[INFO] [stderr]    Compiling time v0.3.41
[INFO] [stderr]    Compiling clap_builder v4.5.38
[INFO] [stderr]    Compiling cc v1.2.23
[INFO] [stderr]    Compiling parking_lot v0.12.3
[INFO] [stderr]    Compiling unicode-normalization v0.1.24
[INFO] [stderr]    Compiling hashlink v0.8.4
[INFO] [stderr]    Compiling inotify-sys v0.1.5
[INFO] [stderr]    Compiling toml_write v0.1.1
[INFO] [stderr]    Compiling deunicode v1.6.2
[INFO] [stderr]    Compiling winnow v0.7.10
[INFO] [stderr]    Compiling colored v2.2.0
[INFO] [stderr]    Compiling inotify v0.11.0
[INFO] [stderr]    Compiling filetime v0.2.25
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling slug v0.1.6
[INFO] [stderr]    Compiling caseless v0.2.2
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling axum-core v0.5.2
[INFO] [stderr]    Compiling rustls-pemfile v2.2.0
[INFO] [stderr]    Compiling cmake v0.1.54
[INFO] [stderr]    Compiling yaml-rust2 v0.8.1
[INFO] [stderr]    Compiling csv-core v0.1.12
[INFO] [stderr]    Compiling unsafe-libyaml v0.2.11
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling shell-words v1.1.0
[INFO] [stderr]    Compiling matchit v0.8.4
[INFO] [stderr]    Compiling arc-swap v1.7.1
[INFO] [stderr]    Compiling http-range-header v0.4.2
[INFO] [stderr]    Compiling entities v1.0.1
[INFO] [stderr]    Compiling utf8-width v0.1.7
[INFO] [stderr]    Compiling xdg v2.5.2
[INFO] [stderr]    Compiling unicode_categories v0.1.1
[INFO] [stderr]    Compiling typed-arena v2.0.2
[INFO] [stderr]    Compiling chrono v0.4.41
[INFO] [stderr]    Compiling simple_logger v5.0.0
[INFO] [stderr]    Compiling html-escape v0.2.13
[INFO] [stderr]    Compiling aws-lc-sys v0.29.0
[INFO] [stderr]    Compiling onig_sys v69.8.1
[INFO] [stderr]    Compiling sha2 v0.10.9
[INFO] [stderr]    Compiling rayon v1.10.0
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling frontmatter v0.4.0
[INFO] [stderr]    Compiling glob v0.3.2
[INFO] [stderr]    Compiling glob-match v0.2.1
[INFO] [stderr]    Compiling urlencoding v2.1.3
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling liquid-derive v0.26.10
[INFO] [stderr]    Compiling onig v6.4.0
[INFO] [stderr]    Compiling clap_derive v4.5.32
[INFO] [stderr]    Compiling tokio v1.45.0
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling futures-util v0.3.31
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling bon-macros v3.6.3
[INFO] [stderr]    Compiling thiserror v2.0.12
[INFO] [stderr]    Compiling pest v2.8.0
[INFO] [stderr]    Compiling clap v4.5.38
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling pest_meta v2.8.0
[INFO] [stderr]    Compiling pest_generator v2.8.0
[INFO] [stderr]    Compiling pest_derive v2.8.0
[INFO] [stderr]    Compiling bon v3.6.3
[INFO] [stderr]    Compiling kstring v2.0.2
[INFO] [stderr]    Compiling toml_datetime v0.6.9
[INFO] [stderr]    Compiling plist v1.7.1
[INFO] [stderr]    Compiling bincode v1.3.3
[INFO] [stderr]    Compiling serde_spanned v0.6.8
[INFO] [stderr]    Compiling serde_path_to_error v0.1.17
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling toml v0.5.11
[INFO] [stderr]    Compiling notify-types v2.0.0
[INFO] [stderr]    Compiling serde_yaml v0.8.26
[INFO] [stderr]    Compiling serde_yaml v0.9.34+deprecated
[INFO] [stderr]    Compiling tokio-util v0.7.15
[INFO] [stderr]    Compiling liquid-core v0.26.11
[INFO] [stderr]    Compiling toml_edit v0.22.26
[INFO] [stderr]    Compiling async-compression v0.4.23
[INFO] [stderr]    Compiling tower v0.5.2
[INFO] [stderr]    Compiling notify v8.0.0
[INFO] [stderr]    Compiling csv v1.3.1
[INFO] [stderr]    Compiling h2 v0.4.10
[INFO] [stderr]    Compiling yaml-front-matter v0.1.0
[INFO] [stderr]    Compiling syntect v5.2.0
[INFO] [stderr]    Compiling gray_matter v0.2.8
[INFO] [stderr]    Compiling tower-http v0.6.4
[INFO] [stderr]    Compiling toml v0.8.22
[INFO] [stderr]    Compiling liquid-lib v0.26.11
[INFO] [stderr]    Compiling comrak v0.39.0
[INFO] [stderr]    Compiling liquid v0.26.11
[INFO] [stderr]    Compiling rustls-webpki v0.103.3
[INFO] [stderr]    Compiling hyper v1.6.0
[INFO] [stderr]    Compiling hyper-util v0.1.12
[INFO] [stderr]    Compiling axum v0.8.4
[INFO] [stderr]    Compiling tokio-rustls v0.26.2
[INFO] [stderr]    Compiling axum-server v0.7.2
[INFO] [stderr]    Compiling rustyll v0.8.4 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `dir`
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:19
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |                   ^^^ help: if this is intentional, prefix it with an underscore: `_dir`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collection`
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:31
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yaml_str`
[INFO] [stdout]   --> src/front_matter/defaults.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |     let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yaml_str`
[INFO] [stdout]    --> src/front_matter/defaults.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `suffix`
[INFO] [stdout]    --> src/liquid/preprocess.rs:105:13
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let suffix = &caps[2];   // The trim marker and closing %}
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_suffix`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `includes`
[INFO] [stdout]    --> src/liquid/mod.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 118 |     includes: HashMap<String, String>
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_dir`
[INFO] [stdout]   --> src/report/links.rs:85:5
[INFO] [stdout]    |
[INFO] [stdout] 85 |     base_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/report/mod.rs:173:53
[INFO] [stdout]     |
[INFO] [stdout] 173 | pub fn generate_console_report(report: &SiteReport, verbose: bool) -> String {
[INFO] [stdout]     |                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `post_dir`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:127:51
[INFO] [stdout]     |
[INFO] [stdout] 127 | ...self, file_path: &Path, post_dir: &Path, posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), Strin...
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_post_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:127:91
[INFO] [stdout]     |
[INFO] [stdout] 127 | ..., posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:246:68
[INFO] [stdout]     |
[INFO] [stdout] 246 | ...                   processed_post_dirs: &Vec<PathBuf>, verbose: bool, 
[INFO] [stdout]     |                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_page`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:278:29
[INFO] [stdout]     |
[INFO] [stdout] 278 |                         let is_page = true;
[INFO] [stdout]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_page`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content_dir`
[INFO] [stdout]   --> src/migrate/engines/zola/content.rs:68:44
[INFO] [stdout]    |
[INFO] [stdout] 68 | fn process_blog_directory(blog_dir: &Path, content_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), St...
[INFO] [stdout]    |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_posts_dir`
[INFO] [stdout]    --> src/migrate/engines/zola/content.rs:131:78
[INFO] [stdout]     |
[INFO] [stdout] 131 | ...pages_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_posts_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/migrate/engines/zola/data.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     result: &mut MigrationResult,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `options`
[INFO] [stdout]   --> src/migrate/engines/gatsby/mod.rs:29:23
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn migrate(&self, options: &MigrationOptions) -> Result<MigrationResult, String> {
[INFO] [stdout]    |                       ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_options`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/config.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 52 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/config.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `in_frontmatter` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:92:9
[INFO] [stdout]    |
[INFO] [stdout] 92 |     let mut in_frontmatter = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_in_frontmatter` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `has_frontmatter` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |     let mut has_frontmatter = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_has_frontmatter` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `in_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:102:9
[INFO] [stdout]     |
[INFO] [stdout] 102 |         in_frontmatter = true;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `in_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |         in_frontmatter = false;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `has_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:101:9
[INFO] [stdout]     |
[INFO] [stdout] 101 |         has_frontmatter = true;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/layouts.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/partials.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 74 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/data.rs:80:5
[INFO] [stdout]    |
[INFO] [stdout] 80 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:111:5
[INFO] [stdout]     |
[INFO] [stdout] 111 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/assets.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/assets.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/assets.rs:250:5
[INFO] [stdout]     |
[INFO] [stdout] 250 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/config.rs:126:5
[INFO] [stdout]     |
[INFO] [stdout] 126 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `theme_content`
[INFO] [stdout]    --> src/migrate/engines/mdbook/config.rs:150:25
[INFO] [stdout]     |
[INFO] [stdout] 150 | fn extract_theme_config(theme_content: &str) -> Result<String, String> {
[INFO] [stdout]     |                         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_theme_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/content.rs:62:5
[INFO] [stdout]    |
[INFO] [stdout] 62 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/content.rs:106:5
[INFO] [stdout]     |
[INFO] [stdout] 106 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/theme.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:231:5
[INFO] [stdout]     |
[INFO] [stdout] 231 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:280:5
[INFO] [stdout]     |
[INFO] [stdout] 280 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:306:5
[INFO] [stdout]     |
[INFO] [stdout] 306 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/preprocessors.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:103:5
[INFO] [stdout]     |
[INFO] [stdout] 103 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 150 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 95 |     config: &toml::Value,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 96 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/renderers.rs:135:5
[INFO] [stdout]     |
[INFO] [stdout] 135 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/renderers.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]  --> src/migrate/engines/mdbook/search.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     source_dir: &Path,
[INFO] [stdout]   |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/static_files.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/static_files.rs:80:5
[INFO] [stdout]    |
[INFO] [stdout] 80 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_path`
[INFO] [stdout]    --> src/migrate/engines/mkdocs/content.rs:147:48
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn get_permalink_from_path(source_path: &Path, dest_path: &Path) -> Result<String, String> {
[INFO] [stdout]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `custom_dir`
[INFO] [stdout]   --> src/migrate/engines/mkdocs/layouts.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 |     let custom_dir = source_dir.join("custom_theme");
[INFO] [stdout]    |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_custom_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/migrate/engines/mkdocs/data.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     result: &mut MigrationResult,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other_config`
[INFO] [stdout]   --> src/migrate/engines/gitbook/config.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |         let other_config = serde_yaml::Mapping::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_other_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `found_summary` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/gitbook/content.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |         let mut found_summary = false;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_found_summary` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_summary` is never read
[INFO] [stdout]   --> src/migrate/engines/gitbook/content.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             found_summary = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `found_assets` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let mut found_assets = false;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_found_assets` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_assets` is never read
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 39 |                 found_assets = true;
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:59:59
[INFO] [stdout]    |
[INFO] [stdout] 59 | ...f, assets_dir: &Path, source_dir: &Path, dest_assets_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `processed` is never read
[INFO] [stdout]    --> src/migrate/engines/slate/content.rs:151:25
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut processed = content.to_string();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/layouts.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ext`
[INFO] [stdout]   --> src/migrate/engines/slate/includes.rs:64:36
[INFO] [stdout]    |
[INFO] [stdout] 64 |     let new_filename = if let Some(ext) = dest_path.extension() {
[INFO] [stdout]    |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_ext`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/assets.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     dest_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/assets.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     dest_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content_dir`
[INFO] [stdout]   --> src/migrate/engines/pelican/content.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 52 |     content_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `post_name` is never read
[INFO] [stdout]    --> src/migrate/engines/pelican/content.rs:161:29
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let mut post_name = String::new();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/migrate/engines/pelican/plugins.rs:229:23
[INFO] [stdout]     |
[INFO] [stdout] 174 |         "related_posts" | "toc" | "table_of_contents" | "archives" | "redirect" | 
[INFO] [stdout]     |         --------------- matches all the relevant values
[INFO] [stdout] ...
[INFO] [stdout] 229 |         "neighbors" | "related_posts" => {
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/pelican/translations.rs:332:21
[INFO] [stdout]     |
[INFO] [stdout] 332 |                 let file_name = file_path.file_name().unwrap().to_string_lossy();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:46:74
[INFO] [stdout]    |
[INFO] [stdout] 46 |     fn migrate_content_file(&self, file_path: &Path, content_dir: &Path, dest_dir: &Path, 
[INFO] [stdout]    |                                                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:48:27
[INFO] [stdout]    |
[INFO] [stdout] 48 |                           verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_content`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:74:51
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn process_blog_post(&self, file_path: &Path, original_content: &str, metadata: &Vec<(String, String)>, 
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_content`
[INFO] [stdout]    --> src/migrate/engines/nanoc/content.rs:141:63
[INFO] [stdout]     |
[INFO] [stdout] 141 |     fn process_page(&self, file_path: &Path, rel_path: &Path, original_content: &str, 
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/nanoc/layouts.rs:117:53
[INFO] [stdout]     |
[INFO] [stdout] 117 |     fn process_html_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stdout]     |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/nanoc/layouts.rs:147:52
[INFO] [stdout]     |
[INFO] [stdout] 147 |     fn process_erb_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stdout]     |                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_dir`
[INFO] [stdout]    --> src/migrate/engines/nanoc/data.rs:175:56
[INFO] [stdout]     |
[INFO] [stdout] 175 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/content.rs:192:51
[INFO] [stdout]     |
[INFO] [stdout] 192 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/content.rs:253:37
[INFO] [stdout]     |
[INFO] [stdout] 253 |     fn create_sample_content(&self, dest_dir: &Path, pages_dir: &Path, posts_dir: &Path, result: &mut MigrationResult) -> Result<()...
[INFO] [stdout]     |                                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `includes_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/layouts.rs:230:56
[INFO] [stdout]     |
[INFO] [stdout] 230 |     fn create_basic_layouts(&self, layouts_dir: &Path, includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]    --> src/migrate/engines/assemble/layouts.rs:525:21
[INFO] [stdout]     |
[INFO] [stdout] 525 |         if let Some(context) = caps.get(2) {
[INFO] [stdout]     |                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/data.rs:252:53
[INFO] [stdout]     |
[INFO] [stdout] 252 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/content.rs:106:51
[INFO] [stdout]     |
[INFO] [stdout] 106 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `captures`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/content.rs:120:42
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let dest_file_name = if let Some(captures) = date_regex.captures(&file_name) {
[INFO] [stdout]     |                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_captures`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/plugins.rs:160:5
[INFO] [stdout]     |
[INFO] [stdout] 160 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_file`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/assets.rs:307:5
[INFO] [stdout]     |
[INFO] [stdout] 307 |     source_file: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/assets.rs:310:5
[INFO] [stdout]     |
[INFO] [stdout] 310 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/cobalt/content.rs:114:51
[INFO] [stdout]     |
[INFO] [stdout] 114 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/cobalt/plugins.rs:104:5
[INFO] [stdout]     |
[INFO] [stdout] 104 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/cobalt/plugins.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `import_map_path`
[INFO] [stdout]   --> src/migrate/engines/fresh/config.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let import_map_path = source_dir.join("import_map.json");
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_import_map_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dev_path`
[INFO] [stdout]   --> src/migrate/engines/fresh/config.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let dev_path = source_dir.join("dev.ts");
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dev_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]   --> src/migrate/engines/fresh/routes.rs:65:9
[INFO] [stdout]    |
[INFO] [stdout] 65 |     let file_name = route_path.file_name().unwrap().to_string_lossy();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `has_props`
[INFO] [stdout]   --> src/migrate/engines/fresh/components.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |     let has_props = regex::Regex::new(props_pattern).unwrap().is_match(&content);
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_has_props`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content`
[INFO] [stdout]   --> src/migrate/engines/fresh/islands.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let content = fs::read_to_string(source_path)
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_content` is never read
[INFO] [stdout]   --> src/migrate/engines/harp/content.rs:29:33
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let mut found_content = false;
[INFO] [stdout]    |                                 ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_content` is never read
[INFO] [stdout]   --> src/migrate/engines/harp/content.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 found_content = true;
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/harp/content.rs:480:54
[INFO] [stdout]     |
[INFO] [stdout] 480 | fn extract_metadata_from_data_json(file_path: &Path, source_dir: &Path) -> Result<std::collections::HashMap<String, String>, String> {
[INFO] [stdout]     |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/harp/partials.rs:82:54
[INFO] [stdout]    |
[INFO] [stdout] 82 | ...lf, file_path: &Path, source_dir: &Path, dest_includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/harp/static_assets.rs:145:51
[INFO] [stdout]     |
[INFO] [stdout] 145 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, asset_type: &str, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/config.rs:107:5
[INFO] [stdout]     |
[INFO] [stdout] 107 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/collections.rs:168:5
[INFO] [stdout]     |
[INFO] [stdout] 168 |     dest_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/collections.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `params`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/helpers.rs:240:38
[INFO] [stdout]     |
[INFO] [stdout] 240 |             if let (Some(name), Some(params), Some(body)) = (cap.get(1), cap.get(2), cap.get(3)) {
[INFO] [stdout]     |                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_params`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/jigsaw/assets.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `relative_path`
[INFO] [stdout]   --> src/migrate/engines/metalsmith/metadata.rs:54:17
[INFO] [stdout]    |
[INFO] [stdout] 54 |             let relative_path = entry.path().strip_prefix(metadata_dir)
[INFO] [stdout]    |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/nikola/content.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/nikola/content.rs:132:5
[INFO] [stdout]     |
[INFO] [stdout] 132 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/nikola/layouts.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `current_section` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/octopress/config.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let mut current_section = None;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_current_section` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_section` is never read
[INFO] [stdout]   --> src/migrate/engines/octopress/config.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |             current_section = Some(trimmed.trim_start_matches('#').trim().to_lowercase());
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/octopress/content.rs:103:5
[INFO] [stdout]     |
[INFO] [stdout] 103 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/octopress/content.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `html`
[INFO] [stdout]    --> src/plugins/mod.rs:343:37
[INFO] [stdout]     |
[INFO] [stdout] 343 |                         if let Some(html) = content.as_str() {
[INFO] [stdout]     |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_html`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]    --> src/plugins/mod.rs:398:44
[INFO] [stdout]     |
[INFO] [stdout] 398 |         fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult {
[INFO] [stdout]     |                                            ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_markdown_file` is never used
[INFO] [stdout]   --> src/builder/site/mod.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub fn is_markdown_file(path: &Path, config: &Config) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `needs_rebuild` and `get_affected_files` are never used
[INFO] [stdout]    --> src/builder/site/builder.rs:95:8
[INFO] [stdout]     |
[INFO] [stdout]  38 | impl IncrementalCache {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  95 |     fn needs_rebuild(&self, path: &Path) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn get_affected_files(&self, path: &Path) -> HashSet<PathBuf> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_excluded` is never used
[INFO] [stdout]    --> src/builder/site/builder.rs:691:8
[INFO] [stdout]     |
[INFO] [stdout] 691 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `relative_path` is never read
[INFO] [stdout]   --> src/builder/page/model.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct Page {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout]  9 |     pub path: PathBuf,
[INFO] [stdout] 10 |     pub relative_path: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Page` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `yaml_to_any` is never used
[INFO] [stdout]   --> src/builder/processor/yaml.rs:76:8
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn yaml_to_any(yaml: YamlValue) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `livereload_port` is never read
[INFO] [stdout]   --> src/server/config/server_config.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub struct ServerConfig {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub livereload_port: Option<u16>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ServerConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/server/config/server_config.rs:89:12
[INFO] [stdout]     |
[INFO] [stdout]  70 | impl ServerConfig {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub fn with_detach(mut self, detach: bool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn with_baseurl(mut self, baseurl: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn with_livereload_port(mut self, port: u16) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn with_ssl(mut self, cert: PathBuf, key: PathBuf) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn with_dir_listing(mut self, show: bool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn with_livereload_ignore(mut self, patterns: Vec<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn with_livereload_delays(mut self, min: u64, max: u64) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIRECTORY_INDEX` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const DIRECTORY_INDEX: [&str; 9] = [
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_static_files_handler` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn create_static_files_handler(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_index_file` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:43:14
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub async fn find_index_file(directory: &FilePath) -> Option<Response> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `livereload_url` is never used
[INFO] [stdout]   --> src/server/livereload/watcher.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn livereload_url(host: &str, port: u16) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LiveReloadHandler` is never constructed
[INFO] [stdout]  --> src/server/livereload/handler.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct LiveReloadHandler {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/server/livereload/handler.rs:23:12
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl LiveReloadHandler {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  22 |     /// Create a new LiveReload handler
[INFO] [stdout]  23 |     pub fn new(port: u16, ignore_patterns: Vec<String>, min_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn should_ignore(&self, path: &Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  55 |     pub fn start(&self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn stop(&self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub fn is_running(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  74 |     pub fn trigger_reload(&self, paths: &[&Path]) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub fn url(&self, host: &str) -> String {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `config` and `serve_dir` are never read
[INFO] [stdout]   --> src/server/core/server.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | struct ServerState {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] 31 |     reload_requested: Arc<AtomicBool>,
[INFO] [stdout] 32 |     config: Arc<Config>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 33 |     serve_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ServerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CorsMiddleware` is never constructed
[INFO] [stdout]  --> src/server/middleware/cors.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct CorsMiddleware;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `allow_all` and `new` are never used
[INFO] [stdout]   --> src/server/middleware/cors.rs:9:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl CorsMiddleware {
[INFO] [stdout]    | ------------------- associated functions in this implementation
[INFO] [stdout]  8 |     /// Create a CORS middleware that allows any origin
[INFO] [stdout]  9 |     pub fn allow_all() -> CorsLayer {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn new(origins: Vec<String>) -> CorsLayer {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `exclude_types` is never read
[INFO] [stdout]   --> src/server/middleware/compression.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct CompressionConfig {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub exclude_types: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CompressionConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `best`, `fastest`, `balanced`, `with_level`, `with_min_size`, and `exclude_content_type` are never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:60:12
[INFO] [stdout]     |
[INFO] [stdout]  58 | impl CompressionConfig {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  59 |     /// Create configuration for maximum compression
[INFO] [stdout]  60 |     pub fn best() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  68 |     pub fn fastest() -> Self {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn balanced() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub fn with_level(mut self, level: u8) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn with_min_size(mut self, min_size: u16) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn exclude_content_type(mut self, content_type: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:146:8
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn create_default_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_static_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:152:8
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub fn create_static_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_dynamic_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:158:8
[INFO] [stdout]     |
[INFO] [stdout] 158 | pub fn create_dynamic_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `should_compress_content_type` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:164:8
[INFO] [stdout]     |
[INFO] [stdout] 164 | pub fn should_compress_content_type(content_type: &str, exclude_types: &[String]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompressionStats` is never constructed
[INFO] [stdout]    --> src/server/middleware/compression.rs:192:12
[INFO] [stdout]     |
[INFO] [stdout] 192 | pub struct CompressionStats {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `record_compression`, and `get_savings_percentage` are never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:200:12
[INFO] [stdout]     |
[INFO] [stdout] 199 | impl CompressionStats {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 200 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub fn record_compression(&mut self, original_size: u64, compressed_size: u64) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 221 |     pub fn get_savings_percentage(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CacheConfig` is never constructed
[INFO] [stdout]   --> src/server/middleware/cache.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct CacheConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CacheControl` is never constructed
[INFO] [stdout]   --> src/server/middleware/cache.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct CacheControl {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]   --> src/server/middleware/cache.rs:77:12
[INFO] [stdout]    |
[INFO] [stdout] 75 | impl CacheControl {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] 76 |     /// Build the Cache-Control header value
[INFO] [stdout] 77 |     pub fn to_header_value(&self, max_age: u32) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ETagCache` is never constructed
[INFO] [stdout]    --> src/server/middleware/cache.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct ETagCache {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `get`, `set`, and `clear` are never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | impl ETagCache {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 119 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub async fn get(&self, key: &str) -> Option<String> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub async fn set(&self, key: String, etag: String) {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub async fn clear(&self) {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_etag` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:142:8
[INFO] [stdout]     |
[INFO] [stdout] 142 | pub fn generate_etag(content: &[u8]) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_etag_match` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | pub fn check_etag_match(request_headers: &HeaderMap, etag: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_if_modified_since` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | pub fn check_if_modified_since(request_headers: &HeaderMap, last_modified: SystemTime) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_middleware` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:178:14
[INFO] [stdout]     |
[INFO] [stdout] 178 | pub async fn cache_middleware(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_static_asset` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:283:4
[INFO] [stdout]     |
[INFO] [stdout] 283 | fn is_static_asset(path: &str) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_cache_layers` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:302:8
[INFO] [stdout]     |
[INFO] [stdout] 302 | pub fn create_cache_layers(config: Arc<CacheConfig>) -> impl Layer<
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SecurityConfig` is never constructed
[INFO] [stdout]   --> src/server/middleware/security.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SecurityConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `strict` and `development` are never used
[INFO] [stdout]    --> src/server/middleware/security.rs:152:12
[INFO] [stdout]     |
[INFO] [stdout] 100 | impl ContentSecurityPolicy {
[INFO] [stdout]     | -------------------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 152 |     pub fn strict() -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn development() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `XFrameOptions` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:194:10
[INFO] [stdout]     |
[INFO] [stdout] 194 | pub enum XFrameOptions {
[INFO] [stdout]     |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:201:12
[INFO] [stdout]     |
[INFO] [stdout] 200 | impl XFrameOptions {
[INFO] [stdout]     | ------------------ method in this implementation
[INFO] [stdout] 201 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `ReferrerPolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:215:10
[INFO] [stdout]     |
[INFO] [stdout] 215 | pub enum ReferrerPolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:227:12
[INFO] [stdout]     |
[INFO] [stdout] 226 | impl ReferrerPolicy {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] 227 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HstsConfig` is never constructed
[INFO] [stdout]    --> src/server/middleware/security.rs:243:12
[INFO] [stdout]     |
[INFO] [stdout] 243 | pub struct HstsConfig {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:260:12
[INFO] [stdout]     |
[INFO] [stdout] 259 | impl HstsConfig {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] 260 |     pub fn to_header_value(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginOpenerPolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:274:10
[INFO] [stdout]     |
[INFO] [stdout] 274 | pub enum CrossOriginOpenerPolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:281:12
[INFO] [stdout]     |
[INFO] [stdout] 280 | impl CrossOriginOpenerPolicy {
[INFO] [stdout]     | ---------------------------- method in this implementation
[INFO] [stdout] 281 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginEmbedderPolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:292:10
[INFO] [stdout]     |
[INFO] [stdout] 292 | pub enum CrossOriginEmbedderPolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:299:12
[INFO] [stdout]     |
[INFO] [stdout] 298 | impl CrossOriginEmbedderPolicy {
[INFO] [stdout]     | ------------------------------ method in this implementation
[INFO] [stdout] 299 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginResourcePolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:310:10
[INFO] [stdout]     |
[INFO] [stdout] 310 | pub enum CrossOriginResourcePolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:317:12
[INFO] [stdout]     |
[INFO] [stdout] 316 | impl CrossOriginResourcePolicy {
[INFO] [stdout]     | ------------------------------ method in this implementation
[INFO] [stdout] 317 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `security_middleware` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:327:14
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub async fn security_middleware(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_production_security_layers` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:423:8
[INFO] [stdout]     |
[INFO] [stdout] 423 | pub fn create_production_security_layers() -> impl Layer<
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PermalinkStyle` is never used
[INFO] [stdout]    --> src/config/types.rs:551:10
[INFO] [stdout]     |
[INFO] [stdout] 551 | pub enum PermalinkStyle {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_pattern` is never used
[INFO] [stdout]    --> src/config/types.rs:572:12
[INFO] [stdout]     |
[INFO] [stdout] 571 | impl PermalinkStyle {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] 572 |     pub fn to_pattern(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_excluded` is never used
[INFO] [stdout]    --> src/config/types.rs:637:12
[INFO] [stdout]     |
[INFO] [stdout] 583 | impl Config {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 637 |     pub fn is_excluded(&self, path: &Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_exclude` is never used
[INFO] [stdout]   --> src/config/defaults/values.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub fn default_exclude() -> Vec<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults` is never used
[INFO] [stdout]  --> src/config/defaults/front_matter.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn apply_defaults(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_default_values` is never used
[INFO] [stdout]   --> src/config/defaults/front_matter.rs:52:4
[INFO] [stdout]    |
[INFO] [stdout] 52 | fn apply_default_values(front_matter: &mut FrontMatter, values: &Value) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_permalink` is never used
[INFO] [stdout]   --> src/config/permalink.rs:48:8
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub fn process_permalink(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_date_placeholders` is never used
[INFO] [stdout]    --> src/config/permalink.rs:111:4
[INFO] [stdout]     |
[INFO] [stdout] 111 | fn add_date_placeholders(placeholders: &mut HashMap<String, String>, date: DateTime<Utc>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `slugify` is never used
[INFO] [stdout]    --> src/config/permalink.rs:129:4
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn slugify(input: &str) -> String {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_theme` and `available_themes` are never used
[INFO] [stdout]   --> src/markdown/renderer/syntax.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl SyntaxHighlighter {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `engine` and `toc_options` are never read
[INFO] [stdout]   --> src/markdown/renderer/markdown_renderer.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub struct MarkdownRenderer<'a> {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] 24 |     engine: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     toc_options: TocOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/markdown/renderer/markdown_renderer.rs:75:12
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl<'a> MarkdownRenderer<'a> {
[INFO] [stdout]     | ----------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn set_toc_options(&mut self, options: TocOptions) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  90 |     pub fn set_math_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn set_diagrams_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn set_typographic_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 168 |     pub fn generate_toc(&self, html: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 214 |     pub fn render_with_toc(&self, content: &str) -> (String, String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `markdownify` is never used
[INFO] [stdout]    --> src/markdown/renderer/markdown_renderer.rs:222:8
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub fn markdownify<'a>(content: &str, renderer: &MarkdownRenderer<'a>) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `min_level`, `max_level`, `include_title`, and `list_class` are never read
[INFO] [stdout]   --> src/markdown/toc/mod.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct TocOptions {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 10 |     /// Minimum level to include (h1 = 1, h2 = 2, etc.)
[INFO] [stdout] 11 |     pub min_level: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 12 |     /// Maximum level to include
[INFO] [stdout] 13 |     pub max_level: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 14 |     /// Whether to include the page title (h1)
[INFO] [stdout] 15 |     pub include_title: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 16 |     /// CSS class for the TOC list
[INFO] [stdout] 17 |     pub list_class: String,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TocOptions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_toc` is never used
[INFO] [stdout]  --> src/markdown/toc/generator.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn generate_toc(markdown: &str) -> BoxResult<String> {
[INFO] [stdout]   |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_headings` is never used
[INFO] [stdout]   --> src/markdown/toc/generator.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub fn extract_headings(markdown: &str) -> BoxResult<Vec<(usize, String)>> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TocHeading` is never constructed
[INFO] [stdout]   --> src/markdown/toc/parser.rs:16:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub struct TocHeading {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `to_html`, and `to_markdown` are never used
[INFO] [stdout]   --> src/markdown/toc/parser.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl TocHeading {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 24 |     pub fn new(level: usize, id: String, text: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn to_html(&self, _current_level: usize) -> String {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn to_markdown(&self, indent_level: usize) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TableOfContents` is never constructed
[INFO] [stdout]   --> src/markdown/toc/parser.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub struct TableOfContents {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:83:12
[INFO] [stdout]     |
[INFO] [stdout]  82 | impl TableOfContents {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout]  83 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn with_min_level(mut self, level: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  98 |     pub fn with_max_level(mut self, level: usize) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 104 |     fn build_hierarchy(&mut self, flat_headings: Vec<(usize, String, String)>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 146 |     pub fn to_html(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub fn to_markdown(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn to_simple_list(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     fn append_simple_list(&self, list: &mut String, heading: &TocHeading, indent: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_headings` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:199:8
[INFO] [stdout]     |
[INFO] [stdout] 199 | pub fn extract_headings(html: &str) -> BoxResult<Vec<(usize, String, String)>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_toc_from_html` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:222:8
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub fn build_toc_from_html(html: &str) -> BoxResult<TableOfContents> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_toc_with_levels` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:230:8
[INFO] [stdout]     |
[INFO] [stdout] 230 | pub fn build_toc_with_levels(html: &str, min_level: usize, max_level: usize) -> BoxResult<TableOfContents> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strip_html_tags` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:240:4
[INFO] [stdout]     |
[INFO] [stdout] 240 | fn strip_html_tags(text: &str) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_id_from_text` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:245:4
[INFO] [stdout]     |
[INFO] [stdout] 245 | fn generate_id_from_text(text: &str) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TocOptions` is never constructed
[INFO] [stdout]    --> src/markdown/toc/parser.rs:270:12
[INFO] [stdout]     |
[INFO] [stdout] 270 | pub struct TocOptions {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_toc_with_options` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:299:8
[INFO] [stdout]     |
[INFO] [stdout] 299 | pub fn generate_toc_with_options(_html: &str, _options: &TocOptions) -> BoxResult<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strip_markdown` is never used
[INFO] [stdout]  --> src/markdown/utils/text.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn strip_markdown(text: &str) -> String {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_summary` is never used
[INFO] [stdout]   --> src/markdown/utils/text.rs:31:8
[INFO] [stdout]    |
[INFO] [stdout] 31 | pub fn extract_summary(markdown: &str, length: usize) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DirectoryType` is never used
[INFO] [stdout]  --> src/directory/types/directory_type.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum DirectoryType {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sass_dir`, `theme_sass_dir`, `theme_assets_dir`, and `include_patterns` are never read
[INFO] [stdout]   --> src/directory/structure/directory_structure.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct DirectoryStructure {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub sass_dir: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub theme_sass_dir: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 25 |     pub theme_assets_dir: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub include_patterns: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DirectoryStructure` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_directory` is never used
[INFO] [stdout]   --> src/directory/structure/directory_structure.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl DirectoryStructure {
[INFO] [stdout]    | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn get_directory(&self, dir_type: DirectoryType) -> PathBuf {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy` is never used
[INFO] [stdout]  --> src/directory/utils/file_operations.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn copy(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_file` is never used
[INFO] [stdout]   --> src/directory/utils/file_operations.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn copy_file(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_static_files` is never used
[INFO] [stdout]   --> src/directory/utils/file_operations.rs:59:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub fn copy_static_files(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `patterns_to_regex` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn patterns_to_regex(patterns: &[String]) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `option_patterns_to_regex` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub fn option_patterns_to_regex(patterns: &Option<Vec<String>>) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_files` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub fn find_files(config: &Config, patterns: &[&str]) -> BoxResult<Vec<PathBuf>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_excluded` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:91:8
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clean_directory` is never used
[INFO] [stdout]   --> src/directory/utils/cleaning.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub fn clean_directory(path: &Path) -> io::Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metadata` is never read
[INFO] [stdout]   --> src/collections/document/model/mod.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Collection {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub metadata: CollectionMetadata,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Collection` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Draft` is never constructed
[INFO] [stdout]   --> src/collections/document/model/mod.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub enum DocumentState {
[INFO] [stdout]    |          ------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 53 |     Draft,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DocumentState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `state`, `mtime`, and `ctime` are never read
[INFO] [stdout]    --> src/collections/document/model/mod.rs:96:9
[INFO] [stdout]     |
[INFO] [stdout]  61 | pub struct Document {
[INFO] [stdout]     |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub state: DocumentState,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub mtime: Option<DateTime<Utc>>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub ctime: Option<DateTime<Utc>>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Document` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `should_write` and `title` are never used
[INFO] [stdout]    --> src/collections/document/model/mod.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl Document {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn should_write(&self, config: &Config) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 217 |     pub fn title(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_documents` is never used
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:4
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `BoxResult` is never used
[INFO] [stdout]   --> src/front_matter/types/front_matter.rs:10:6
[INFO] [stdout]    |
[INFO] [stdout] 10 | type BoxResult<T> = Result<T, Box<dyn Error>>;
[INFO] [stdout]    |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/front_matter/types/front_matter.rs:236:12
[INFO] [stdout]     |
[INFO] [stdout] 234 | impl FrontMatter {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 235 |     /// Create a new empty front matter
[INFO] [stdout] 236 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub fn parse(content: &str) -> BoxResult<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn extract_content(content: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 251 |     pub fn to_yaml(&self) -> BoxResult<String> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 257 |     pub fn add_to_content(&self, content: &str) -> BoxResult<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 477 |     pub fn merge(&mut self, other: &FrontMatter) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 613 |     pub fn get_modified_date(&self) -> Option<chrono::DateTime<chrono::Utc>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 635 |     pub fn get_category_string(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 640 |     pub fn get_tag_string(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 645 |     pub fn is_published(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 650 |     pub fn is_draft(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 655 |     pub fn get_state(&self) -> crate::collections::document::model::DocumentState {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_content` is never used
[INFO] [stdout]  --> src/front_matter/utils/content.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn extract_content(content: &str) -> String {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_front_matter_only` is never used
[INFO] [stdout]   --> src/front_matter/utils/content.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn extract_front_matter_only(content: &str) -> BoxResult<FrontMatter> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_front_matter` is never used
[INFO] [stdout]  --> src/front_matter/parser/mod.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn parse_front_matter(content: &str) -> Result<FrontMatter, Box<dyn Error>> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `BoxResult` is never used
[INFO] [stdout]  --> src/front_matter/parser/yaml_parser.rs:6:6
[INFO] [stdout]   |
[INFO] [stdout] 6 | type BoxResult<T> = Result<T, Box<dyn Error>>;
[INFO] [stdout]   |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse` is never used
[INFO] [stdout]  --> src/front_matter/parser/yaml_parser.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn parse(content: &str) -> BoxResult<FrontMatter> {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_yaml` is never used
[INFO] [stdout]   --> src/front_matter/parser/yaml_parser.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn parse_yaml(content: &str) -> Result<(serde_yaml::Value, String), Box<dyn Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_to_front_matter` is never used
[INFO] [stdout]  --> src/front_matter/defaults.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn apply_defaults_to_front_matter(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_to_paths` is never used
[INFO] [stdout]   --> src/front_matter/defaults.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn apply_defaults_to_paths(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_default_if_matches` is never used
[INFO] [stdout]   --> src/front_matter/defaults.rs:46:4
[INFO] [stdout]    |
[INFO] [stdout] 46 | fn apply_default_if_matches(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `scope_matches` is never used
[INFO] [stdout]   --> src/front_matter/defaults.rs:74:4
[INFO] [stdout]    |
[INFO] [stdout] 74 | fn scope_matches(
[INFO] [stdout]    |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:130:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | pub fn apply_defaults(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_from_list` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:154:4
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn apply_defaults_from_list(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_matching_default` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:184:4
[INFO] [stdout]     |
[INFO] [stdout] 184 | fn find_matching_default<'a>(path: &Path, defaults: &'a [FrontMatterDefault]) -> Option<&'a FrontMatterDefault> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_liquid` is never used
[INFO] [stdout]   --> src/liquid/mod.rs:79:8
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub fn parse_liquid(content: &str, parser: &liquid::Parser, globals: &Object) -> BoxResult<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `parse_parameters` is never used
[INFO] [stdout]   --> src/liquid/tags/include.rs:91:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl IncludeTag {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 91 |     fn parse_parameters(&self, params_str: &str) -> HashMap<String, String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn is_file<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_directory` is never used
[INFO] [stdout]   --> src/utils/fs.rs:24:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub fn remove_directory<P: AsRef<Path>>(path: P) -> BoxResult<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn read_file<P: AsRef<Path>>(path: P) -> BoxResult<String> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:40:8
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub fn write_file<P: AsRef<Path>>(path: P, contents: &str) -> BoxResult<()> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn copy_file<P: AsRef<Path>, Q: AsRef<Path>>(from: P, to: Q) -> BoxResult<u64> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_files` is never used
[INFO] [stdout]   --> src/utils/fs.rs:63:8
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub fn list_files<P: AsRef<Path>>(dir: P) -> BoxResult<Vec<PathBuf>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_path` is never used
[INFO] [stdout]  --> src/utils/path.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_extension` is never used
[INFO] [stdout]   --> src/utils/path.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn get_extension<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_stem` is never used
[INFO] [stdout]   --> src/utils/path.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub fn get_stem<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_extension` is never used
[INFO] [stdout]   --> src/utils/path.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub fn has_extension<P: AsRef<Path>>(path: P, ext: &str) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_relative` is never used
[INFO] [stdout]   --> src/utils/path.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn make_relative<P: AsRef<Path>, B: AsRef<Path>>(path: P, base: B) -> Option<PathBuf> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `uri_to_path` is never used
[INFO] [stdout]   --> src/utils/path.rs:73:8
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub fn uri_to_path<P: AsRef<Path>>(root: P, uri: &str) -> PathBuf {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `join` is never used
[INFO] [stdout]   --> src/utils/path.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub fn join<P: AsRef<Path>, Q: AsRef<Path>>(base: P, path: Q) -> PathBuf {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Template`, `FrontMatter`, `Markdown`, `File`, and `Server` are never constructed
[INFO] [stdout]   --> src/utils/error.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum RustyllError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 16 |     Template(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 17 |     /// Front matter parsing error
[INFO] [stdout] 18 |     FrontMatter(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 19 |     /// Markdown processing error
[INFO] [stdout] 20 |     Markdown(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     /// File handling error
[INFO] [stdout] 22 |     File(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 23 |     /// Server error
[INFO] [stdout] 24 |     Server(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RustyllError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LayoutRenderer` is never constructed
[INFO] [stdout]   --> src/layout/renderer.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct LayoutRenderer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `render`, and `find_layout` are never used
[INFO] [stdout]   --> src/layout/renderer.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl LayoutRenderer {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 20 |     /// Create a new layout renderer
[INFO] [stdout] 21 |     pub fn new(config: &Config) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn render(&self, content: &str, layout_name: &str, globals: &liquid::Object) -> BoxResult<String> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn find_layout(&self, name: &str) -> BoxResult<PathBuf> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `console_output` is never read
[INFO] [stdout]   --> src/report/mod.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ReportOptions {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 13 |     pub verbose: bool,
[INFO] [stdout] 14 |     pub console_output: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `build_time`, `num_pages`, `num_posts`, and `num_collections` are never read
[INFO] [stdout]   --> src/report/mod.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct SiteReport {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 19 |     /// Site title
[INFO] [stdout] 20 |     pub title: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 21 |     /// Build time
[INFO] [stdout] 22 |     pub build_time: Duration,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 23 |     /// Number of pages
[INFO] [stdout] 24 |     pub num_pages: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 25 |     /// Number of posts
[INFO] [stdout] 26 |     pub num_posts: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 27 |     /// Number of collections
[INFO] [stdout] 28 |     pub num_collections: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Ignored` is never constructed
[INFO] [stdout]   --> src/migrate/mod.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub enum ChangeType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 63 |     Ignored,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]   --> src/migrate/mod.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub trait EngineMigrator {
[INFO] [stdout]    |           -------------- method in this trait
[INFO] [stdout] 80 |     fn name(&self) -> &'static str;
[INFO] [stdout] 81 |     fn description(&self) -> &'static str;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `taxonomies` is never read
[INFO] [stdout]   --> src/migrate/engines/hugo/config.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct HugoConfig {
[INFO] [stdout]    |        ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     taxonomies: Option<serde_json::Value>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HugoConfig` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `write_readme_files` is never used
[INFO] [stdout]   --> src/migrate/engines/zola/readme.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 63 | impl super::ZolaMigrator {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 64 |     pub(super) fn write_readme_files(&self, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `migrate_static_assets` is never used
[INFO] [stdout]  --> src/migrate/engines/mkdocs/static_assets.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(super) fn migrate_static_assets(
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_assets` is never used
[INFO] [stdout]   --> src/migrate/engines/mkdocs/static_assets.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn create_default_assets(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convert_json_to_yaml` is never used
[INFO] [stdout]    --> src/migrate/engines/gitbook/config.rs:216:4
[INFO] [stdout]     |
[INFO] [stdout] 216 | fn convert_json_to_yaml(json_value: serde_json::Value) -> serde_yaml::Value {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_jekyll_config` is never used
[INFO] [stdout]    --> src/migrate/engines/slate/config.rs:138:4
[INFO] [stdout]     |
[INFO] [stdout] 138 | fn generate_jekyll_config(source_dir: &Path) -> Result<String, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_cobalt_structure` is never used
[INFO] [stdout]    --> src/migrate/engines/cobalt/mod.rs:119:4
[INFO] [stdout]     |
[INFO] [stdout] 119 | fn has_cobalt_structure(source_dir: &Path) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_cobalt_config` is never used
[INFO] [stdout]    --> src/migrate/engines/cobalt/mod.rs:129:4
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn is_cobalt_config(source_dir: &Path) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_includes` is never used
[INFO] [stdout]   --> src/migrate/engines/cobalt/includes.rs:95:4
[INFO] [stdout]    |
[INFO] [stdout] 95 | fn create_default_includes(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `migrate_data` is never used
[INFO] [stdout]  --> src/migrate/engines/cobalt/data.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(super) fn migrate_data(source_dir: &Path, dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]   |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_readme_files` is never used
[INFO] [stdout]  --> src/migrate/engines/cobalt/readme.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub(super) fn write_readme_files(dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `initialize`, `register_hooks`, `handle_hook`, and `cleanup` are never used
[INFO] [stdout]   --> src/plugins/mod.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub trait Plugin: Send + Sync {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 54 |     fn initialize(&mut self, config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>>;
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 57 |     fn register_hooks(&self) -> Vec<Hook>;
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 60 |     fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn cleanup(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PluginManager` is never constructed
[INFO] [stdout]   --> src/plugins/mod.rs:69:12
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub struct PluginManager {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/plugins/mod.rs:84:12
[INFO] [stdout]     |
[INFO] [stdout]  82 | impl PluginManager {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout]  83 |     /// Create a new plugin manager
[INFO] [stdout]  84 |     pub fn new(enabled: bool) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub fn with_plugin_dir(enabled: bool, plugin_dir: PathBuf) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn load_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn load_plugin_configs(&self) -> Result<HashMap<String, PluginConfig>, Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     fn load_plugin(&mut self, name: &str, config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     fn register_all_hooks(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     pub fn execute_hook(&self, hook_name: &str, context: &mut HookContext) -> HookResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub fn list_plugins(&self) -> Vec<PluginMetadata> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 272 |     pub fn unload_all(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 285 |     pub fn reload_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Hook` is never used
[INFO] [stdout]  --> src/plugins/hooks.rs:8:10
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub enum Hook {
[INFO] [stdout]   |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `name` and `from_name` are never used
[INFO] [stdout]   --> src/plugins/hooks.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Hook {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 38 |     /// Get the name of the hook
[INFO] [stdout] 39 |     pub fn name(&self) -> &str {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn from_name(name: &str) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HookContext` is never constructed
[INFO] [stdout]   --> src/plugins/hooks.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub struct HookContext {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_data`, `get_data`, `set_current_page`, and `clear_current_page` are never used
[INFO] [stdout]    --> src/plugins/hooks.rs:94:12
[INFO] [stdout]     |
[INFO] [stdout]  92 | impl HookContext {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  93 |     /// Create a new hook context
[INFO] [stdout]  94 |     pub fn new(source_dir: String, output_dir: String) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn add_data(&mut self, key: String, value: Value) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn get_data(&self, key: &str) -> Option<&Value> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn set_current_page(&mut self, page: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn clear_current_page(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `HookResult` is never used
[INFO] [stdout]    --> src/plugins/hooks.rs:127:10
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub enum HookResult {
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PluginLoader` is never constructed
[INFO] [stdout]  --> src/plugins/loader.rs:9:12
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub struct PluginLoader {
[INFO] [stdout]   |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `load_rust_plugin`, `load_wasm_plugin`, `load_js_plugin`, and `load_python_plugin` are never used
[INFO] [stdout]   --> src/plugins/loader.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PluginLoader {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 14 |     /// Create a new plugin loader
[INFO] [stdout] 15 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20 |     pub fn load_rust_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn load_wasm_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn load_js_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn load_python_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 06s
[INFO] running `Command { std: "docker" "inspect" "61ee5b2b21cab2405304a7220a4a06b73c5b38faf9f62b3e75b8452328f32471", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "61ee5b2b21cab2405304a7220a4a06b73c5b38faf9f62b3e75b8452328f32471", kill_on_drop: false }`
[INFO] [stdout] 61ee5b2b21cab2405304a7220a4a06b73c5b38faf9f62b3e75b8452328f32471
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] cabf5304e3b88b7a17e4ee5826afbd67477d1a53ad005e7d84785b86c9629f6a
[INFO] running `Command { std: "docker" "start" "-a" "cabf5304e3b88b7a17e4ee5826afbd67477d1a53ad005e7d84785b86c9629f6a", kill_on_drop: false }`
[INFO] [stderr]    Compiling rustyll v0.8.4 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]   --> src/front_matter/parser/yaml_parser.rs:60:9
[INFO] [stdout]    |
[INFO] [stdout] 60 |     use std::collections::HashMap;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `html`
[INFO] [stdout]    --> src/markdown/renderer/markdown_renderer.rs:260:14
[INFO] [stdout]     |
[INFO] [stdout] 260 |         let (html, toc) = renderer.render_with_toc(markdown);
[INFO] [stdout]     |              ^^^^ help: if this is intentional, prefix it with an underscore: `_html`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dir`
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:19
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |                   ^^^ help: if this is intentional, prefix it with an underscore: `_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collection`
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:31
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collection`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yaml_str`
[INFO] [stdout]   --> src/front_matter/defaults.rs:58:9
[INFO] [stdout]    |
[INFO] [stdout] 58 |     let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `yaml_str`
[INFO] [stdout]    --> src/front_matter/defaults.rs:164:13
[INFO] [stdout]     |
[INFO] [stdout] 164 |         let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `suffix`
[INFO] [stdout]    --> src/liquid/preprocess.rs:105:13
[INFO] [stdout]     |
[INFO] [stdout] 105 |         let suffix = &caps[2];   // The trim marker and closing %}
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_suffix`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `includes`
[INFO] [stdout]    --> src/liquid/mod.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 118 |     includes: HashMap<String, String>
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `base_dir`
[INFO] [stdout]   --> src/report/links.rs:85:5
[INFO] [stdout]    |
[INFO] [stdout] 85 |     base_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/report/mod.rs:173:53
[INFO] [stdout]     |
[INFO] [stdout] 173 | pub fn generate_console_report(report: &SiteReport, verbose: bool) -> String {
[INFO] [stdout]     |                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `post_dir`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:127:51
[INFO] [stdout]     |
[INFO] [stdout] 127 | ...self, file_path: &Path, post_dir: &Path, posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), Strin...
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_post_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:127:91
[INFO] [stdout]     |
[INFO] [stdout] 127 | ..., posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:246:68
[INFO] [stdout]     |
[INFO] [stdout] 246 | ...                   processed_post_dirs: &Vec<PathBuf>, verbose: bool, 
[INFO] [stdout]     |                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_page`
[INFO] [stdout]    --> src/migrate/engines/hugo/content.rs:278:29
[INFO] [stdout]     |
[INFO] [stdout] 278 |                         let is_page = true;
[INFO] [stdout]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_page`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content_dir`
[INFO] [stdout]   --> src/migrate/engines/zola/content.rs:68:44
[INFO] [stdout]    |
[INFO] [stdout] 68 | fn process_blog_directory(blog_dir: &Path, content_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), St...
[INFO] [stdout]    |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_posts_dir`
[INFO] [stdout]    --> src/migrate/engines/zola/content.rs:131:78
[INFO] [stdout]     |
[INFO] [stdout] 131 | ...pages_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_posts_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/migrate/engines/zola/data.rs:49:5
[INFO] [stdout]    |
[INFO] [stdout] 49 |     result: &mut MigrationResult,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `options`
[INFO] [stdout]   --> src/migrate/engines/gatsby/mod.rs:29:23
[INFO] [stdout]    |
[INFO] [stdout] 29 |     fn migrate(&self, options: &MigrationOptions) -> Result<MigrationResult, String> {
[INFO] [stdout]    |                       ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_options`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/config.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 52 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/config.rs:201:5
[INFO] [stdout]     |
[INFO] [stdout] 201 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `in_frontmatter` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:92:9
[INFO] [stdout]    |
[INFO] [stdout] 92 |     let mut in_frontmatter = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_in_frontmatter` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `has_frontmatter` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/docsy/content.rs:93:9
[INFO] [stdout]    |
[INFO] [stdout] 93 |     let mut has_frontmatter = false;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_has_frontmatter` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `in_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:102:9
[INFO] [stdout]     |
[INFO] [stdout] 102 |         in_frontmatter = true;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `in_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:132:9
[INFO] [stdout]     |
[INFO] [stdout] 132 |         in_frontmatter = false;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `has_frontmatter` is never read
[INFO] [stdout]    --> src/migrate/engines/docsy/content.rs:101:9
[INFO] [stdout]     |
[INFO] [stdout] 101 |         has_frontmatter = true;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/layouts.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 93 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/partials.rs:74:5
[INFO] [stdout]    |
[INFO] [stdout] 74 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/data.rs:80:5
[INFO] [stdout]    |
[INFO] [stdout] 80 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:111:5
[INFO] [stdout]     |
[INFO] [stdout] 111 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/data.rs:167:5
[INFO] [stdout]     |
[INFO] [stdout] 167 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/docsy/assets.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 63 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/assets.rs:162:5
[INFO] [stdout]     |
[INFO] [stdout] 162 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/docsy/assets.rs:250:5
[INFO] [stdout]     |
[INFO] [stdout] 250 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/config.rs:126:5
[INFO] [stdout]     |
[INFO] [stdout] 126 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `theme_content`
[INFO] [stdout]    --> src/migrate/engines/mdbook/config.rs:150:25
[INFO] [stdout]     |
[INFO] [stdout] 150 | fn extract_theme_config(theme_content: &str) -> Result<String, String> {
[INFO] [stdout]     |                         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_theme_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/content.rs:62:5
[INFO] [stdout]    |
[INFO] [stdout] 62 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/content.rs:106:5
[INFO] [stdout]     |
[INFO] [stdout] 106 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/theme.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:231:5
[INFO] [stdout]     |
[INFO] [stdout] 231 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:280:5
[INFO] [stdout]     |
[INFO] [stdout] 280 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/theme.rs:306:5
[INFO] [stdout]     |
[INFO] [stdout] 306 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/preprocessors.rs:70:5
[INFO] [stdout]    |
[INFO] [stdout] 70 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:103:5
[INFO] [stdout]     |
[INFO] [stdout] 103 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:150:5
[INFO] [stdout]     |
[INFO] [stdout] 150 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:180:5
[INFO] [stdout]     |
[INFO] [stdout] 180 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/preprocessors.rs:182:5
[INFO] [stdout]     |
[INFO] [stdout] 182 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:56:5
[INFO] [stdout]    |
[INFO] [stdout] 56 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:95:5
[INFO] [stdout]    |
[INFO] [stdout] 95 |     config: &toml::Value,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/renderers.rs:96:5
[INFO] [stdout]    |
[INFO] [stdout] 96 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/migrate/engines/mdbook/renderers.rs:135:5
[INFO] [stdout]     |
[INFO] [stdout] 135 |     config: &toml::Value,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/mdbook/renderers.rs:136:5
[INFO] [stdout]     |
[INFO] [stdout] 136 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]  --> src/migrate/engines/mdbook/search.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 |     source_dir: &Path,
[INFO] [stdout]   |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/static_files.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/mdbook/static_files.rs:80:5
[INFO] [stdout]    |
[INFO] [stdout] 80 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_path`
[INFO] [stdout]    --> src/migrate/engines/mkdocs/content.rs:147:48
[INFO] [stdout]     |
[INFO] [stdout] 147 | fn get_permalink_from_path(source_path: &Path, dest_path: &Path) -> Result<String, String> {
[INFO] [stdout]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `custom_dir`
[INFO] [stdout]   --> src/migrate/engines/mkdocs/layouts.rs:21:9
[INFO] [stdout]    |
[INFO] [stdout] 21 |     let custom_dir = source_dir.join("custom_theme");
[INFO] [stdout]    |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_custom_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]   --> src/migrate/engines/mkdocs/data.rs:60:5
[INFO] [stdout]    |
[INFO] [stdout] 60 |     result: &mut MigrationResult,
[INFO] [stdout]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `other_config`
[INFO] [stdout]   --> src/migrate/engines/gitbook/config.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |         let other_config = serde_yaml::Mapping::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_other_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `found_summary` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/gitbook/content.rs:18:13
[INFO] [stdout]    |
[INFO] [stdout] 18 |         let mut found_summary = false;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_found_summary` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_summary` is never read
[INFO] [stdout]   --> src/migrate/engines/gitbook/content.rs:21:13
[INFO] [stdout]    |
[INFO] [stdout] 21 |             found_summary = true;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `found_assets` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:29:13
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let mut found_assets = false;
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_found_assets` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_assets` is never read
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:39:17
[INFO] [stdout]    |
[INFO] [stdout] 39 |                 found_assets = true;
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/gitbook/static_assets.rs:59:59
[INFO] [stdout]    |
[INFO] [stdout] 59 | ...f, assets_dir: &Path, source_dir: &Path, dest_assets_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `processed` is never read
[INFO] [stdout]    --> src/migrate/engines/slate/content.rs:151:25
[INFO] [stdout]     |
[INFO] [stdout] 151 |     let mut processed = content.to_string();
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/layouts.rs:47:5
[INFO] [stdout]    |
[INFO] [stdout] 47 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ext`
[INFO] [stdout]   --> src/migrate/engines/slate/includes.rs:64:36
[INFO] [stdout]    |
[INFO] [stdout] 64 |     let new_filename = if let Some(ext) = dest_path.extension() {
[INFO] [stdout]    |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_ext`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/assets.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 36 |     dest_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/slate/assets.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 90 |     dest_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content_dir`
[INFO] [stdout]   --> src/migrate/engines/pelican/content.rs:52:5
[INFO] [stdout]    |
[INFO] [stdout] 52 |     content_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `post_name` is never read
[INFO] [stdout]    --> src/migrate/engines/pelican/content.rs:161:29
[INFO] [stdout]     |
[INFO] [stdout] 161 |         let mut post_name = String::new();
[INFO] [stdout]     |                             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/migrate/engines/pelican/plugins.rs:229:23
[INFO] [stdout]     |
[INFO] [stdout] 174 |         "related_posts" | "toc" | "table_of_contents" | "archives" | "redirect" | 
[INFO] [stdout]     |         --------------- matches all the relevant values
[INFO] [stdout] ...
[INFO] [stdout] 229 |         "neighbors" | "related_posts" => {
[INFO] [stdout]     |                       ^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/pelican/translations.rs:332:21
[INFO] [stdout]     |
[INFO] [stdout] 332 |                 let file_name = file_path.file_name().unwrap().to_string_lossy();
[INFO] [stdout]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:46:74
[INFO] [stdout]    |
[INFO] [stdout] 46 |     fn migrate_content_file(&self, file_path: &Path, content_dir: &Path, dest_dir: &Path, 
[INFO] [stdout]    |                                                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:48:27
[INFO] [stdout]    |
[INFO] [stdout] 48 |                           verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_content`
[INFO] [stdout]   --> src/migrate/engines/nanoc/content.rs:74:51
[INFO] [stdout]    |
[INFO] [stdout] 74 |     fn process_blog_post(&self, file_path: &Path, original_content: &str, metadata: &Vec<(String, String)>, 
[INFO] [stdout]    |                                                   ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `original_content`
[INFO] [stdout]    --> src/migrate/engines/nanoc/content.rs:141:63
[INFO] [stdout]     |
[INFO] [stdout] 141 |     fn process_page(&self, file_path: &Path, rel_path: &Path, original_content: &str, 
[INFO] [stdout]     |                                                               ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/nanoc/layouts.rs:117:53
[INFO] [stdout]     |
[INFO] [stdout] 117 |     fn process_html_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stdout]     |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]    --> src/migrate/engines/nanoc/layouts.rs:147:52
[INFO] [stdout]     |
[INFO] [stdout] 147 |     fn process_erb_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stdout]     |                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_dir`
[INFO] [stdout]    --> src/migrate/engines/nanoc/data.rs:175:56
[INFO] [stdout]     |
[INFO] [stdout] 175 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/content.rs:192:51
[INFO] [stdout]     |
[INFO] [stdout] 192 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/content.rs:253:37
[INFO] [stdout]     |
[INFO] [stdout] 253 |     fn create_sample_content(&self, dest_dir: &Path, pages_dir: &Path, posts_dir: &Path, result: &mut MigrationResult) -> Result<()...
[INFO] [stdout]     |                                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `includes_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/layouts.rs:230:56
[INFO] [stdout]     |
[INFO] [stdout] 230 |     fn create_basic_layouts(&self, layouts_dir: &Path, includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]    --> src/migrate/engines/assemble/layouts.rs:525:21
[INFO] [stdout]     |
[INFO] [stdout] 525 |         if let Some(context) = caps.get(2) {
[INFO] [stdout]     |                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_dir`
[INFO] [stdout]    --> src/migrate/engines/assemble/data.rs:252:53
[INFO] [stdout]     |
[INFO] [stdout] 252 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/content.rs:106:51
[INFO] [stdout]     |
[INFO] [stdout] 106 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `captures`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/content.rs:120:42
[INFO] [stdout]     |
[INFO] [stdout] 120 |         let dest_file_name = if let Some(captures) = date_regex.captures(&file_name) {
[INFO] [stdout]     |                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_captures`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/plugins.rs:160:5
[INFO] [stdout]     |
[INFO] [stdout] 160 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_file`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/assets.rs:307:5
[INFO] [stdout]     |
[INFO] [stdout] 307 |     source_file: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/bridgetown/assets.rs:310:5
[INFO] [stdout]     |
[INFO] [stdout] 310 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/cobalt/content.rs:114:51
[INFO] [stdout]     |
[INFO] [stdout] 114 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/cobalt/plugins.rs:104:5
[INFO] [stdout]     |
[INFO] [stdout] 104 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `result`
[INFO] [stdout]    --> src/migrate/engines/cobalt/plugins.rs:177:5
[INFO] [stdout]     |
[INFO] [stdout] 177 |     result: &mut MigrationResult,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `import_map_path`
[INFO] [stdout]   --> src/migrate/engines/fresh/config.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 |     let import_map_path = source_dir.join("import_map.json");
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_import_map_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dev_path`
[INFO] [stdout]   --> src/migrate/engines/fresh/config.rs:17:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     let dev_path = source_dir.join("dev.ts");
[INFO] [stdout]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dev_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file_name`
[INFO] [stdout]   --> src/migrate/engines/fresh/routes.rs:65:9
[INFO] [stdout]    |
[INFO] [stdout] 65 |     let file_name = route_path.file_name().unwrap().to_string_lossy();
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `has_props`
[INFO] [stdout]   --> src/migrate/engines/fresh/components.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 76 |     let has_props = regex::Regex::new(props_pattern).unwrap().is_match(&content);
[INFO] [stdout]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_has_props`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `content`
[INFO] [stdout]   --> src/migrate/engines/fresh/islands.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let content = fs::read_to_string(source_path)
[INFO] [stdout]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_content` is never read
[INFO] [stdout]   --> src/migrate/engines/harp/content.rs:29:33
[INFO] [stdout]    |
[INFO] [stdout] 29 |         let mut found_content = false;
[INFO] [stdout]    |                                 ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `found_content` is never read
[INFO] [stdout]   --> src/migrate/engines/harp/content.rs:46:17
[INFO] [stdout]    |
[INFO] [stdout] 46 |                 found_content = true;
[INFO] [stdout]    |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/harp/content.rs:480:54
[INFO] [stdout]     |
[INFO] [stdout] 480 | fn extract_metadata_from_data_json(file_path: &Path, source_dir: &Path) -> Result<std::collections::HashMap<String, String>, String> {
[INFO] [stdout]     |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/harp/partials.rs:82:54
[INFO] [stdout]    |
[INFO] [stdout] 82 | ...lf, file_path: &Path, source_dir: &Path, dest_includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/harp/static_assets.rs:145:51
[INFO] [stdout]     |
[INFO] [stdout] 145 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, asset_type: &str, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/config.rs:107:5
[INFO] [stdout]     |
[INFO] [stdout] 107 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dest_dir`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/collections.rs:168:5
[INFO] [stdout]     |
[INFO] [stdout] 168 |     dest_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/collections.rs:169:5
[INFO] [stdout]     |
[INFO] [stdout] 169 |     verbose: bool,
[INFO] [stdout]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `params`
[INFO] [stdout]    --> src/migrate/engines/jigsaw/helpers.rs:240:38
[INFO] [stdout]     |
[INFO] [stdout] 240 |             if let (Some(name), Some(params), Some(body)) = (cap.get(1), cap.get(2), cap.get(3)) {
[INFO] [stdout]     |                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_params`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `verbose`
[INFO] [stdout]   --> src/migrate/engines/jigsaw/assets.rs:55:5
[INFO] [stdout]    |
[INFO] [stdout] 55 |     verbose: bool,
[INFO] [stdout]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `relative_path`
[INFO] [stdout]   --> src/migrate/engines/metalsmith/metadata.rs:54:17
[INFO] [stdout]    |
[INFO] [stdout] 54 |             let relative_path = entry.path().strip_prefix(metadata_dir)
[INFO] [stdout]    |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_path`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/nikola/content.rs:88:5
[INFO] [stdout]    |
[INFO] [stdout] 88 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/nikola/content.rs:132:5
[INFO] [stdout]     |
[INFO] [stdout] 132 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]   --> src/migrate/engines/nikola/layouts.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 73 |     source_dir: &Path,
[INFO] [stdout]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `current_section` is assigned to, but never used
[INFO] [stdout]   --> src/migrate/engines/octopress/config.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 51 |     let mut current_section = None;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_current_section` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `current_section` is never read
[INFO] [stdout]   --> src/migrate/engines/octopress/config.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |             current_section = Some(trimmed.trim_start_matches('#').trim().to_lowercase());
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/octopress/content.rs:103:5
[INFO] [stdout]     |
[INFO] [stdout] 103 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_dir`
[INFO] [stdout]    --> src/migrate/engines/octopress/content.rs:148:5
[INFO] [stdout]     |
[INFO] [stdout] 148 |     source_dir: &Path,
[INFO] [stdout]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `html`
[INFO] [stdout]    --> src/plugins/mod.rs:343:37
[INFO] [stdout]     |
[INFO] [stdout] 343 |                         if let Some(html) = content.as_str() {
[INFO] [stdout]     |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_html`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `context`
[INFO] [stdout]    --> src/plugins/mod.rs:398:44
[INFO] [stdout]     |
[INFO] [stdout] 398 |         fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult {
[INFO] [stdout]     |                                            ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_markdown_file` is never used
[INFO] [stdout]   --> src/builder/site/mod.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub fn is_markdown_file(path: &Path, config: &Config) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `needs_rebuild` and `get_affected_files` are never used
[INFO] [stdout]    --> src/builder/site/builder.rs:95:8
[INFO] [stdout]     |
[INFO] [stdout]  38 | impl IncrementalCache {
[INFO] [stdout]     | --------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  95 |     fn needs_rebuild(&self, path: &Path) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn get_affected_files(&self, path: &Path) -> HashSet<PathBuf> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_excluded` is never used
[INFO] [stdout]    --> src/builder/site/builder.rs:691:8
[INFO] [stdout]     |
[INFO] [stdout] 691 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `relative_path` is never read
[INFO] [stdout]   --> src/builder/page/model.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct Page {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout]  9 |     pub path: PathBuf,
[INFO] [stdout] 10 |     pub relative_path: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Page` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `yaml_to_any` is never used
[INFO] [stdout]   --> src/builder/processor/yaml.rs:76:8
[INFO] [stdout]    |
[INFO] [stdout] 76 | pub fn yaml_to_any(yaml: YamlValue) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `livereload_port` is never read
[INFO] [stdout]   --> src/server/config/server_config.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub struct ServerConfig {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 16 |     pub livereload_port: Option<u16>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ServerConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/server/config/server_config.rs:89:12
[INFO] [stdout]     |
[INFO] [stdout]  70 | impl ServerConfig {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  89 |     pub fn with_detach(mut self, detach: bool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn with_baseurl(mut self, baseurl: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn with_livereload_port(mut self, port: u16) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn with_ssl(mut self, cert: PathBuf, key: PathBuf) -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub fn with_dir_listing(mut self, show: bool) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn with_livereload_ignore(mut self, patterns: Vec<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 126 |     pub fn with_livereload_delays(mut self, min: u64, max: u64) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `DIRECTORY_INDEX` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:14:7
[INFO] [stdout]    |
[INFO] [stdout] 14 | const DIRECTORY_INDEX: [&str; 9] = [
[INFO] [stdout]    |       ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_static_files_handler` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:27:8
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub fn create_static_files_handler(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_index_file` is never used
[INFO] [stdout]   --> src/server/handlers/static_files.rs:43:14
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub async fn find_index_file(directory: &FilePath) -> Option<Response> {
[INFO] [stdout]    |              ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `livereload_url` is never used
[INFO] [stdout]   --> src/server/livereload/watcher.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub fn livereload_url(host: &str, port: u16) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LiveReloadHandler` is never constructed
[INFO] [stdout]  --> src/server/livereload/handler.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct LiveReloadHandler {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/server/livereload/handler.rs:23:12
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl LiveReloadHandler {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout]  22 |     /// Create a new LiveReload handler
[INFO] [stdout]  23 |     pub fn new(port: u16, ignore_patterns: Vec<String>, min_delay: Duration) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  34 |     pub fn should_ignore(&self, path: &Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  55 |     pub fn start(&self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  62 |     pub fn stop(&self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  69 |     pub fn is_running(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  74 |     pub fn trigger_reload(&self, paths: &[&Path]) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub fn url(&self, host: &str) -> String {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `config` and `serve_dir` are never read
[INFO] [stdout]   --> src/server/core/server.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 30 | struct ServerState {
[INFO] [stdout]    |        ----------- fields in this struct
[INFO] [stdout] 31 |     reload_requested: Arc<AtomicBool>,
[INFO] [stdout] 32 |     config: Arc<Config>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 33 |     serve_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ServerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CorsMiddleware` is never constructed
[INFO] [stdout]  --> src/server/middleware/cors.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct CorsMiddleware;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `allow_all` and `new` are never used
[INFO] [stdout]   --> src/server/middleware/cors.rs:9:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl CorsMiddleware {
[INFO] [stdout]    | ------------------- associated functions in this implementation
[INFO] [stdout]  8 |     /// Create a CORS middleware that allows any origin
[INFO] [stdout]  9 |     pub fn allow_all() -> CorsLayer {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn new(origins: Vec<String>) -> CorsLayer {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `exclude_types` is never read
[INFO] [stdout]   --> src/server/middleware/compression.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct CompressionConfig {
[INFO] [stdout]    |            ----------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 23 |     pub exclude_types: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `CompressionConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `balanced`, `with_level`, `with_min_size`, and `exclude_content_type` are never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:76:12
[INFO] [stdout]     |
[INFO] [stdout]  58 | impl CompressionConfig {
[INFO] [stdout]     | ---------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn balanced() -> Self {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  84 |     pub fn with_level(mut self, level: u8) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub fn with_min_size(mut self, min_size: u16) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub fn exclude_content_type(mut self, content_type: impl Into<String>) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:146:8
[INFO] [stdout]     |
[INFO] [stdout] 146 | pub fn create_default_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_static_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:152:8
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub fn create_static_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_dynamic_compression_layer` is never used
[INFO] [stdout]    --> src/server/middleware/compression.rs:158:8
[INFO] [stdout]     |
[INFO] [stdout] 158 | pub fn create_dynamic_compression_layer() -> CompressionLayer {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CacheConfig` is never constructed
[INFO] [stdout]   --> src/server/middleware/cache.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub struct CacheConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ETagCache` is never constructed
[INFO] [stdout]    --> src/server/middleware/cache.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct ETagCache {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `get`, `set`, and `clear` are never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 118 | impl ETagCache {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 119 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub async fn get(&self, key: &str) -> Option<String> {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 130 |     pub async fn set(&self, key: String, etag: String) {
[INFO] [stdout]     |                  ^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub async fn clear(&self) {
[INFO] [stdout]     |                  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_etag_match` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:150:8
[INFO] [stdout]     |
[INFO] [stdout] 150 | pub fn check_etag_match(request_headers: &HeaderMap, etag: &str) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_if_modified_since` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:166:8
[INFO] [stdout]     |
[INFO] [stdout] 166 | pub fn check_if_modified_since(request_headers: &HeaderMap, last_modified: SystemTime) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `cache_middleware` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:178:14
[INFO] [stdout]     |
[INFO] [stdout] 178 | pub async fn cache_middleware(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_cache_layers` is never used
[INFO] [stdout]    --> src/server/middleware/cache.rs:302:8
[INFO] [stdout]     |
[INFO] [stdout] 302 | pub fn create_cache_layers(config: Arc<CacheConfig>) -> impl Layer<
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SecurityConfig` is never constructed
[INFO] [stdout]   --> src/server/middleware/security.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SecurityConfig {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `development` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:172:12
[INFO] [stdout]     |
[INFO] [stdout] 100 | impl ContentSecurityPolicy {
[INFO] [stdout]     | -------------------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 172 |     pub fn development() -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `AllowFrom` is never constructed
[INFO] [stdout]    --> src/server/middleware/security.rs:197:5
[INFO] [stdout]     |
[INFO] [stdout] 194 | pub enum XFrameOptions {
[INFO] [stdout]     |          ------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 197 |     AllowFrom(String),
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `XFrameOptions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `NoReferrerWhenDowngrade`, `Origin`, `OriginWhenCrossOrigin`, `SameOrigin`, `StrictOriginWhenCrossOrigin`, and `UnsafeUrl` are never constructed
[INFO] [stdout]    --> src/server/middleware/security.rs:217:5
[INFO] [stdout]     |
[INFO] [stdout] 215 | pub enum ReferrerPolicy {
[INFO] [stdout]     |          -------------- variants in this enum
[INFO] [stdout] 216 |     NoReferrer,
[INFO] [stdout] 217 |     NoReferrerWhenDowngrade,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 218 |     Origin,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 219 |     OriginWhenCrossOrigin,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 220 |     SameOrigin,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] 221 |     StrictOrigin,
[INFO] [stdout] 222 |     StrictOriginWhenCrossOrigin,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 223 |     UnsafeUrl,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `ReferrerPolicy` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginOpenerPolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:274:10
[INFO] [stdout]     |
[INFO] [stdout] 274 | pub enum CrossOriginOpenerPolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:281:12
[INFO] [stdout]     |
[INFO] [stdout] 280 | impl CrossOriginOpenerPolicy {
[INFO] [stdout]     | ---------------------------- method in this implementation
[INFO] [stdout] 281 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginEmbedderPolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:292:10
[INFO] [stdout]     |
[INFO] [stdout] 292 | pub enum CrossOriginEmbedderPolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:299:12
[INFO] [stdout]     |
[INFO] [stdout] 298 | impl CrossOriginEmbedderPolicy {
[INFO] [stdout]     | ------------------------------ method in this implementation
[INFO] [stdout] 299 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CrossOriginResourcePolicy` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:310:10
[INFO] [stdout]     |
[INFO] [stdout] 310 | pub enum CrossOriginResourcePolicy {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_header_value` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:317:12
[INFO] [stdout]     |
[INFO] [stdout] 316 | impl CrossOriginResourcePolicy {
[INFO] [stdout]     | ------------------------------ method in this implementation
[INFO] [stdout] 317 |     pub fn to_header_value(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `security_middleware` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:327:14
[INFO] [stdout]     |
[INFO] [stdout] 327 | pub async fn security_middleware(
[INFO] [stdout]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_production_security_layers` is never used
[INFO] [stdout]    --> src/server/middleware/security.rs:423:8
[INFO] [stdout]     |
[INFO] [stdout] 423 | pub fn create_production_security_layers() -> impl Layer<
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PermalinkStyle` is never used
[INFO] [stdout]    --> src/config/types.rs:551:10
[INFO] [stdout]     |
[INFO] [stdout] 551 | pub enum PermalinkStyle {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `to_pattern` is never used
[INFO] [stdout]    --> src/config/types.rs:572:12
[INFO] [stdout]     |
[INFO] [stdout] 571 | impl PermalinkStyle {
[INFO] [stdout]     | ------------------- method in this implementation
[INFO] [stdout] 572 |     pub fn to_pattern(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_excluded` is never used
[INFO] [stdout]    --> src/config/types.rs:637:12
[INFO] [stdout]     |
[INFO] [stdout] 583 | impl Config {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 637 |     pub fn is_excluded(&self, path: &Path) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `default_exclude` is never used
[INFO] [stdout]   --> src/config/defaults/values.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub fn default_exclude() -> Vec<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults` is never used
[INFO] [stdout]  --> src/config/defaults/front_matter.rs:9:8
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub fn apply_defaults(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_default_values` is never used
[INFO] [stdout]   --> src/config/defaults/front_matter.rs:52:4
[INFO] [stdout]    |
[INFO] [stdout] 52 | fn apply_default_values(front_matter: &mut FrontMatter, values: &Value) {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `process_permalink` is never used
[INFO] [stdout]   --> src/config/permalink.rs:48:8
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub fn process_permalink(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_date_placeholders` is never used
[INFO] [stdout]    --> src/config/permalink.rs:111:4
[INFO] [stdout]     |
[INFO] [stdout] 111 | fn add_date_placeholders(placeholders: &mut HashMap<String, String>, date: DateTime<Utc>) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `slugify` is never used
[INFO] [stdout]    --> src/config/permalink.rs:129:4
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn slugify(input: &str) -> String {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_theme` and `available_themes` are never used
[INFO] [stdout]   --> src/markdown/renderer/syntax.rs:32:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl SyntaxHighlighter {
[INFO] [stdout]    | ---------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 32 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 42 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `engine` and `toc_options` are never read
[INFO] [stdout]   --> src/markdown/renderer/markdown_renderer.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 23 | pub struct MarkdownRenderer<'a> {
[INFO] [stdout]    |            ---------------- fields in this struct
[INFO] [stdout] 24 |     engine: String,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27 |     toc_options: TocOptions,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `set_theme`, `available_themes`, `set_toc_options`, `set_math_enabled`, `set_diagrams_enabled`, and `set_typographic_enabled` are never used
[INFO] [stdout]    --> src/markdown/renderer/markdown_renderer.rs:75:12
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl<'a> MarkdownRenderer<'a> {
[INFO] [stdout]     | ----------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  85 |     pub fn set_toc_options(&mut self, options: TocOptions) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  90 |     pub fn set_math_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn set_diagrams_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn set_typographic_enabled(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `markdownify` is never used
[INFO] [stdout]    --> src/markdown/renderer/markdown_renderer.rs:222:8
[INFO] [stdout]     |
[INFO] [stdout] 222 | pub fn markdownify<'a>(content: &str, renderer: &MarkdownRenderer<'a>) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `min_level`, `max_level`, `include_title`, and `list_class` are never read
[INFO] [stdout]   --> src/markdown/toc/mod.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub struct TocOptions {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 10 |     /// Minimum level to include (h1 = 1, h2 = 2, etc.)
[INFO] [stdout] 11 |     pub min_level: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 12 |     /// Maximum level to include
[INFO] [stdout] 13 |     pub max_level: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 14 |     /// Whether to include the page title (h1)
[INFO] [stdout] 15 |     pub include_title: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout] 16 |     /// CSS class for the TOC list
[INFO] [stdout] 17 |     pub list_class: String,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TocOptions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_html` and `to_markdown` are never used
[INFO] [stdout]   --> src/markdown/toc/parser.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl TocHeading {
[INFO] [stdout]    | --------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn to_html(&self, _current_level: usize) -> String {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn to_markdown(&self, indent_level: usize) -> String {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_html`, `to_markdown`, `to_simple_list`, and `append_simple_list` are never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:146:12
[INFO] [stdout]     |
[INFO] [stdout]  82 | impl TableOfContents {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 146 |     pub fn to_html(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     pub fn to_markdown(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     pub fn to_simple_list(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 188 |     fn append_simple_list(&self, list: &mut String, heading: &TocHeading, indent: usize) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TocOptions` is never constructed
[INFO] [stdout]    --> src/markdown/toc/parser.rs:270:12
[INFO] [stdout]     |
[INFO] [stdout] 270 | pub struct TocOptions {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_toc_with_options` is never used
[INFO] [stdout]    --> src/markdown/toc/parser.rs:299:8
[INFO] [stdout]     |
[INFO] [stdout] 299 | pub fn generate_toc_with_options(_html: &str, _options: &TocOptions) -> BoxResult<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DirectoryType` is never used
[INFO] [stdout]  --> src/directory/types/directory_type.rs:3:10
[INFO] [stdout]   |
[INFO] [stdout] 3 | pub enum DirectoryType {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `sass_dir`, `theme_sass_dir`, `theme_assets_dir`, and `include_patterns` are never read
[INFO] [stdout]   --> src/directory/structure/directory_structure.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub struct DirectoryStructure {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub sass_dir: PathBuf,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub theme_sass_dir: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 25 |     pub theme_assets_dir: Option<PathBuf>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |     pub include_patterns: Vec<String>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DirectoryStructure` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_directory` is never used
[INFO] [stdout]   --> src/directory/structure/directory_structure.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 32 | impl DirectoryStructure {
[INFO] [stdout]    | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn get_directory(&self, dir_type: DirectoryType) -> PathBuf {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy` is never used
[INFO] [stdout]  --> src/directory/utils/file_operations.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn copy(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stdout]   |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_file` is never used
[INFO] [stdout]   --> src/directory/utils/file_operations.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 37 | pub fn copy_file(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_static_files` is never used
[INFO] [stdout]   --> src/directory/utils/file_operations.rs:59:8
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub fn copy_static_files(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `patterns_to_regex` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:28:8
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub fn patterns_to_regex(patterns: &[String]) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `option_patterns_to_regex` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:45:8
[INFO] [stdout]    |
[INFO] [stdout] 45 | pub fn option_patterns_to_regex(patterns: &Option<Vec<String>>) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_files` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | pub fn find_files(config: &Config, patterns: &[&str]) -> BoxResult<Vec<PathBuf>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_excluded` is never used
[INFO] [stdout]   --> src/directory/utils/path_helpers.rs:91:8
[INFO] [stdout]    |
[INFO] [stdout] 91 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `clean_directory` is never used
[INFO] [stdout]   --> src/directory/utils/cleaning.rs:57:8
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub fn clean_directory(path: &Path) -> io::Result<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metadata` is never read
[INFO] [stdout]   --> src/collections/document/model/mod.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct Collection {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub metadata: CollectionMetadata,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Collection` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Draft` is never constructed
[INFO] [stdout]   --> src/collections/document/model/mod.rs:53:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub enum DocumentState {
[INFO] [stdout]    |          ------------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 53 |     Draft,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DocumentState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `state`, `mtime`, and `ctime` are never read
[INFO] [stdout]    --> src/collections/document/model/mod.rs:96:9
[INFO] [stdout]     |
[INFO] [stdout]  61 | pub struct Document {
[INFO] [stdout]     |            -------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout]  96 |     pub state: DocumentState,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 114 |     pub mtime: Option<DateTime<Utc>>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub ctime: Option<DateTime<Utc>>,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Document` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `should_write` and `title` are never used
[INFO] [stdout]    --> src/collections/document/model/mod.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout] 120 | impl Document {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn should_write(&self, config: &Config) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 217 |     pub fn title(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_documents` is never used
[INFO] [stdout]    --> src/collections/document/loader/mod.rs:171:4
[INFO] [stdout]     |
[INFO] [stdout] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `BoxResult` is never used
[INFO] [stdout]   --> src/front_matter/types/front_matter.rs:10:6
[INFO] [stdout]    |
[INFO] [stdout] 10 | type BoxResult<T> = Result<T, Box<dyn Error>>;
[INFO] [stdout]    |      ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/front_matter/types/front_matter.rs:236:12
[INFO] [stdout]     |
[INFO] [stdout] 234 | impl FrontMatter {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout] 235 |     /// Create a new empty front matter
[INFO] [stdout] 236 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub fn parse(content: &str) -> BoxResult<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn extract_content(content: &str) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 251 |     pub fn to_yaml(&self) -> BoxResult<String> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 257 |     pub fn add_to_content(&self, content: &str) -> BoxResult<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 613 |     pub fn get_modified_date(&self) -> Option<chrono::DateTime<chrono::Utc>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 635 |     pub fn get_category_string(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 640 |     pub fn get_tag_string(&self) -> Option<String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 645 |     pub fn is_published(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 650 |     pub fn is_draft(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 655 |     pub fn get_state(&self) -> crate::collections::document::model::DocumentState {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_content` is never used
[INFO] [stdout]  --> src/front_matter/utils/content.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn extract_content(content: &str) -> String {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_front_matter_only` is never used
[INFO] [stdout]   --> src/front_matter/utils/content.rs:68:8
[INFO] [stdout]    |
[INFO] [stdout] 68 | pub fn extract_front_matter_only(content: &str) -> BoxResult<FrontMatter> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_front_matter` is never used
[INFO] [stdout]  --> src/front_matter/parser/mod.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn parse_front_matter(content: &str) -> Result<FrontMatter, Box<dyn Error>> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_yaml` is never used
[INFO] [stdout]   --> src/front_matter/parser/yaml_parser.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 | pub fn parse_yaml(content: &str) -> Result<(serde_yaml::Value, String), Box<dyn Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_to_front_matter` is never used
[INFO] [stdout]  --> src/front_matter/defaults.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn apply_defaults_to_front_matter(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_to_paths` is never used
[INFO] [stdout]   --> src/front_matter/defaults.rs:34:8
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub fn apply_defaults_to_paths(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:130:8
[INFO] [stdout]     |
[INFO] [stdout] 130 | pub fn apply_defaults(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `apply_defaults_from_list` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:154:4
[INFO] [stdout]     |
[INFO] [stdout] 154 | fn apply_defaults_from_list(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_matching_default` is never used
[INFO] [stdout]    --> src/front_matter/defaults.rs:184:4
[INFO] [stdout]     |
[INFO] [stdout] 184 | fn find_matching_default<'a>(path: &Path, defaults: &'a [FrontMatterDefault]) -> Option<&'a FrontMatterDefault> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_liquid` is never used
[INFO] [stdout]   --> src/liquid/mod.rs:79:8
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub fn parse_liquid(content: &str, parser: &liquid::Parser, globals: &Object) -> BoxResult<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `parse_parameters` is never used
[INFO] [stdout]   --> src/liquid/tags/include.rs:91:8
[INFO] [stdout]    |
[INFO] [stdout] 18 | impl IncludeTag {
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 91 |     fn parse_parameters(&self, params_str: &str) -> HashMap<String, String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:13:8
[INFO] [stdout]    |
[INFO] [stdout] 13 | pub fn is_file<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_directory` is never used
[INFO] [stdout]   --> src/utils/fs.rs:24:8
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub fn remove_directory<P: AsRef<Path>>(path: P) -> BoxResult<()> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `read_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:32:8
[INFO] [stdout]    |
[INFO] [stdout] 32 | pub fn read_file<P: AsRef<Path>>(path: P) -> BoxResult<String> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:40:8
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub fn write_file<P: AsRef<Path>>(path: P, contents: &str) -> BoxResult<()> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `copy_file` is never used
[INFO] [stdout]   --> src/utils/fs.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn copy_file<P: AsRef<Path>, Q: AsRef<Path>>(from: P, to: Q) -> BoxResult<u64> {
[INFO] [stdout]    |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `list_files` is never used
[INFO] [stdout]   --> src/utils/fs.rs:63:8
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub fn list_files<P: AsRef<Path>>(dir: P) -> BoxResult<Vec<PathBuf>> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `normalize_path` is never used
[INFO] [stdout]  --> src/utils/path.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_extension` is never used
[INFO] [stdout]   --> src/utils/path.rs:30:8
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub fn get_extension<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_stem` is never used
[INFO] [stdout]   --> src/utils/path.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub fn get_stem<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_extension` is never used
[INFO] [stdout]   --> src/utils/path.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 46 | pub fn has_extension<P: AsRef<Path>>(path: P, ext: &str) -> bool {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `make_relative` is never used
[INFO] [stdout]   --> src/utils/path.rs:52:8
[INFO] [stdout]    |
[INFO] [stdout] 52 | pub fn make_relative<P: AsRef<Path>, B: AsRef<Path>>(path: P, base: B) -> Option<PathBuf> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `uri_to_path` is never used
[INFO] [stdout]   --> src/utils/path.rs:73:8
[INFO] [stdout]    |
[INFO] [stdout] 73 | pub fn uri_to_path<P: AsRef<Path>>(root: P, uri: &str) -> PathBuf {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `join` is never used
[INFO] [stdout]   --> src/utils/path.rs:84:8
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub fn join<P: AsRef<Path>, Q: AsRef<Path>>(base: P, path: Q) -> PathBuf {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Template`, `FrontMatter`, `Markdown`, `File`, and `Server` are never constructed
[INFO] [stdout]   --> src/utils/error.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub enum RustyllError {
[INFO] [stdout]    |          ------------ variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 16 |     Template(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 17 |     /// Front matter parsing error
[INFO] [stdout] 18 |     FrontMatter(String),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 19 |     /// Markdown processing error
[INFO] [stdout] 20 |     Markdown(String),
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     /// File handling error
[INFO] [stdout] 22 |     File(String),
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 23 |     /// Server error
[INFO] [stdout] 24 |     Server(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RustyllError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `LayoutRenderer` is never constructed
[INFO] [stdout]   --> src/layout/renderer.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub struct LayoutRenderer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `render`, and `find_layout` are never used
[INFO] [stdout]   --> src/layout/renderer.rs:21:12
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl LayoutRenderer {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 20 |     /// Create a new layout renderer
[INFO] [stdout] 21 |     pub fn new(config: &Config) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn render(&self, content: &str, layout_name: &str, globals: &liquid::Object) -> BoxResult<String> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 66 |     fn find_layout(&self, name: &str) -> BoxResult<PathBuf> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `console_output` is never read
[INFO] [stdout]   --> src/report/mod.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ReportOptions {
[INFO] [stdout]    |            ------------- field in this struct
[INFO] [stdout] 13 |     pub verbose: bool,
[INFO] [stdout] 14 |     pub console_output: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `title`, `build_time`, `num_pages`, `num_posts`, and `num_collections` are never read
[INFO] [stdout]   --> src/report/mod.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct SiteReport {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 19 |     /// Site title
[INFO] [stdout] 20 |     pub title: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 21 |     /// Build time
[INFO] [stdout] 22 |     pub build_time: Duration,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 23 |     /// Number of pages
[INFO] [stdout] 24 |     pub num_pages: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 25 |     /// Number of posts
[INFO] [stdout] 26 |     pub num_posts: usize,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 27 |     /// Number of collections
[INFO] [stdout] 28 |     pub num_collections: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Ignored` is never constructed
[INFO] [stdout]   --> src/migrate/mod.rs:63:5
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub enum ChangeType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 63 |     Ignored,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `description` is never used
[INFO] [stdout]   --> src/migrate/mod.rs:81:8
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub trait EngineMigrator {
[INFO] [stdout]    |           -------------- method in this trait
[INFO] [stdout] 80 |     fn name(&self) -> &'static str;
[INFO] [stdout] 81 |     fn description(&self) -> &'static str;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `taxonomies` is never read
[INFO] [stdout]   --> src/migrate/engines/hugo/config.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct HugoConfig {
[INFO] [stdout]    |        ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     taxonomies: Option<serde_json::Value>,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `HugoConfig` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `write_readme_files` is never used
[INFO] [stdout]   --> src/migrate/engines/zola/readme.rs:64:19
[INFO] [stdout]    |
[INFO] [stdout] 63 | impl super::ZolaMigrator {
[INFO] [stdout]    | ------------------------ method in this implementation
[INFO] [stdout] 64 |     pub(super) fn write_readme_files(&self, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]    |                   ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `migrate_static_assets` is never used
[INFO] [stdout]  --> src/migrate/engines/mkdocs/static_assets.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(super) fn migrate_static_assets(
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_assets` is never used
[INFO] [stdout]   --> src/migrate/engines/mkdocs/static_assets.rs:98:4
[INFO] [stdout]    |
[INFO] [stdout] 98 | fn create_default_assets(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `convert_json_to_yaml` is never used
[INFO] [stdout]    --> src/migrate/engines/gitbook/config.rs:216:4
[INFO] [stdout]     |
[INFO] [stdout] 216 | fn convert_json_to_yaml(json_value: serde_json::Value) -> serde_yaml::Value {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_jekyll_config` is never used
[INFO] [stdout]    --> src/migrate/engines/slate/config.rs:138:4
[INFO] [stdout]     |
[INFO] [stdout] 138 | fn generate_jekyll_config(source_dir: &Path) -> Result<String, String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_cobalt_structure` is never used
[INFO] [stdout]    --> src/migrate/engines/cobalt/mod.rs:119:4
[INFO] [stdout]     |
[INFO] [stdout] 119 | fn has_cobalt_structure(source_dir: &Path) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_cobalt_config` is never used
[INFO] [stdout]    --> src/migrate/engines/cobalt/mod.rs:129:4
[INFO] [stdout]     |
[INFO] [stdout] 129 | fn is_cobalt_config(source_dir: &Path) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_default_includes` is never used
[INFO] [stdout]   --> src/migrate/engines/cobalt/includes.rs:95:4
[INFO] [stdout]    |
[INFO] [stdout] 95 | fn create_default_includes(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `migrate_data` is never used
[INFO] [stdout]  --> src/migrate/engines/cobalt/data.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub(super) fn migrate_data(source_dir: &Path, dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]   |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `write_readme_files` is never used
[INFO] [stdout]  --> src/migrate/engines/cobalt/readme.rs:4:15
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub(super) fn write_readme_files(dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stdout]   |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `handle_hook` and `cleanup` are never used
[INFO] [stdout]   --> src/plugins/mod.rs:60:8
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub trait Plugin: Send + Sync {
[INFO] [stdout]    |           ------ methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 60 |     fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult;
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 63 |     fn cleanup(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `plugin_dir`, `registry`, `loader`, and `hook_handlers` are never read
[INFO] [stdout]   --> src/plugins/mod.rs:73:5
[INFO] [stdout]    |
[INFO] [stdout] 69 | pub struct PluginManager {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 73 |     plugin_dir: PathBuf,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 74 |     /// Registry of loaded plugins
[INFO] [stdout] 75 |     registry: Arc<RwLock<PluginRegistry>>,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 76 |     /// Plugin loader
[INFO] [stdout] 77 |     loader: PluginLoader,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 78 |     /// Hook handlers mapped by hook name
[INFO] [stdout] 79 |     hook_handlers: Arc<RwLock<HashMap<String, Vec<Arc<dyn Plugin>>>>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/plugins/mod.rs:100:12
[INFO] [stdout]     |
[INFO] [stdout]  82 | impl PluginManager {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 100 |     pub fn load_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 136 |     fn load_plugin_configs(&self) -> Result<HashMap<String, PluginConfig>, Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 187 |     fn load_plugin(&mut self, name: &str, config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 212 |     fn register_all_hooks(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 233 |     pub fn execute_hook(&self, hook_name: &str, context: &mut HookContext) -> HookResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 263 |     pub fn list_plugins(&self) -> Vec<PluginMetadata> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 272 |     pub fn unload_all(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 285 |     pub fn reload_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple variants are never constructed
[INFO] [stdout]   --> src/plugins/hooks.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum Hook {
[INFO] [stdout]    |          ---- variants in this enum
[INFO] [stdout]  9 |     /// Before site initialization
[INFO] [stdout] 10 |     PreInit,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 11 |     /// After site initialization
[INFO] [stdout] 12 |     PostInit,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 13 |     /// Before reading source files
[INFO] [stdout] 14 |     PreRead,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 15 |     /// After reading source files
[INFO] [stdout] 16 |     PostRead,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 17 |     /// Before generating pages
[INFO] [stdout] 18 |     PreGenerate,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 19 |     /// After generating pages
[INFO] [stdout] 20 |     PostGenerate,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 21 |     /// Before rendering content
[INFO] [stdout] 22 |     PreRender,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     PreClean,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 31 |     /// After cleaning site
[INFO] [stdout] 32 |     PostClean,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 33 |     /// Custom hook
[INFO] [stdout] 34 |     Custom(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Hook` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `name` and `from_name` are never used
[INFO] [stdout]   --> src/plugins/hooks.rs:39:12
[INFO] [stdout]    |
[INFO] [stdout] 37 | impl Hook {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 38 |     /// Get the name of the hook
[INFO] [stdout] 39 |     pub fn name(&self) -> &str {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 58 |     pub fn from_name(name: &str) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `HookContext` is never constructed
[INFO] [stdout]   --> src/plugins/hooks.rs:79:12
[INFO] [stdout]    |
[INFO] [stdout] 79 | pub struct HookContext {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `add_data`, `get_data`, `set_current_page`, and `clear_current_page` are never used
[INFO] [stdout]    --> src/plugins/hooks.rs:94:12
[INFO] [stdout]     |
[INFO] [stdout]  92 | impl HookContext {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  93 |     /// Create a new hook context
[INFO] [stdout]  94 |     pub fn new(source_dir: String, output_dir: String) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     pub fn add_data(&mut self, key: String, value: Value) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 110 |     pub fn get_data(&self, key: &str) -> Option<&Value> {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn set_current_page(&mut self, page: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 120 |     pub fn clear_current_page(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `HookResult` is never used
[INFO] [stdout]    --> src/plugins/hooks.rs:127:10
[INFO] [stdout]     |
[INFO] [stdout] 127 | pub enum HookResult {
[INFO] [stdout]     |          ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `load_rust_plugin`, `load_wasm_plugin`, `load_js_plugin`, and `load_python_plugin` are never used
[INFO] [stdout]   --> src/plugins/loader.rs:20:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl PluginLoader {
[INFO] [stdout]    | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 20 |     pub fn load_rust_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     pub fn load_wasm_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 49 |     pub fn load_js_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 62 |     pub fn load_python_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 22.21s
[INFO] running `Command { std: "docker" "inspect" "cabf5304e3b88b7a17e4ee5826afbd67477d1a53ad005e7d84785b86c9629f6a", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cabf5304e3b88b7a17e4ee5826afbd67477d1a53ad005e7d84785b86c9629f6a", kill_on_drop: false }`
[INFO] [stdout] cabf5304e3b88b7a17e4ee5826afbd67477d1a53ad005e7d84785b86c9629f6a
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+db823df02fd0c2cf67b43025ac3fef3f2d743245" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 8b5fa220c23a404fd8626673ba750ab7818accc68e07dc3a03eb0258690255d1
[INFO] running `Command { std: "docker" "start" "-a" "8b5fa220c23a404fd8626673ba750ab7818accc68e07dc3a03eb0258690255d1", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `std::collections::HashMap`
[INFO] [stderr]   --> src/front_matter/parser/yaml_parser.rs:60:9
[INFO] [stderr]    |
[INFO] [stderr] 60 |     use std::collections::HashMap;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `html`
[INFO] [stderr]    --> src/markdown/renderer/markdown_renderer.rs:260:14
[INFO] [stderr]     |
[INFO] [stderr] 260 |         let (html, toc) = renderer.render_with_toc(markdown);
[INFO] [stderr]     |              ^^^^ help: if this is intentional, prefix it with an underscore: `_html`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dir`
[INFO] [stderr]    --> src/collections/document/loader/mod.rs:171:19
[INFO] [stderr]     |
[INFO] [stderr] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stderr]     |                   ^^^ help: if this is intentional, prefix it with an underscore: `_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `collection`
[INFO] [stderr]    --> src/collections/document/loader/mod.rs:171:31
[INFO] [stderr]     |
[INFO] [stderr] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stderr]     |                               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collection`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `yaml_str`
[INFO] [stderr]   --> src/front_matter/defaults.rs:58:9
[INFO] [stderr]    |
[INFO] [stderr] 58 |     let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stderr]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `yaml_str`
[INFO] [stderr]    --> src/front_matter/defaults.rs:164:13
[INFO] [stderr]     |
[INFO] [stderr] 164 |         let yaml_str = serde_yaml::to_string(&default.values)?;
[INFO] [stderr]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_yaml_str`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `suffix`
[INFO] [stderr]    --> src/liquid/preprocess.rs:105:13
[INFO] [stderr]     |
[INFO] [stderr] 105 |         let suffix = &caps[2];   // The trim marker and closing %}
[INFO] [stderr]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_suffix`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `includes`
[INFO] [stderr]    --> src/liquid/mod.rs:118:5
[INFO] [stderr]     |
[INFO] [stderr] 118 |     includes: HashMap<String, String>
[INFO] [stderr]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `base_dir`
[INFO] [stderr]   --> src/report/links.rs:85:5
[INFO] [stderr]    |
[INFO] [stderr] 85 |     base_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_base_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/report/mod.rs:173:53
[INFO] [stderr]     |
[INFO] [stderr] 173 | pub fn generate_console_report(report: &SiteReport, verbose: bool) -> String {
[INFO] [stderr]     |                                                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `post_dir`
[INFO] [stderr]    --> src/migrate/engines/hugo/content.rs:127:51
[INFO] [stderr]     |
[INFO] [stderr] 127 | ...self, file_path: &Path, post_dir: &Path, posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), Strin...
[INFO] [stderr]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_post_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/hugo/content.rs:127:91
[INFO] [stderr]     |
[INFO] [stderr] 127 | ..., posts_dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/hugo/content.rs:246:68
[INFO] [stderr]     |
[INFO] [stderr] 246 | ...                   processed_post_dirs: &Vec<PathBuf>, verbose: bool, 
[INFO] [stderr]     |                                                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `is_page`
[INFO] [stderr]    --> src/migrate/engines/hugo/content.rs:278:29
[INFO] [stderr]     |
[INFO] [stderr] 278 |                         let is_page = true;
[INFO] [stderr]     |                             ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_page`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `content_dir`
[INFO] [stderr]   --> src/migrate/engines/zola/content.rs:68:44
[INFO] [stderr]    |
[INFO] [stderr] 68 | fn process_blog_directory(blog_dir: &Path, content_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), St...
[INFO] [stderr]    |                                            ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_posts_dir`
[INFO] [stderr]    --> src/migrate/engines/zola/content.rs:131:78
[INFO] [stderr]     |
[INFO] [stderr] 131 | ...pages_dir: &Path, dest_posts_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                      ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_posts_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]   --> src/migrate/engines/zola/data.rs:49:5
[INFO] [stderr]    |
[INFO] [stderr] 49 |     result: &mut MigrationResult,
[INFO] [stderr]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `options`
[INFO] [stderr]   --> src/migrate/engines/gatsby/mod.rs:29:23
[INFO] [stderr]    |
[INFO] [stderr] 29 |     fn migrate(&self, options: &MigrationOptions) -> Result<MigrationResult, String> {
[INFO] [stderr]    |                       ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_options`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/config.rs:52:5
[INFO] [stderr]    |
[INFO] [stderr] 52 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/config.rs:201:5
[INFO] [stderr]     |
[INFO] [stderr] 201 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/content.rs:69:5
[INFO] [stderr]    |
[INFO] [stderr] 69 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `in_frontmatter` is assigned to, but never used
[INFO] [stderr]   --> src/migrate/engines/docsy/content.rs:92:9
[INFO] [stderr]    |
[INFO] [stderr] 92 |     let mut in_frontmatter = false;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_in_frontmatter` instead
[INFO] [stderr] 
[INFO] [stderr] warning: variable `has_frontmatter` is assigned to, but never used
[INFO] [stderr]   --> src/migrate/engines/docsy/content.rs:93:9
[INFO] [stderr]    |
[INFO] [stderr] 93 |     let mut has_frontmatter = false;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_has_frontmatter` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `in_frontmatter` is never read
[INFO] [stderr]    --> src/migrate/engines/docsy/content.rs:102:9
[INFO] [stderr]     |
[INFO] [stderr] 102 |         in_frontmatter = true;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr]     = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `in_frontmatter` is never read
[INFO] [stderr]    --> src/migrate/engines/docsy/content.rs:132:9
[INFO] [stderr]     |
[INFO] [stderr] 132 |         in_frontmatter = false;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `has_frontmatter` is never read
[INFO] [stderr]    --> src/migrate/engines/docsy/content.rs:101:9
[INFO] [stderr]     |
[INFO] [stderr] 101 |         has_frontmatter = true;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/layouts.rs:93:5
[INFO] [stderr]    |
[INFO] [stderr] 93 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/partials.rs:74:5
[INFO] [stderr]    |
[INFO] [stderr] 74 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/data.rs:80:5
[INFO] [stderr]    |
[INFO] [stderr] 80 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/data.rs:111:5
[INFO] [stderr]     |
[INFO] [stderr] 111 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/data.rs:136:5
[INFO] [stderr]     |
[INFO] [stderr] 136 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/data.rs:167:5
[INFO] [stderr]     |
[INFO] [stderr] 167 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/docsy/assets.rs:63:5
[INFO] [stderr]    |
[INFO] [stderr] 63 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/assets.rs:162:5
[INFO] [stderr]     |
[INFO] [stderr] 162 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/docsy/assets.rs:250:5
[INFO] [stderr]     |
[INFO] [stderr] 250 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/config.rs:126:5
[INFO] [stderr]     |
[INFO] [stderr] 126 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `theme_content`
[INFO] [stderr]    --> src/migrate/engines/mdbook/config.rs:150:25
[INFO] [stderr]     |
[INFO] [stderr] 150 | fn extract_theme_config(theme_content: &str) -> Result<String, String> {
[INFO] [stderr]     |                         ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_theme_content`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/content.rs:62:5
[INFO] [stderr]    |
[INFO] [stderr] 62 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/content.rs:106:5
[INFO] [stderr]     |
[INFO] [stderr] 106 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/theme.rs:88:5
[INFO] [stderr]    |
[INFO] [stderr] 88 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/theme.rs:231:5
[INFO] [stderr]     |
[INFO] [stderr] 231 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/theme.rs:280:5
[INFO] [stderr]     |
[INFO] [stderr] 280 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/theme.rs:306:5
[INFO] [stderr]     |
[INFO] [stderr] 306 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/preprocessors.rs:70:5
[INFO] [stderr]    |
[INFO] [stderr] 70 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/preprocessors.rs:103:5
[INFO] [stderr]     |
[INFO] [stderr] 103 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/migrate/engines/mdbook/preprocessors.rs:148:5
[INFO] [stderr]     |
[INFO] [stderr] 148 |     config: &toml::Value,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/preprocessors.rs:150:5
[INFO] [stderr]     |
[INFO] [stderr] 150 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/migrate/engines/mdbook/preprocessors.rs:180:5
[INFO] [stderr]     |
[INFO] [stderr] 180 |     config: &toml::Value,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/preprocessors.rs:182:5
[INFO] [stderr]     |
[INFO] [stderr] 182 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/renderers.rs:56:5
[INFO] [stderr]    |
[INFO] [stderr] 56 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]   --> src/migrate/engines/mdbook/renderers.rs:95:5
[INFO] [stderr]    |
[INFO] [stderr] 95 |     config: &toml::Value,
[INFO] [stderr]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/renderers.rs:96:5
[INFO] [stderr]    |
[INFO] [stderr] 96 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `config`
[INFO] [stderr]    --> src/migrate/engines/mdbook/renderers.rs:135:5
[INFO] [stderr]     |
[INFO] [stderr] 135 |     config: &toml::Value,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/mdbook/renderers.rs:136:5
[INFO] [stderr]     |
[INFO] [stderr] 136 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]  --> src/migrate/engines/mdbook/search.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 |     source_dir: &Path,
[INFO] [stderr]   |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/static_files.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/mdbook/static_files.rs:80:5
[INFO] [stderr]    |
[INFO] [stderr] 80 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_path`
[INFO] [stderr]    --> src/migrate/engines/mkdocs/content.rs:147:48
[INFO] [stderr]     |
[INFO] [stderr] 147 | fn get_permalink_from_path(source_path: &Path, dest_path: &Path) -> Result<String, String> {
[INFO] [stderr]     |                                                ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `custom_dir`
[INFO] [stderr]   --> src/migrate/engines/mkdocs/layouts.rs:21:9
[INFO] [stderr]    |
[INFO] [stderr] 21 |     let custom_dir = source_dir.join("custom_theme");
[INFO] [stderr]    |         ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_custom_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]   --> src/migrate/engines/mkdocs/data.rs:60:5
[INFO] [stderr]    |
[INFO] [stderr] 60 |     result: &mut MigrationResult,
[INFO] [stderr]    |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `other_config`
[INFO] [stderr]   --> src/migrate/engines/gitbook/config.rs:23:13
[INFO] [stderr]    |
[INFO] [stderr] 23 |         let other_config = serde_yaml::Mapping::new();
[INFO] [stderr]    |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_other_config`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `found_summary` is assigned to, but never used
[INFO] [stderr]   --> src/migrate/engines/gitbook/content.rs:18:13
[INFO] [stderr]    |
[INFO] [stderr] 18 |         let mut found_summary = false;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_found_summary` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `found_summary` is never read
[INFO] [stderr]   --> src/migrate/engines/gitbook/content.rs:21:13
[INFO] [stderr]    |
[INFO] [stderr] 21 |             found_summary = true;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: variable `found_assets` is assigned to, but never used
[INFO] [stderr]   --> src/migrate/engines/gitbook/static_assets.rs:29:13
[INFO] [stderr]    |
[INFO] [stderr] 29 |         let mut found_assets = false;
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_found_assets` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `found_assets` is never read
[INFO] [stderr]   --> src/migrate/engines/gitbook/static_assets.rs:39:17
[INFO] [stderr]    |
[INFO] [stderr] 39 |                 found_assets = true;
[INFO] [stderr]    |                 ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]   --> src/migrate/engines/gitbook/static_assets.rs:59:59
[INFO] [stderr]    |
[INFO] [stderr] 59 | ...f, assets_dir: &Path, source_dir: &Path, dest_assets_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `processed` is never read
[INFO] [stderr]    --> src/migrate/engines/slate/content.rs:151:25
[INFO] [stderr]     |
[INFO] [stderr] 151 |     let mut processed = content.to_string();
[INFO] [stderr]     |                         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]   --> src/migrate/engines/slate/layouts.rs:47:5
[INFO] [stderr]    |
[INFO] [stderr] 47 |     source_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ext`
[INFO] [stderr]   --> src/migrate/engines/slate/includes.rs:64:36
[INFO] [stderr]    |
[INFO] [stderr] 64 |     let new_filename = if let Some(ext) = dest_path.extension() {
[INFO] [stderr]    |                                    ^^^ help: if this is intentional, prefix it with an underscore: `_ext`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_dir`
[INFO] [stderr]   --> src/migrate/engines/slate/assets.rs:36:5
[INFO] [stderr]    |
[INFO] [stderr] 36 |     dest_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_dir`
[INFO] [stderr]   --> src/migrate/engines/slate/assets.rs:90:5
[INFO] [stderr]    |
[INFO] [stderr] 90 |     dest_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `content_dir`
[INFO] [stderr]   --> src/migrate/engines/pelican/content.rs:52:5
[INFO] [stderr]    |
[INFO] [stderr] 52 |     content_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `post_name` is never read
[INFO] [stderr]    --> src/migrate/engines/pelican/content.rs:161:29
[INFO] [stderr]     |
[INFO] [stderr] 161 |         let mut post_name = String::new();
[INFO] [stderr]     |                             ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unreachable pattern
[INFO] [stderr]    --> src/migrate/engines/pelican/plugins.rs:229:23
[INFO] [stderr]     |
[INFO] [stderr] 174 |         "related_posts" | "toc" | "table_of_contents" | "archives" | "redirect" | 
[INFO] [stderr]     |         --------------- matches all the relevant values
[INFO] [stderr] ...
[INFO] [stderr] 229 |         "neighbors" | "related_posts" => {
[INFO] [stderr]     |                       ^^^^^^^^^^^^^^^ no value can reach this
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_name`
[INFO] [stderr]    --> src/migrate/engines/pelican/translations.rs:332:21
[INFO] [stderr]     |
[INFO] [stderr] 332 |                 let file_name = file_path.file_name().unwrap().to_string_lossy();
[INFO] [stderr]     |                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_dir`
[INFO] [stderr]   --> src/migrate/engines/nanoc/content.rs:46:74
[INFO] [stderr]    |
[INFO] [stderr] 46 |     fn migrate_content_file(&self, file_path: &Path, content_dir: &Path, dest_dir: &Path, 
[INFO] [stderr]    |                                                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/nanoc/content.rs:48:27
[INFO] [stderr]    |
[INFO] [stderr] 48 |                           verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]    |                           ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `original_content`
[INFO] [stderr]   --> src/migrate/engines/nanoc/content.rs:74:51
[INFO] [stderr]    |
[INFO] [stderr] 74 |     fn process_blog_post(&self, file_path: &Path, original_content: &str, metadata: &Vec<(String, String)>, 
[INFO] [stderr]    |                                                   ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `original_content`
[INFO] [stderr]    --> src/migrate/engines/nanoc/content.rs:141:63
[INFO] [stderr]     |
[INFO] [stderr] 141 |     fn process_page(&self, file_path: &Path, rel_path: &Path, original_content: &str, 
[INFO] [stderr]     |                                                               ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_original_content`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_name`
[INFO] [stderr]    --> src/migrate/engines/nanoc/layouts.rs:117:53
[INFO] [stderr]     |
[INFO] [stderr] 117 |     fn process_html_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stderr]     |                                                     ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_name`
[INFO] [stderr]    --> src/migrate/engines/nanoc/layouts.rs:147:52
[INFO] [stderr]     |
[INFO] [stderr] 147 |     fn process_erb_layout(&self, file_path: &Path, file_name: &str, dest_layouts_dir: &Path, 
[INFO] [stderr]     |                                                    ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data_dir`
[INFO] [stderr]    --> src/migrate/engines/nanoc/data.rs:175:56
[INFO] [stderr]     |
[INFO] [stderr] 175 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/assemble/content.rs:192:51
[INFO] [stderr]     |
[INFO] [stderr] 192 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_dir`
[INFO] [stderr]    --> src/migrate/engines/assemble/content.rs:253:37
[INFO] [stderr]     |
[INFO] [stderr] 253 |     fn create_sample_content(&self, dest_dir: &Path, pages_dir: &Path, posts_dir: &Path, result: &mut MigrationResult) -> Result<()...
[INFO] [stderr]     |                                     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `includes_dir`
[INFO] [stderr]    --> src/migrate/engines/assemble/layouts.rs:230:56
[INFO] [stderr]     |
[INFO] [stderr] 230 |     fn create_basic_layouts(&self, layouts_dir: &Path, includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                                                        ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_includes_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `context`
[INFO] [stderr]    --> src/migrate/engines/assemble/layouts.rs:525:21
[INFO] [stderr]     |
[INFO] [stderr] 525 |         if let Some(context) = caps.get(2) {
[INFO] [stderr]     |                     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data_dir`
[INFO] [stderr]    --> src/migrate/engines/assemble/data.rs:252:53
[INFO] [stderr]     |
[INFO] [stderr] 252 | ...self, file_path: &Path, data_dir: &Path, dest_data_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                            ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/bridgetown/content.rs:106:51
[INFO] [stderr]     |
[INFO] [stderr] 106 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `captures`
[INFO] [stderr]    --> src/migrate/engines/bridgetown/content.rs:120:42
[INFO] [stderr]     |
[INFO] [stderr] 120 |         let dest_file_name = if let Some(captures) = date_regex.captures(&file_name) {
[INFO] [stderr]     |                                          ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_captures`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]    --> src/migrate/engines/bridgetown/plugins.rs:160:5
[INFO] [stderr]     |
[INFO] [stderr] 160 |     result: &mut MigrationResult,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_file`
[INFO] [stderr]    --> src/migrate/engines/bridgetown/assets.rs:307:5
[INFO] [stderr]     |
[INFO] [stderr] 307 |     source_file: &Path,
[INFO] [stderr]     |     ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_file`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]    --> src/migrate/engines/bridgetown/assets.rs:310:5
[INFO] [stderr]     |
[INFO] [stderr] 310 |     result: &mut MigrationResult,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/cobalt/content.rs:114:51
[INFO] [stderr]     |
[INFO] [stderr] 114 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]    --> src/migrate/engines/cobalt/plugins.rs:104:5
[INFO] [stderr]     |
[INFO] [stderr] 104 |     result: &mut MigrationResult,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `result`
[INFO] [stderr]    --> src/migrate/engines/cobalt/plugins.rs:177:5
[INFO] [stderr]     |
[INFO] [stderr] 177 |     result: &mut MigrationResult,
[INFO] [stderr]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_result`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `import_map_path`
[INFO] [stderr]   --> src/migrate/engines/fresh/config.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr] 16 |     let import_map_path = source_dir.join("import_map.json");
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_import_map_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dev_path`
[INFO] [stderr]   --> src/migrate/engines/fresh/config.rs:17:9
[INFO] [stderr]    |
[INFO] [stderr] 17 |     let dev_path = source_dir.join("dev.ts");
[INFO] [stderr]    |         ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dev_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `file_name`
[INFO] [stderr]   --> src/migrate/engines/fresh/routes.rs:65:9
[INFO] [stderr]    |
[INFO] [stderr] 65 |     let file_name = route_path.file_name().unwrap().to_string_lossy();
[INFO] [stderr]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file_name`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `has_props`
[INFO] [stderr]   --> src/migrate/engines/fresh/components.rs:76:9
[INFO] [stderr]    |
[INFO] [stderr] 76 |     let has_props = regex::Regex::new(props_pattern).unwrap().is_match(&content);
[INFO] [stderr]    |         ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_has_props`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `content`
[INFO] [stderr]   --> src/migrate/engines/fresh/islands.rs:87:9
[INFO] [stderr]    |
[INFO] [stderr] 87 |     let content = fs::read_to_string(source_path)
[INFO] [stderr]    |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_content`
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `found_content` is never read
[INFO] [stderr]   --> src/migrate/engines/harp/content.rs:29:33
[INFO] [stderr]    |
[INFO] [stderr] 29 |         let mut found_content = false;
[INFO] [stderr]    |                                 ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `found_content` is never read
[INFO] [stderr]   --> src/migrate/engines/harp/content.rs:46:17
[INFO] [stderr]    |
[INFO] [stderr] 46 |                 found_content = true;
[INFO] [stderr]    |                 ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/harp/content.rs:480:54
[INFO] [stderr]     |
[INFO] [stderr] 480 | fn extract_metadata_from_data_json(file_path: &Path, source_dir: &Path) -> Result<std::collections::HashMap<String, String>, String> {
[INFO] [stderr]     |                                                      ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]   --> src/migrate/engines/harp/partials.rs:82:54
[INFO] [stderr]    |
[INFO] [stderr] 82 | ...lf, file_path: &Path, source_dir: &Path, dest_includes_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]    |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/harp/static_assets.rs:145:51
[INFO] [stderr]     |
[INFO] [stderr] 145 | ...lf, file_path: &Path, source_dir: &Path, dest_dir: &Path, asset_type: &str, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]     |                          ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/jigsaw/config.rs:107:5
[INFO] [stderr]     |
[INFO] [stderr] 107 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `dest_dir`
[INFO] [stderr]    --> src/migrate/engines/jigsaw/collections.rs:168:5
[INFO] [stderr]     |
[INFO] [stderr] 168 |     dest_dir: &Path,
[INFO] [stderr]     |     ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_dest_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]    --> src/migrate/engines/jigsaw/collections.rs:169:5
[INFO] [stderr]     |
[INFO] [stderr] 169 |     verbose: bool,
[INFO] [stderr]     |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `params`
[INFO] [stderr]    --> src/migrate/engines/jigsaw/helpers.rs:240:38
[INFO] [stderr]     |
[INFO] [stderr] 240 |             if let (Some(name), Some(params), Some(body)) = (cap.get(1), cap.get(2), cap.get(3)) {
[INFO] [stderr]     |                                      ^^^^^^ help: if this is intentional, prefix it with an underscore: `_params`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `verbose`
[INFO] [stderr]   --> src/migrate/engines/jigsaw/assets.rs:55:5
[INFO] [stderr]    |
[INFO] [stderr] 55 |     verbose: bool,
[INFO] [stderr]    |     ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_verbose`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `relative_path`
[INFO] [stderr]   --> src/migrate/engines/metalsmith/metadata.rs:54:17
[INFO] [stderr]    |
[INFO] [stderr] 54 |             let relative_path = entry.path().strip_prefix(metadata_dir)
[INFO] [stderr]    |                 ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_relative_path`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]   --> src/migrate/engines/nikola/content.rs:88:5
[INFO] [stderr]    |
[INFO] [stderr] 88 |     source_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/nikola/content.rs:132:5
[INFO] [stderr]     |
[INFO] [stderr] 132 |     source_dir: &Path,
[INFO] [stderr]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]   --> src/migrate/engines/nikola/layouts.rs:73:5
[INFO] [stderr]    |
[INFO] [stderr] 73 |     source_dir: &Path,
[INFO] [stderr]    |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `current_section` is assigned to, but never used
[INFO] [stderr]   --> src/migrate/engines/octopress/config.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |     let mut current_section = None;
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: consider using `_current_section` instead
[INFO] [stderr] 
[INFO] [stderr] warning: value assigned to `current_section` is never read
[INFO] [stderr]   --> src/migrate/engines/octopress/config.rs:90:13
[INFO] [stderr]    |
[INFO] [stderr] 90 |             current_section = Some(trimmed.trim_start_matches('#').trim().to_lowercase());
[INFO] [stderr]    |             ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = help: maybe it is overwritten before being read?
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/octopress/content.rs:103:5
[INFO] [stderr]     |
[INFO] [stderr] 103 |     source_dir: &Path,
[INFO] [stderr]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `source_dir`
[INFO] [stderr]    --> src/migrate/engines/octopress/content.rs:148:5
[INFO] [stderr]     |
[INFO] [stderr] 148 |     source_dir: &Path,
[INFO] [stderr]     |     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_dir`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `html`
[INFO] [stderr]    --> src/plugins/mod.rs:343:37
[INFO] [stderr]     |
[INFO] [stderr] 343 |                         if let Some(html) = content.as_str() {
[INFO] [stderr]     |                                     ^^^^ help: if this is intentional, prefix it with an underscore: `_html`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `context`
[INFO] [stderr]    --> src/plugins/mod.rs:398:44
[INFO] [stderr]     |
[INFO] [stderr] 398 |         fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult {
[INFO] [stderr]     |                                            ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_context`
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_markdown_file` is never used
[INFO] [stderr]   --> src/builder/site/mod.rs:15:8
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub fn is_markdown_file(path: &Path, config: &Config) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `needs_rebuild` and `get_affected_files` are never used
[INFO] [stderr]    --> src/builder/site/builder.rs:95:8
[INFO] [stderr]     |
[INFO] [stderr]  38 | impl IncrementalCache {
[INFO] [stderr]     | --------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  95 |     fn needs_rebuild(&self, path: &Path) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 136 |     fn get_affected_files(&self, path: &Path) -> HashSet<PathBuf> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_excluded` is never used
[INFO] [stderr]    --> src/builder/site/builder.rs:691:8
[INFO] [stderr]     |
[INFO] [stderr] 691 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `relative_path` is never read
[INFO] [stderr]   --> src/builder/page/model.rs:10:9
[INFO] [stderr]    |
[INFO] [stderr]  8 | pub struct Page {
[INFO] [stderr]    |            ---- field in this struct
[INFO] [stderr]  9 |     pub path: PathBuf,
[INFO] [stderr] 10 |     pub relative_path: PathBuf,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Page` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: function `yaml_to_any` is never used
[INFO] [stderr]   --> src/builder/processor/yaml.rs:76:8
[INFO] [stderr]    |
[INFO] [stderr] 76 | pub fn yaml_to_any(yaml: YamlValue) -> Option<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `livereload_port` is never read
[INFO] [stderr]   --> src/server/config/server_config.rs:16:9
[INFO] [stderr]    |
[INFO] [stderr]  5 | pub struct ServerConfig {
[INFO] [stderr]    |            ------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 16 |     pub livereload_port: Option<u16>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ServerConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/server/config/server_config.rs:89:12
[INFO] [stderr]     |
[INFO] [stderr]  70 | impl ServerConfig {
[INFO] [stderr]     | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  89 |     pub fn with_detach(mut self, detach: bool) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  95 |     pub fn with_baseurl(mut self, baseurl: &str) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 101 |     pub fn with_livereload_port(mut self, port: u16) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 107 |     pub fn with_ssl(mut self, cert: PathBuf, key: PathBuf) -> Self {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 114 |     pub fn with_dir_listing(mut self, show: bool) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 120 |     pub fn with_livereload_ignore(mut self, patterns: Vec<String>) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 126 |     pub fn with_livereload_delays(mut self, min: u64, max: u64) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: constant `DIRECTORY_INDEX` is never used
[INFO] [stderr]   --> src/server/handlers/static_files.rs:14:7
[INFO] [stderr]    |
[INFO] [stderr] 14 | const DIRECTORY_INDEX: [&str; 9] = [
[INFO] [stderr]    |       ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_static_files_handler` is never used
[INFO] [stderr]   --> src/server/handlers/static_files.rs:27:8
[INFO] [stderr]    |
[INFO] [stderr] 27 | pub fn create_static_files_handler(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_index_file` is never used
[INFO] [stderr]   --> src/server/handlers/static_files.rs:43:14
[INFO] [stderr]    |
[INFO] [stderr] 43 | pub async fn find_index_file(directory: &FilePath) -> Option<Response> {
[INFO] [stderr]    |              ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `livereload_url` is never used
[INFO] [stderr]   --> src/server/livereload/watcher.rs:60:8
[INFO] [stderr]    |
[INFO] [stderr] 60 | pub fn livereload_url(host: &str, port: u16) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LiveReloadHandler` is never constructed
[INFO] [stderr]  --> src/server/livereload/handler.rs:8:12
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub struct LiveReloadHandler {
[INFO] [stderr]   |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/server/livereload/handler.rs:23:12
[INFO] [stderr]     |
[INFO] [stderr]  21 | impl LiveReloadHandler {
[INFO] [stderr]     | ---------------------- associated items in this implementation
[INFO] [stderr]  22 |     /// Create a new LiveReload handler
[INFO] [stderr]  23 |     pub fn new(port: u16, ignore_patterns: Vec<String>, min_delay: Duration) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr]  34 |     pub fn should_ignore(&self, path: &Path) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  55 |     pub fn start(&self) {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  62 |     pub fn stop(&self) {
[INFO] [stderr]     |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr]  69 |     pub fn is_running(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  74 |     pub fn trigger_reload(&self, paths: &[&Path]) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 109 |     pub fn url(&self, host: &str) -> String {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `config` and `serve_dir` are never read
[INFO] [stderr]   --> src/server/core/server.rs:32:5
[INFO] [stderr]    |
[INFO] [stderr] 30 | struct ServerState {
[INFO] [stderr]    |        ----------- fields in this struct
[INFO] [stderr] 31 |     reload_requested: Arc<AtomicBool>,
[INFO] [stderr] 32 |     config: Arc<Config>,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 33 |     serve_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `ServerState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CorsMiddleware` is never constructed
[INFO] [stderr]  --> src/server/middleware/cors.rs:5:12
[INFO] [stderr]   |
[INFO] [stderr] 5 | pub struct CorsMiddleware;
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated functions `allow_all` and `new` are never used
[INFO] [stderr]   --> src/server/middleware/cors.rs:9:12
[INFO] [stderr]    |
[INFO] [stderr]  7 | impl CorsMiddleware {
[INFO] [stderr]    | ------------------- associated functions in this implementation
[INFO] [stderr]  8 |     /// Create a CORS middleware that allows any origin
[INFO] [stderr]  9 |     pub fn allow_all() -> CorsLayer {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 24 |     pub fn new(origins: Vec<String>) -> CorsLayer {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `exclude_types` is never read
[INFO] [stderr]   --> src/server/middleware/compression.rs:23:9
[INFO] [stderr]    |
[INFO] [stderr]  9 | pub struct CompressionConfig {
[INFO] [stderr]    |            ----------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 23 |     pub exclude_types: Vec<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `CompressionConfig` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `balanced`, `with_level`, `with_min_size`, and `exclude_content_type` are never used
[INFO] [stderr]    --> src/server/middleware/compression.rs:76:12
[INFO] [stderr]     |
[INFO] [stderr]  58 | impl CompressionConfig {
[INFO] [stderr]     | ---------------------- associated items in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  76 |     pub fn balanced() -> Self {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  84 |     pub fn with_level(mut self, level: u8) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  96 |     pub fn with_min_size(mut self, min_size: u16) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 102 |     pub fn exclude_content_type(mut self, content_type: impl Into<String>) -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_default_compression_layer` is never used
[INFO] [stderr]    --> src/server/middleware/compression.rs:146:8
[INFO] [stderr]     |
[INFO] [stderr] 146 | pub fn create_default_compression_layer() -> CompressionLayer {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_static_compression_layer` is never used
[INFO] [stderr]    --> src/server/middleware/compression.rs:152:8
[INFO] [stderr]     |
[INFO] [stderr] 152 | pub fn create_static_compression_layer() -> CompressionLayer {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_dynamic_compression_layer` is never used
[INFO] [stderr]    --> src/server/middleware/compression.rs:158:8
[INFO] [stderr]     |
[INFO] [stderr] 158 | pub fn create_dynamic_compression_layer() -> CompressionLayer {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `CacheConfig` is never constructed
[INFO] [stderr]   --> src/server/middleware/cache.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 21 | pub struct CacheConfig {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `ETagCache` is never constructed
[INFO] [stderr]    --> src/server/middleware/cache.rs:114:12
[INFO] [stderr]     |
[INFO] [stderr] 114 | pub struct ETagCache {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `get`, `set`, and `clear` are never used
[INFO] [stderr]    --> src/server/middleware/cache.rs:119:12
[INFO] [stderr]     |
[INFO] [stderr] 118 | impl ETagCache {
[INFO] [stderr]     | -------------- associated items in this implementation
[INFO] [stderr] 119 |     pub fn new() -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 125 |     pub async fn get(&self, key: &str) -> Option<String> {
[INFO] [stderr]     |                  ^^^
[INFO] [stderr] ...
[INFO] [stderr] 130 |     pub async fn set(&self, key: String, etag: String) {
[INFO] [stderr]     |                  ^^^
[INFO] [stderr] ...
[INFO] [stderr] 135 |     pub async fn clear(&self) {
[INFO] [stderr]     |                  ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `check_etag_match` is never used
[INFO] [stderr]    --> src/server/middleware/cache.rs:150:8
[INFO] [stderr]     |
[INFO] [stderr] 150 | pub fn check_etag_match(request_headers: &HeaderMap, etag: &str) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `check_if_modified_since` is never used
[INFO] [stderr]    --> src/server/middleware/cache.rs:166:8
[INFO] [stderr]     |
[INFO] [stderr] 166 | pub fn check_if_modified_since(request_headers: &HeaderMap, last_modified: SystemTime) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `cache_middleware` is never used
[INFO] [stderr]    --> src/server/middleware/cache.rs:178:14
[INFO] [stderr]     |
[INFO] [stderr] 178 | pub async fn cache_middleware(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_cache_layers` is never used
[INFO] [stderr]    --> src/server/middleware/cache.rs:302:8
[INFO] [stderr]     |
[INFO] [stderr] 302 | pub fn create_cache_layers(config: Arc<CacheConfig>) -> impl Layer<
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `SecurityConfig` is never constructed
[INFO] [stderr]   --> src/server/middleware/security.rs:17:12
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct SecurityConfig {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated function `development` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:172:12
[INFO] [stderr]     |
[INFO] [stderr] 100 | impl ContentSecurityPolicy {
[INFO] [stderr]     | -------------------------- associated function in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 172 |     pub fn development() -> Self {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `AllowFrom` is never constructed
[INFO] [stderr]    --> src/server/middleware/security.rs:197:5
[INFO] [stderr]     |
[INFO] [stderr] 194 | pub enum XFrameOptions {
[INFO] [stderr]     |          ------------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 197 |     AllowFrom(String),
[INFO] [stderr]     |     ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `XFrameOptions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variants `NoReferrerWhenDowngrade`, `Origin`, `OriginWhenCrossOrigin`, `SameOrigin`, `StrictOriginWhenCrossOrigin`, and `UnsafeUrl` are never constructed
[INFO] [stderr]    --> src/server/middleware/security.rs:217:5
[INFO] [stderr]     |
[INFO] [stderr] 215 | pub enum ReferrerPolicy {
[INFO] [stderr]     |          -------------- variants in this enum
[INFO] [stderr] 216 |     NoReferrer,
[INFO] [stderr] 217 |     NoReferrerWhenDowngrade,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 218 |     Origin,
[INFO] [stderr]     |     ^^^^^^
[INFO] [stderr] 219 |     OriginWhenCrossOrigin,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 220 |     SameOrigin,
[INFO] [stderr]     |     ^^^^^^^^^^
[INFO] [stderr] 221 |     StrictOrigin,
[INFO] [stderr] 222 |     StrictOriginWhenCrossOrigin,
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 223 |     UnsafeUrl,
[INFO] [stderr]     |     ^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `ReferrerPolicy` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: enum `CrossOriginOpenerPolicy` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:274:10
[INFO] [stderr]     |
[INFO] [stderr] 274 | pub enum CrossOriginOpenerPolicy {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_header_value` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:281:12
[INFO] [stderr]     |
[INFO] [stderr] 280 | impl CrossOriginOpenerPolicy {
[INFO] [stderr]     | ---------------------------- method in this implementation
[INFO] [stderr] 281 |     pub fn to_header_value(&self) -> &str {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `CrossOriginEmbedderPolicy` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:292:10
[INFO] [stderr]     |
[INFO] [stderr] 292 | pub enum CrossOriginEmbedderPolicy {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_header_value` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:299:12
[INFO] [stderr]     |
[INFO] [stderr] 298 | impl CrossOriginEmbedderPolicy {
[INFO] [stderr]     | ------------------------------ method in this implementation
[INFO] [stderr] 299 |     pub fn to_header_value(&self) -> &str {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `CrossOriginResourcePolicy` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:310:10
[INFO] [stderr]     |
[INFO] [stderr] 310 | pub enum CrossOriginResourcePolicy {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_header_value` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:317:12
[INFO] [stderr]     |
[INFO] [stderr] 316 | impl CrossOriginResourcePolicy {
[INFO] [stderr]     | ------------------------------ method in this implementation
[INFO] [stderr] 317 |     pub fn to_header_value(&self) -> &str {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `security_middleware` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:327:14
[INFO] [stderr]     |
[INFO] [stderr] 327 | pub async fn security_middleware(
[INFO] [stderr]     |              ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_production_security_layers` is never used
[INFO] [stderr]    --> src/server/middleware/security.rs:423:8
[INFO] [stderr]     |
[INFO] [stderr] 423 | pub fn create_production_security_layers() -> impl Layer<
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `PermalinkStyle` is never used
[INFO] [stderr]    --> src/config/types.rs:551:10
[INFO] [stderr]     |
[INFO] [stderr] 551 | pub enum PermalinkStyle {
[INFO] [stderr]     |          ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `to_pattern` is never used
[INFO] [stderr]    --> src/config/types.rs:572:12
[INFO] [stderr]     |
[INFO] [stderr] 571 | impl PermalinkStyle {
[INFO] [stderr]     | ------------------- method in this implementation
[INFO] [stderr] 572 |     pub fn to_pattern(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `is_excluded` is never used
[INFO] [stderr]    --> src/config/types.rs:637:12
[INFO] [stderr]     |
[INFO] [stderr] 583 | impl Config {
[INFO] [stderr]     | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 637 |     pub fn is_excluded(&self, path: &Path) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `default_exclude` is never used
[INFO] [stderr]   --> src/config/defaults/values.rs:54:8
[INFO] [stderr]    |
[INFO] [stderr] 54 | pub fn default_exclude() -> Vec<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_defaults` is never used
[INFO] [stderr]  --> src/config/defaults/front_matter.rs:9:8
[INFO] [stderr]   |
[INFO] [stderr] 9 | pub fn apply_defaults(
[INFO] [stderr]   |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_default_values` is never used
[INFO] [stderr]   --> src/config/defaults/front_matter.rs:52:4
[INFO] [stderr]    |
[INFO] [stderr] 52 | fn apply_default_values(front_matter: &mut FrontMatter, values: &Value) {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `process_permalink` is never used
[INFO] [stderr]   --> src/config/permalink.rs:48:8
[INFO] [stderr]    |
[INFO] [stderr] 48 | pub fn process_permalink(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `add_date_placeholders` is never used
[INFO] [stderr]    --> src/config/permalink.rs:111:4
[INFO] [stderr]     |
[INFO] [stderr] 111 | fn add_date_placeholders(placeholders: &mut HashMap<String, String>, date: DateTime<Utc>) {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `slugify` is never used
[INFO] [stderr]    --> src/config/permalink.rs:129:4
[INFO] [stderr]     |
[INFO] [stderr] 129 | fn slugify(input: &str) -> String {
[INFO] [stderr]     |    ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `set_theme` and `available_themes` are never used
[INFO] [stderr]   --> src/markdown/renderer/syntax.rs:32:12
[INFO] [stderr]    |
[INFO] [stderr] 17 | impl SyntaxHighlighter {
[INFO] [stderr]    | ---------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 32 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 42 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `engine` and `toc_options` are never read
[INFO] [stderr]   --> src/markdown/renderer/markdown_renderer.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 23 | pub struct MarkdownRenderer<'a> {
[INFO] [stderr]    |            ---------------- fields in this struct
[INFO] [stderr] 24 |     engine: String,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 27 |     toc_options: TocOptions,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `set_theme`, `available_themes`, `set_toc_options`, `set_math_enabled`, `set_diagrams_enabled`, and `set_typographic_enabled` are never used
[INFO] [stderr]    --> src/markdown/renderer/markdown_renderer.rs:75:12
[INFO] [stderr]     |
[INFO] [stderr]  33 | impl<'a> MarkdownRenderer<'a> {
[INFO] [stderr]     | ----------------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr]  75 |     pub fn set_theme(&mut self, theme_name: &str) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  80 |     pub fn available_themes(&self) -> Vec<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  85 |     pub fn set_toc_options(&mut self, options: TocOptions) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  90 |     pub fn set_math_enabled(&mut self, enabled: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr]  95 |     pub fn set_diagrams_enabled(&mut self, enabled: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 100 |     pub fn set_typographic_enabled(&mut self, enabled: bool) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `markdownify` is never used
[INFO] [stderr]    --> src/markdown/renderer/markdown_renderer.rs:222:8
[INFO] [stderr]     |
[INFO] [stderr] 222 | pub fn markdownify<'a>(content: &str, renderer: &MarkdownRenderer<'a>) -> String {
[INFO] [stderr]     |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `min_level`, `max_level`, `include_title`, and `list_class` are never read
[INFO] [stderr]   --> src/markdown/toc/mod.rs:11:9
[INFO] [stderr]    |
[INFO] [stderr]  9 | pub struct TocOptions {
[INFO] [stderr]    |            ---------- fields in this struct
[INFO] [stderr] 10 |     /// Minimum level to include (h1 = 1, h2 = 2, etc.)
[INFO] [stderr] 11 |     pub min_level: usize,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr] 12 |     /// Maximum level to include
[INFO] [stderr] 13 |     pub max_level: usize,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr] 14 |     /// Whether to include the page title (h1)
[INFO] [stderr] 15 |     pub include_title: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^^
[INFO] [stderr] 16 |     /// CSS class for the TOC list
[INFO] [stderr] 17 |     pub list_class: String,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `TocOptions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `to_html` and `to_markdown` are never used
[INFO] [stderr]   --> src/markdown/toc/parser.rs:34:12
[INFO] [stderr]    |
[INFO] [stderr] 23 | impl TocHeading {
[INFO] [stderr]    | --------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 34 |     pub fn to_html(&self, _current_level: usize) -> String {
[INFO] [stderr]    |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 58 |     pub fn to_markdown(&self, indent_level: usize) -> String {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `to_html`, `to_markdown`, `to_simple_list`, and `append_simple_list` are never used
[INFO] [stderr]    --> src/markdown/toc/parser.rs:146:12
[INFO] [stderr]     |
[INFO] [stderr]  82 | impl TableOfContents {
[INFO] [stderr]     | -------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 146 |     pub fn to_html(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 163 |     pub fn to_markdown(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 178 |     pub fn to_simple_list(&self) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 188 |     fn append_simple_list(&self, list: &mut String, heading: &TocHeading, indent: usize) {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `TocOptions` is never constructed
[INFO] [stderr]    --> src/markdown/toc/parser.rs:270:12
[INFO] [stderr]     |
[INFO] [stderr] 270 | pub struct TocOptions {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `generate_toc_with_options` is never used
[INFO] [stderr]    --> src/markdown/toc/parser.rs:299:8
[INFO] [stderr]     |
[INFO] [stderr] 299 | pub fn generate_toc_with_options(_html: &str, _options: &TocOptions) -> BoxResult<String> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `DirectoryType` is never used
[INFO] [stderr]  --> src/directory/types/directory_type.rs:3:10
[INFO] [stderr]   |
[INFO] [stderr] 3 | pub enum DirectoryType {
[INFO] [stderr]   |          ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `sass_dir`, `theme_sass_dir`, `theme_assets_dir`, and `include_patterns` are never read
[INFO] [stderr]   --> src/directory/structure/directory_structure.rs:18:9
[INFO] [stderr]    |
[INFO] [stderr]  7 | pub struct DirectoryStructure {
[INFO] [stderr]    |            ------------------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 18 |     pub sass_dir: PathBuf,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 24 |     pub theme_sass_dir: Option<PathBuf>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^
[INFO] [stderr] 25 |     pub theme_assets_dir: Option<PathBuf>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 29 |     pub include_patterns: Vec<String>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `DirectoryStructure` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `get_directory` is never used
[INFO] [stderr]   --> src/directory/structure/directory_structure.rs:76:12
[INFO] [stderr]    |
[INFO] [stderr] 32 | impl DirectoryStructure {
[INFO] [stderr]    | ----------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 76 |     pub fn get_directory(&self, dir_type: DirectoryType) -> PathBuf {
[INFO] [stderr]    |            ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `copy` is never used
[INFO] [stderr]  --> src/directory/utils/file_operations.rs:8:8
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub fn copy(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stderr]   |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `copy_file` is never used
[INFO] [stderr]   --> src/directory/utils/file_operations.rs:37:8
[INFO] [stderr]    |
[INFO] [stderr] 37 | pub fn copy_file(source: &Path, destination: &Path) -> io::Result<()> {
[INFO] [stderr]    |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `copy_static_files` is never used
[INFO] [stderr]   --> src/directory/utils/file_operations.rs:59:8
[INFO] [stderr]    |
[INFO] [stderr] 59 | pub fn copy_static_files(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `patterns_to_regex` is never used
[INFO] [stderr]   --> src/directory/utils/path_helpers.rs:28:8
[INFO] [stderr]    |
[INFO] [stderr] 28 | pub fn patterns_to_regex(patterns: &[String]) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `option_patterns_to_regex` is never used
[INFO] [stderr]   --> src/directory/utils/path_helpers.rs:45:8
[INFO] [stderr]    |
[INFO] [stderr] 45 | pub fn option_patterns_to_regex(patterns: &Option<Vec<String>>) -> String {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_files` is never used
[INFO] [stderr]   --> src/directory/utils/path_helpers.rs:54:8
[INFO] [stderr]    |
[INFO] [stderr] 54 | pub fn find_files(config: &Config, patterns: &[&str]) -> BoxResult<Vec<PathBuf>> {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_excluded` is never used
[INFO] [stderr]   --> src/directory/utils/path_helpers.rs:91:8
[INFO] [stderr]    |
[INFO] [stderr] 91 | pub fn is_excluded(path: &Path, config: &Config) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `clean_directory` is never used
[INFO] [stderr]   --> src/directory/utils/cleaning.rs:57:8
[INFO] [stderr]    |
[INFO] [stderr] 57 | pub fn clean_directory(path: &Path) -> io::Result<()> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `metadata` is never read
[INFO] [stderr]   --> src/collections/document/model/mod.rs:35:9
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct Collection {
[INFO] [stderr]    |            ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 35 |     pub metadata: CollectionMetadata,
[INFO] [stderr]    |         ^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Collection` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Draft` is never constructed
[INFO] [stderr]   --> src/collections/document/model/mod.rs:53:5
[INFO] [stderr]    |
[INFO] [stderr] 48 | pub enum DocumentState {
[INFO] [stderr]    |          ------------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 53 |     Draft,
[INFO] [stderr]    |     ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `DocumentState` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: fields `state`, `mtime`, and `ctime` are never read
[INFO] [stderr]    --> src/collections/document/model/mod.rs:96:9
[INFO] [stderr]     |
[INFO] [stderr]  61 | pub struct Document {
[INFO] [stderr]     |            -------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr]  96 |     pub state: DocumentState,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 114 |     pub mtime: Option<DateTime<Utc>>,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 117 |     pub ctime: Option<DateTime<Utc>>,
[INFO] [stderr]     |         ^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `Document` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: methods `should_write` and `title` are never used
[INFO] [stderr]    --> src/collections/document/model/mod.rs:189:12
[INFO] [stderr]     |
[INFO] [stderr] 120 | impl Document {
[INFO] [stderr]     | ------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 189 |     pub fn should_write(&self, config: &Config) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 217 |     pub fn title(&self) -> Option<String> {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `load_documents` is never used
[INFO] [stderr]    --> src/collections/document/loader/mod.rs:171:4
[INFO] [stderr]     |
[INFO] [stderr] 171 | fn load_documents(dir: &Path, collection: &str, _config: &Config) -> BoxResult<Vec<Document>> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: type alias `BoxResult` is never used
[INFO] [stderr]   --> src/front_matter/types/front_matter.rs:10:6
[INFO] [stderr]    |
[INFO] [stderr] 10 | type BoxResult<T> = Result<T, Box<dyn Error>>;
[INFO] [stderr]    |      ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple associated items are never used
[INFO] [stderr]    --> src/front_matter/types/front_matter.rs:236:12
[INFO] [stderr]     |
[INFO] [stderr] 234 | impl FrontMatter {
[INFO] [stderr]     | ---------------- associated items in this implementation
[INFO] [stderr] 235 |     /// Create a new empty front matter
[INFO] [stderr] 236 |     pub fn new() -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 241 |     pub fn parse(content: &str) -> BoxResult<Self> {
[INFO] [stderr]     |            ^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 246 |     pub fn extract_content(content: &str) -> String {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 251 |     pub fn to_yaml(&self) -> BoxResult<String> {
[INFO] [stderr]     |            ^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 257 |     pub fn add_to_content(&self, content: &str) -> BoxResult<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 613 |     pub fn get_modified_date(&self) -> Option<chrono::DateTime<chrono::Utc>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 635 |     pub fn get_category_string(&self) -> Option<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 640 |     pub fn get_tag_string(&self) -> Option<String> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 645 |     pub fn is_published(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 650 |     pub fn is_draft(&self) -> bool {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 655 |     pub fn get_state(&self) -> crate::collections::document::model::DocumentState {
[INFO] [stderr]     |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `extract_content` is never used
[INFO] [stderr]  --> src/front_matter/utils/content.rs:7:8
[INFO] [stderr]   |
[INFO] [stderr] 7 | pub fn extract_content(content: &str) -> String {
[INFO] [stderr]   |        ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `extract_front_matter_only` is never used
[INFO] [stderr]   --> src/front_matter/utils/content.rs:68:8
[INFO] [stderr]    |
[INFO] [stderr] 68 | pub fn extract_front_matter_only(content: &str) -> BoxResult<FrontMatter> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_front_matter` is never used
[INFO] [stderr]  --> src/front_matter/parser/mod.rs:8:8
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub fn parse_front_matter(content: &str) -> Result<FrontMatter, Box<dyn Error>> {
[INFO] [stderr]   |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_yaml` is never used
[INFO] [stderr]   --> src/front_matter/parser/yaml_parser.rs:35:8
[INFO] [stderr]    |
[INFO] [stderr] 35 | pub fn parse_yaml(content: &str) -> Result<(serde_yaml::Value, String), Box<dyn Error>> {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_defaults_to_front_matter` is never used
[INFO] [stderr]  --> src/front_matter/defaults.rs:8:8
[INFO] [stderr]   |
[INFO] [stderr] 8 | pub fn apply_defaults_to_front_matter(
[INFO] [stderr]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_defaults_to_paths` is never used
[INFO] [stderr]   --> src/front_matter/defaults.rs:34:8
[INFO] [stderr]    |
[INFO] [stderr] 34 | pub fn apply_defaults_to_paths(
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_defaults` is never used
[INFO] [stderr]    --> src/front_matter/defaults.rs:130:8
[INFO] [stderr]     |
[INFO] [stderr] 130 | pub fn apply_defaults(
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `apply_defaults_from_list` is never used
[INFO] [stderr]    --> src/front_matter/defaults.rs:154:4
[INFO] [stderr]     |
[INFO] [stderr] 154 | fn apply_defaults_from_list(
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `find_matching_default` is never used
[INFO] [stderr]    --> src/front_matter/defaults.rs:184:4
[INFO] [stderr]     |
[INFO] [stderr] 184 | fn find_matching_default<'a>(path: &Path, defaults: &'a [FrontMatterDefault]) -> Option<&'a FrontMatterDefault> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `parse_liquid` is never used
[INFO] [stderr]   --> src/liquid/mod.rs:79:8
[INFO] [stderr]    |
[INFO] [stderr] 79 | pub fn parse_liquid(content: &str, parser: &liquid::Parser, globals: &Object) -> BoxResult<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `parse_parameters` is never used
[INFO] [stderr]   --> src/liquid/tags/include.rs:91:8
[INFO] [stderr]    |
[INFO] [stderr] 18 | impl IncludeTag {
[INFO] [stderr]    | --------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 91 |     fn parse_parameters(&self, params_str: &str) -> HashMap<String, String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_file` is never used
[INFO] [stderr]   --> src/utils/fs.rs:13:8
[INFO] [stderr]    |
[INFO] [stderr] 13 | pub fn is_file<P: AsRef<Path>>(path: P) -> bool {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `remove_directory` is never used
[INFO] [stderr]   --> src/utils/fs.rs:24:8
[INFO] [stderr]    |
[INFO] [stderr] 24 | pub fn remove_directory<P: AsRef<Path>>(path: P) -> BoxResult<()> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `read_file` is never used
[INFO] [stderr]   --> src/utils/fs.rs:32:8
[INFO] [stderr]    |
[INFO] [stderr] 32 | pub fn read_file<P: AsRef<Path>>(path: P) -> BoxResult<String> {
[INFO] [stderr]    |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `write_file` is never used
[INFO] [stderr]   --> src/utils/fs.rs:40:8
[INFO] [stderr]    |
[INFO] [stderr] 40 | pub fn write_file<P: AsRef<Path>>(path: P, contents: &str) -> BoxResult<()> {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `copy_file` is never used
[INFO] [stderr]   --> src/utils/fs.rs:52:8
[INFO] [stderr]    |
[INFO] [stderr] 52 | pub fn copy_file<P: AsRef<Path>, Q: AsRef<Path>>(from: P, to: Q) -> BoxResult<u64> {
[INFO] [stderr]    |        ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `list_files` is never used
[INFO] [stderr]   --> src/utils/fs.rs:63:8
[INFO] [stderr]    |
[INFO] [stderr] 63 | pub fn list_files<P: AsRef<Path>>(dir: P) -> BoxResult<Vec<PathBuf>> {
[INFO] [stderr]    |        ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `normalize_path` is never used
[INFO] [stderr]  --> src/utils/path.rs:4:8
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub fn normalize_path<P: AsRef<Path>>(path: P) -> PathBuf {
[INFO] [stderr]   |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_extension` is never used
[INFO] [stderr]   --> src/utils/path.rs:30:8
[INFO] [stderr]    |
[INFO] [stderr] 30 | pub fn get_extension<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `get_stem` is never used
[INFO] [stderr]   --> src/utils/path.rs:38:8
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub fn get_stem<P: AsRef<Path>>(path: P) -> Option<String> {
[INFO] [stderr]    |        ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `has_extension` is never used
[INFO] [stderr]   --> src/utils/path.rs:46:8
[INFO] [stderr]    |
[INFO] [stderr] 46 | pub fn has_extension<P: AsRef<Path>>(path: P, ext: &str) -> bool {
[INFO] [stderr]    |        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `make_relative` is never used
[INFO] [stderr]   --> src/utils/path.rs:52:8
[INFO] [stderr]    |
[INFO] [stderr] 52 | pub fn make_relative<P: AsRef<Path>, B: AsRef<Path>>(path: P, base: B) -> Option<PathBuf> {
[INFO] [stderr]    |        ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `uri_to_path` is never used
[INFO] [stderr]   --> src/utils/path.rs:73:8
[INFO] [stderr]    |
[INFO] [stderr] 73 | pub fn uri_to_path<P: AsRef<Path>>(root: P, uri: &str) -> PathBuf {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `join` is never used
[INFO] [stderr]   --> src/utils/path.rs:84:8
[INFO] [stderr]    |
[INFO] [stderr] 84 | pub fn join<P: AsRef<Path>, Q: AsRef<Path>>(base: P, path: Q) -> PathBuf {
[INFO] [stderr]    |        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variants `Template`, `FrontMatter`, `Markdown`, `File`, and `Server` are never constructed
[INFO] [stderr]   --> src/utils/error.rs:16:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub enum RustyllError {
[INFO] [stderr]    |          ------------ variants in this enum
[INFO] [stderr] ...
[INFO] [stderr] 16 |     Template(String),
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 17 |     /// Front matter parsing error
[INFO] [stderr] 18 |     FrontMatter(String),
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 19 |     /// Markdown processing error
[INFO] [stderr] 20 |     Markdown(String),
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 21 |     /// File handling error
[INFO] [stderr] 22 |     File(String),
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 23 |     /// Server error
[INFO] [stderr] 24 |     Server(String),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `RustyllError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: struct `LayoutRenderer` is never constructed
[INFO] [stderr]   --> src/layout/renderer.rs:11:12
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub struct LayoutRenderer {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `render`, and `find_layout` are never used
[INFO] [stderr]   --> src/layout/renderer.rs:21:12
[INFO] [stderr]    |
[INFO] [stderr] 19 | impl LayoutRenderer {
[INFO] [stderr]    | ------------------- associated items in this implementation
[INFO] [stderr] 20 |     /// Create a new layout renderer
[INFO] [stderr] 21 |     pub fn new(config: &Config) -> Self {
[INFO] [stderr]    |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |     pub fn render(&self, content: &str, layout_name: &str, globals: &liquid::Object) -> BoxResult<String> {
[INFO] [stderr]    |            ^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 66 |     fn find_layout(&self, name: &str) -> BoxResult<PathBuf> {
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `console_output` is never read
[INFO] [stderr]   --> src/report/mod.rs:14:9
[INFO] [stderr]    |
[INFO] [stderr] 12 | pub struct ReportOptions {
[INFO] [stderr]    |            ------------- field in this struct
[INFO] [stderr] 13 |     pub verbose: bool,
[INFO] [stderr] 14 |     pub console_output: bool,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `title`, `build_time`, `num_pages`, `num_posts`, and `num_collections` are never read
[INFO] [stderr]   --> src/report/mod.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 18 | pub struct SiteReport {
[INFO] [stderr]    |            ---------- fields in this struct
[INFO] [stderr] 19 |     /// Site title
[INFO] [stderr] 20 |     pub title: String,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr] 21 |     /// Build time
[INFO] [stderr] 22 |     pub build_time: Duration,
[INFO] [stderr]    |         ^^^^^^^^^^
[INFO] [stderr] 23 |     /// Number of pages
[INFO] [stderr] 24 |     pub num_pages: usize,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr] 25 |     /// Number of posts
[INFO] [stderr] 26 |     pub num_posts: usize,
[INFO] [stderr]    |         ^^^^^^^^^
[INFO] [stderr] 27 |     /// Number of collections
[INFO] [stderr] 28 |     pub num_collections: usize,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `Ignored` is never constructed
[INFO] [stderr]   --> src/migrate/mod.rs:63:5
[INFO] [stderr]    |
[INFO] [stderr] 58 | pub enum ChangeType {
[INFO] [stderr]    |          ---------- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 63 |     Ignored,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `description` is never used
[INFO] [stderr]   --> src/migrate/mod.rs:81:8
[INFO] [stderr]    |
[INFO] [stderr] 79 | pub trait EngineMigrator {
[INFO] [stderr]    |           -------------- method in this trait
[INFO] [stderr] 80 |     fn name(&self) -> &'static str;
[INFO] [stderr] 81 |     fn description(&self) -> &'static str;
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `taxonomies` is never read
[INFO] [stderr]   --> src/migrate/engines/hugo/config.rs:19:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | struct HugoConfig {
[INFO] [stderr]    |        ---------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 19 |     taxonomies: Option<serde_json::Value>,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `HugoConfig` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: method `write_readme_files` is never used
[INFO] [stderr]   --> src/migrate/engines/zola/readme.rs:64:19
[INFO] [stderr]    |
[INFO] [stderr] 63 | impl super::ZolaMigrator {
[INFO] [stderr]    | ------------------------ method in this implementation
[INFO] [stderr] 64 |     pub(super) fn write_readme_files(&self, dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `migrate_static_assets` is never used
[INFO] [stderr]  --> src/migrate/engines/mkdocs/static_assets.rs:6:15
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub(super) fn migrate_static_assets(
[INFO] [stderr]   |               ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_default_assets` is never used
[INFO] [stderr]   --> src/migrate/engines/mkdocs/static_assets.rs:98:4
[INFO] [stderr]    |
[INFO] [stderr] 98 | fn create_default_assets(
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `convert_json_to_yaml` is never used
[INFO] [stderr]    --> src/migrate/engines/gitbook/config.rs:216:4
[INFO] [stderr]     |
[INFO] [stderr] 216 | fn convert_json_to_yaml(json_value: serde_json::Value) -> serde_yaml::Value {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `generate_jekyll_config` is never used
[INFO] [stderr]    --> src/migrate/engines/slate/config.rs:138:4
[INFO] [stderr]     |
[INFO] [stderr] 138 | fn generate_jekyll_config(source_dir: &Path) -> Result<String, String> {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `has_cobalt_structure` is never used
[INFO] [stderr]    --> src/migrate/engines/cobalt/mod.rs:119:4
[INFO] [stderr]     |
[INFO] [stderr] 119 | fn has_cobalt_structure(source_dir: &Path) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `is_cobalt_config` is never used
[INFO] [stderr]    --> src/migrate/engines/cobalt/mod.rs:129:4
[INFO] [stderr]     |
[INFO] [stderr] 129 | fn is_cobalt_config(source_dir: &Path) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `create_default_includes` is never used
[INFO] [stderr]   --> src/migrate/engines/cobalt/includes.rs:95:4
[INFO] [stderr]    |
[INFO] [stderr] 95 | fn create_default_includes(
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `migrate_data` is never used
[INFO] [stderr]  --> src/migrate/engines/cobalt/data.rs:6:15
[INFO] [stderr]   |
[INFO] [stderr] 6 | pub(super) fn migrate_data(source_dir: &Path, dest_dir: &Path, verbose: bool, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]   |               ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `write_readme_files` is never used
[INFO] [stderr]  --> src/migrate/engines/cobalt/readme.rs:4:15
[INFO] [stderr]   |
[INFO] [stderr] 4 | pub(super) fn write_readme_files(dest_dir: &Path, result: &mut MigrationResult) -> Result<(), String> {
[INFO] [stderr]   |               ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `handle_hook` and `cleanup` are never used
[INFO] [stderr]   --> src/plugins/mod.rs:60:8
[INFO] [stderr]    |
[INFO] [stderr] 49 | pub trait Plugin: Send + Sync {
[INFO] [stderr]    |           ------ methods in this trait
[INFO] [stderr] ...
[INFO] [stderr] 60 |     fn handle_hook(&self, hook: &Hook, context: &mut HookContext) -> HookResult;
[INFO] [stderr]    |        ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 63 |     fn cleanup(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]    |        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: fields `plugin_dir`, `registry`, `loader`, and `hook_handlers` are never read
[INFO] [stderr]   --> src/plugins/mod.rs:73:5
[INFO] [stderr]    |
[INFO] [stderr] 69 | pub struct PluginManager {
[INFO] [stderr]    |            ------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 73 |     plugin_dir: PathBuf,
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 74 |     /// Registry of loaded plugins
[INFO] [stderr] 75 |     registry: Arc<RwLock<PluginRegistry>>,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 76 |     /// Plugin loader
[INFO] [stderr] 77 |     loader: PluginLoader,
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr] 78 |     /// Hook handlers mapped by hook name
[INFO] [stderr] 79 |     hook_handlers: Arc<RwLock<HashMap<String, Vec<Arc<dyn Plugin>>>>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple methods are never used
[INFO] [stderr]    --> src/plugins/mod.rs:100:12
[INFO] [stderr]     |
[INFO] [stderr]  82 | impl PluginManager {
[INFO] [stderr]     | ------------------ methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 100 |     pub fn load_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 136 |     fn load_plugin_configs(&self) -> Result<HashMap<String, PluginConfig>, Box<dyn std::error::Error>> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 187 |     fn load_plugin(&mut self, name: &str, config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |        ^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 212 |     fn register_all_hooks(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 233 |     pub fn execute_hook(&self, hook_name: &str, context: &mut HookContext) -> HookResult {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 263 |     pub fn list_plugins(&self) -> Vec<PluginMetadata> {
[INFO] [stderr]     |            ^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 272 |     pub fn unload_all(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |            ^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 285 |     pub fn reload_plugins(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: multiple variants are never constructed
[INFO] [stderr]   --> src/plugins/hooks.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr]  8 | pub enum Hook {
[INFO] [stderr]    |          ---- variants in this enum
[INFO] [stderr]  9 |     /// Before site initialization
[INFO] [stderr] 10 |     PreInit,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 11 |     /// After site initialization
[INFO] [stderr] 12 |     PostInit,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 13 |     /// Before reading source files
[INFO] [stderr] 14 |     PreRead,
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 15 |     /// After reading source files
[INFO] [stderr] 16 |     PostRead,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 17 |     /// Before generating pages
[INFO] [stderr] 18 |     PreGenerate,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 19 |     /// After generating pages
[INFO] [stderr] 20 |     PostGenerate,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 21 |     /// Before rendering content
[INFO] [stderr] 22 |     PreRender,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 30 |     PreClean,
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 31 |     /// After cleaning site
[INFO] [stderr] 32 |     PostClean,
[INFO] [stderr]    |     ^^^^^^^^^
[INFO] [stderr] 33 |     /// Custom hook
[INFO] [stderr] 34 |     Custom(String),
[INFO] [stderr]    |     ^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Hook` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `name` and `from_name` are never used
[INFO] [stderr]   --> src/plugins/hooks.rs:39:12
[INFO] [stderr]    |
[INFO] [stderr] 37 | impl Hook {
[INFO] [stderr]    | --------- associated items in this implementation
[INFO] [stderr] 38 |     /// Get the name of the hook
[INFO] [stderr] 39 |     pub fn name(&self) -> &str {
[INFO] [stderr]    |            ^^^^
[INFO] [stderr] ...
[INFO] [stderr] 58 |     pub fn from_name(name: &str) -> Self {
[INFO] [stderr]    |            ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: struct `HookContext` is never constructed
[INFO] [stderr]   --> src/plugins/hooks.rs:79:12
[INFO] [stderr]    |
[INFO] [stderr] 79 | pub struct HookContext {
[INFO] [stderr]    |            ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: associated items `new`, `add_data`, `get_data`, `set_current_page`, and `clear_current_page` are never used
[INFO] [stderr]    --> src/plugins/hooks.rs:94:12
[INFO] [stderr]     |
[INFO] [stderr]  92 | impl HookContext {
[INFO] [stderr]     | ---------------- associated items in this implementation
[INFO] [stderr]  93 |     /// Create a new hook context
[INFO] [stderr]  94 |     pub fn new(source_dir: String, output_dir: String) -> Self {
[INFO] [stderr]     |            ^^^
[INFO] [stderr] ...
[INFO] [stderr] 105 |     pub fn add_data(&mut self, key: String, value: Value) {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 110 |     pub fn get_data(&self, key: &str) -> Option<&Value> {
[INFO] [stderr]     |            ^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 115 |     pub fn set_current_page(&mut self, page: String) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 120 |     pub fn clear_current_page(&mut self) {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: enum `HookResult` is never used
[INFO] [stderr]    --> src/plugins/hooks.rs:127:10
[INFO] [stderr]     |
[INFO] [stderr] 127 | pub enum HookResult {
[INFO] [stderr]     |          ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: methods `load_rust_plugin`, `load_wasm_plugin`, `load_js_plugin`, and `load_python_plugin` are never used
[INFO] [stderr]   --> src/plugins/loader.rs:20:12
[INFO] [stderr]    |
[INFO] [stderr] 13 | impl PluginLoader {
[INFO] [stderr]    | ----------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 20 |     pub fn load_rust_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 36 |     pub fn load_wasm_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 49 |     pub fn load_js_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 62 |     pub fn load_python_plugin(&self, path: &Path, _config: &PluginConfig) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `rustyll` (bin "rustyll" test) generated 247 warnings (run `cargo fix --bin "rustyll" -p rustyll --tests` to apply 104 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.50s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/rustyll-befa920c387e7aae)
[INFO] [stdout] 
[INFO] [stdout] running 34 tests
[INFO] [stdout] test front_matter::defaults::tests::test_scope_matches_path ... ok
[INFO] [stdout] test front_matter::parser::yaml_parser::tests::test_parse_front_matter ... ok
[INFO] [stdout] test front_matter::parser::yaml_parser::tests::test_merge_front_matter ... ok
[INFO] [stdout] test front_matter::defaults::tests::test_scope_matches_type ... ok
[INFO] [stdout] test markdown::toc::parser::tests::test_generate_id_from_text ... ok
[INFO] [stdout] test markdown::engine::comrak::tests::test_comrak_rendering ... ok
[INFO] [stdout] test plugins::registry::tests::test_registry_operations ... ok
[INFO] [stdout] test plugins::tests::test_builtin_seo_plugin ... ok
[INFO] [stdout] test plugins::tests::test_plugin_manager_creation ... ok
[INFO] [stdout] test plugins::tests::test_builtin_feed_plugin ... ok
[INFO] [stdout] test markdown::toc::generator::tests::test_extract_headings ... ok
[INFO] [stdout] test markdown::utils::text::tests::test_extract_summary ... ok
[INFO] [stdout] test markdown::toc::generator::tests::test_toc_generation ... ok
[INFO] [stdout] test server::middleware::cache::tests::test_generate_etag ... ok
[INFO] [stdout] test server::middleware::cache::tests::test_is_static_asset ... ok
[INFO] [stdout] test server::middleware::cache::tests::test_cache_control_header ... ok
[INFO] [stdout] test server::middleware::compression::tests::test_compression_config ... ok
[INFO] [stdout] test server::middleware::security::tests::test_csp_header ... ok
[INFO] [stdout] test server::middleware::security::tests::test_hsts_header ... ok
[INFO] [stdout] test server::middleware::security::tests::test_referrer_policy ... ok
[INFO] [stdout] test server::middleware::compression::tests::test_compression_stats ... ok
[INFO] [stdout] test server::middleware::compression::tests::test_should_compress_content_type ... ok
[INFO] [stdout] test server::middleware::security::tests::test_x_frame_options ... ok
[INFO] [stdout] test markdown::utils::text::tests::test_strip_markdown ... ok
[INFO] [stdout] test markdown::renderer::markdown_renderer::tests::test_math_rendering ... ok
[INFO] [stdout] test markdown::renderer::syntax::tests::test_syntax_highlighting ... ok
[INFO] [stdout] test markdown::renderer::syntax::tests::test_html_processing ... ok
[INFO] [stdout] test markdown::renderer::markdown_renderer::tests::test_markdown_rendering ... ok
[INFO] [stdout] test front_matter::defaults::tests::test_apply_default_if_matches ... FAILED
[INFO] [stdout] test markdown::toc::parser::tests::test_build_toc_hierarchy ... FAILED
[INFO] [stdout] test markdown::renderer::markdown_renderer::tests::test_syntax_highlighting ... FAILED
[INFO] [stdout] test markdown::toc::parser::tests::test_toc_with_levels ... FAILED
[INFO] [stdout] test markdown::renderer::markdown_renderer::tests::test_table_of_contents ... FAILED
[INFO] [stdout] test markdown::toc::parser::tests::test_extract_headings ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- front_matter::defaults::tests::test_apply_default_if_matches stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'front_matter::defaults::tests::test_apply_default_if_matches' (24) panicked at src/front_matter/defaults.rs:240:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: None
[INFO] [stdout]  right: Some("post")
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc6838 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1d00c13 - core[585f66e14d78f9ba]::panicking::assert_failed_inner
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:439:17
[INFO] [stdout]   20:     0x590eb17a4f40 - core[585f66e14d78f9ba]::panicking::assert_failed::<core[585f66e14d78f9ba]::option::Option<alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::option::Option<alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:394:5
[INFO] [stdout]   21:     0x590eb17acf9d - rustyll[cd2bdb2e884ca23b]::front_matter::defaults::tests::test_apply_default_if_matches
[INFO] [stdout]                                at /opt/rustwide/workdir/src/front_matter/defaults.rs:240:9
[INFO] [stdout]   22:     0x590eb17ac037 - rustyll[cd2bdb2e884ca23b]::front_matter::defaults::tests::test_apply_default_if_matches::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/front_matter/defaults.rs:226:39
[INFO] [stdout]   23:     0x590eb1779156 - <rustyll[cd2bdb2e884ca23b]::front_matter::defaults::tests::test_apply_default_if_matches::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   26:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   27:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   28:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   29:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   30:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   32:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   33:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   34:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   35:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   36:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   37:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   38:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   39:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   41:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   43:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   44:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   45:     0x7436ff960a64 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- markdown::toc::parser::tests::test_build_toc_hierarchy stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'markdown::toc::parser::tests::test_build_toc_hierarchy' (38) panicked at src/markdown/toc/parser.rs:9:7:
[INFO] [stdout] called `Result::unwrap()` on an `Err` value: Syntax(
[INFO] [stdout] ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] regex parse error:
[INFO] [stdout]     <h([1-6])(?:[^>]*)(?:id=["']([^"']+)["'])?(?:[^>]*)>(.*?)</h\1>
[INFO] [stdout]                                                                 ^^
[INFO] [stdout] error: backreferences are not supported
[INFO] [stdout] ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[INFO] [stdout] )
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc6838 - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:698:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1d00ad2 - core[585f66e14d78f9ba]::result::unwrap_failed
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1867:5
[INFO] [stdout]   20:     0x590eb1779b7d - <core[585f66e14d78f9ba]::result::Result<regex[f56c331b238269e]::regex::string::Regex, regex[f56c331b238269e]::error::Error>>::unwrap
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/result.rs:1233:23
[INFO] [stdout]   21:     0x590eb1779b7d - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:9:7
[INFO] [stdout]   22:     0x590eb1779b7d - <<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x590eb1761f5e - <lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get::<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:31:41
[INFO] [stdout]   24:     0x590eb176710d - <std[3f03f8b59f91bef1]::sync::once::Once>::call_once::<<lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sync/once.rs:159:41
[INFO] [stdout]   25:     0x590eb1ccbc27 - <std[3f03f8b59f91bef1]::sys::sync::once::futex::Once>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/sync/once/futex.rs:178:21
[INFO] [stdout]   26:     0x590eb1765707 - <std[3f03f8b59f91bef1]::sync::once::Once>::call_once::<<lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sync/once.rs:159:20
[INFO] [stdout]   27:     0x590eb1771c8f - <lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get::<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16
[INFO] [stdout]   28:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__stability
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:135:26
[INFO] [stdout]   29:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:137:17
[INFO] [stdout]   30:     0x590eb17703b9 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::extract_headings
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:202:16
[INFO] [stdout]   31:     0x590eb17708c2 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::build_toc_from_html
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:223:25
[INFO] [stdout]   32:     0x590eb1768cc8 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_build_toc_hierarchy
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:416:19
[INFO] [stdout]   33:     0x590eb17677a7 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_build_toc_hierarchy::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:406:34
[INFO] [stdout]   34:     0x590eb1779556 - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_build_toc_hierarchy::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   35:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   36:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   37:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   38:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   39:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   40:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   41:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   42:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   43:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   44:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   45:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   46:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   47:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   48:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   49:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   50:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   51:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   52:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   53:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   54:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   55:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   56:     0x7436ff960a64 - clone
[INFO] [stdout]   57:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- markdown::renderer::markdown_renderer::tests::test_syntax_highlighting stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'markdown::renderer::markdown_renderer::tests::test_syntax_highlighting' (32) panicked at src/markdown/renderer/markdown_renderer.rs:250:9:
[INFO] [stdout] assertion failed: html.contains("<div class=\"highlight\">")
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc686a - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1d00d52 - core[585f66e14d78f9ba]::panicking::panic
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:150:5
[INFO] [stdout]   20:     0x590eb17644bf - rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_syntax_highlighting
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:250:9
[INFO] [stdout]   21:     0x590eb1762987 - rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_syntax_highlighting::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:243:34
[INFO] [stdout]   22:     0x590eb17797d6 - <rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_syntax_highlighting::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   25:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   26:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   27:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   28:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   29:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   31:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   32:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   33:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stderr] error: test failed, to rerun pass `--bin rustyll`
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   34:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   35:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   36:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   37:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   38:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   40:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   42:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   43:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   44:     0x7436ff960a64 - clone
[INFO] [stdout]   45:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- markdown::toc::parser::tests::test_toc_with_levels stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'markdown::toc::parser::tests::test_toc_with_levels' (41) panicked at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16:
[INFO] [stdout] Once instance has previously been poisoned
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc686a - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1ccbd1c - <std[3f03f8b59f91bef1]::sys::sync::once::futex::Once>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/sync/once/futex.rs:150:21
[INFO] [stdout]   20:     0x590eb1765707 - <std[3f03f8b59f91bef1]::sync::once::Once>::call_once::<<lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sync/once.rs:159:20
[INFO] [stdout]   21:     0x590eb1771c8f - <lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get::<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16
[INFO] [stdout]   22:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__stability
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:135:26
[INFO] [stdout]   23:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:137:17
[INFO] [stdout]   24:     0x590eb17703b9 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::extract_headings
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:202:16
[INFO] [stdout]   25:     0x590eb1770a9c - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::build_toc_with_levels
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:231:25
[INFO] [stdout]   26:     0x590eb17685e3 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_toc_with_levels
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:432:19
[INFO] [stdout]   27:     0x590eb1767747 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_toc_with_levels::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:423:30
[INFO] [stdout]   28:     0x590eb17794d6 - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_toc_with_levels::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   29:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   30:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   31:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   32:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   33:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   34:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   35:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   36:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   37:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   38:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   39:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   40:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   41:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   42:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   43:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   44:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   45:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   46:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   47:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   48:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   49:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   50:     0x7436ff960a64 - clone
[INFO] [stdout]   51:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- markdown::renderer::markdown_renderer::tests::test_table_of_contents stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'markdown::renderer::markdown_renderer::tests::test_table_of_contents' (33) panicked at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16:
[INFO] [stdout] Once instance has previously been poisoned
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc686a - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1ccbd1c - <std[3f03f8b59f91bef1]::sys::sync::once::futex::Once>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/sync/once/futex.rs:150:21
[INFO] [stdout]   20:     0x590eb1765707 - <std[3f03f8b59f91bef1]::sync::once::Once>::call_once::<<lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sync/once.rs:159:20
[INFO] [stdout]   21:     0x590eb1771c8f - <lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get::<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16
[INFO] [stdout]   22:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__stability
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:135:26
[INFO] [stdout]   23:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:137:17
[INFO] [stdout]   24:     0x590eb17703b9 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::extract_headings
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:202:16
[INFO] [stdout]   25:     0x590eb176e0dd - <rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::MarkdownRenderer>::generate_toc
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:169:24
[INFO] [stdout]   26:     0x590eb176e5a5 - <rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::MarkdownRenderer>::render_with_toc
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:216:24
[INFO] [stdout]   27:     0x590eb1763f3b - rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_table_of_contents
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:260:36
[INFO] [stdout]   28:     0x590eb1762927 - rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_table_of_contents::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/renderer/markdown_renderer.rs:255:32
[INFO] [stdout]   29:     0x590eb1779756 - <rustyll[cd2bdb2e884ca23b]::markdown::renderer::markdown_renderer::tests::test_table_of_contents::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   30:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   31:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   32:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   33:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   34:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   35:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   36:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   37:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   38:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   39:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   40:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   41:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   42:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   43:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   44:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   45:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   46:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   47:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   48:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   49:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   50:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   51:     0x7436ff960a64 - clone
[INFO] [stdout]   52:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- markdown::toc::parser::tests::test_extract_headings stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'markdown::toc::parser::tests::test_extract_headings' (39) panicked at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16:
[INFO] [stdout] Once instance has previously been poisoned
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::libunwind::trace
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::backtrace_rs::backtrace::trace_unsynchronized::<std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt::{closure#1}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x590eb1ce81a2 - std[3f03f8b59f91bef1]::sys::backtrace::_print_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:74:9
[INFO] [stdout]    3:     0x590eb1ce81a2 - <<std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print::DisplayBacktrace as core[585f66e14d78f9ba]::fmt::Display>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:44:26
[INFO] [stdout]    4:     0x590eb1d0059a - <core[585f66e14d78f9ba]::fmt::rt::Argument>::fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/fmt/rt.rs:152:76
[INFO] [stdout]    5:     0x590eb1d0059a - core[585f66e14d78f9ba]::fmt::write
[INFO] [stdout]    6:     0x590eb1ced0e6 - std[3f03f8b59f91bef1]::io::default_write_fmt::<alloc[15e7b27aba85d2e2]::vec::Vec<u8>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x590eb1ced0e6 - <alloc[15e7b27aba85d2e2]::vec::Vec<u8> as std[3f03f8b59f91bef1]::io::Write>::write_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/io/mod.rs:1994:13
[INFO] [stdout]    8:     0x590eb1cc677f - <std[3f03f8b59f91bef1]::sys::backtrace::BacktraceLock>::print
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:47:9
[INFO] [stdout]    9:     0x590eb1cc677f - std[3f03f8b59f91bef1]::panicking::default_hook::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:292:27
[INFO] [stdout]   10:     0x590eb1ce0359 - std[3f03f8b59f91bef1]::panicking::default_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:316:9
[INFO] [stdout]   11:     0x590eb17dc7ae - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   12:     0x590eb17dc7ae - test[30224e0cb089acd2]::test_main_with_exit_callback::<test[30224e0cb089acd2]::test_main::{closure#0}>::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x590eb1ce0512 - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn for<'a, 'b> core[585f66e14d78f9ba]::ops::function::Fn<(&'a std[3f03f8b59f91bef1]::panic::PanicHookInfo<'b>,), Output = ()> + core[585f66e14d78f9ba]::marker::Sync + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::Fn<(&std[3f03f8b59f91bef1]::panic::PanicHookInfo,)>>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2220:9
[INFO] [stdout]   14:     0x590eb1ce0512 - std[3f03f8b59f91bef1]::panicking::panic_with_hook
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:833:13
[INFO] [stdout]   15:     0x590eb1cc686a - std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:691:13
[INFO] [stdout]   16:     0x590eb1cbb9f9 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_end_short_backtrace::<std[3f03f8b59f91bef1]::panicking::panic_handler::{closure#0}, !>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:182:18
[INFO] [stdout]   17:     0x590eb1cc768d - __rustc[caa99d26c7bae192]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:689:5
[INFO] [stdout]   18:     0x590eb1d00d8c - core[585f66e14d78f9ba]::panicking::panic_fmt
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panicking.rs:80:14
[INFO] [stdout]   19:     0x590eb1ccbd1c - <std[3f03f8b59f91bef1]::sys::sync::once::futex::Once>::call
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/sync/once/futex.rs:150:21
[INFO] [stdout]   20:     0x590eb1765707 - <std[3f03f8b59f91bef1]::sync::once::Once>::call_once::<<lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>::{closure#0}>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sync/once.rs:159:20
[INFO] [stdout]   21:     0x590eb1771c8f - <lazy_static[cac736491fa996d8]::lazy::Lazy<regex[f56c331b238269e]::regex::string::Regex>>::get::<<rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__static_ref_initialize>
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/inline_lazy.rs:30:16
[INFO] [stdout]   22:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref::__stability
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:135:26
[INFO] [stdout]   23:     0x590eb1771c8f - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::HEADING_REGEX as core[585f66e14d78f9ba]::ops::deref::Deref>::deref
[INFO] [stdout]                                at /opt/rustwide/cargo-home/registry/src/index.crates.io-1949cf8c6b5b557f/lazy_static-1.5.0/src/lib.rs:137:17
[INFO] [stdout]   24:     0x590eb17703b9 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::extract_headings
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:202:16
[INFO] [stdout]   25:     0x590eb1768848 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_extract_headings
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:385:24
[INFO] [stdout]   26:     0x590eb1767777 - rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_extract_headings::{closure#0}
[INFO] [stdout]                                at /opt/rustwide/workdir/src/markdown/toc/parser.rs:376:31
[INFO] [stdout]   27:     0x590eb1779516 - <rustyll[cd2bdb2e884ca23b]::markdown::toc::parser::tests::test_extract_headings::{closure#0} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   28:     0x590eb17d0b5b - <fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   29:     0x590eb17d0b5b - test[30224e0cb089acd2]::__rust_begin_short_backtrace::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, fn() -> core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:663:18
[INFO] [stdout]   30:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:74
[INFO] [stdout]   31:     0x590eb17dd3ba - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   32:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   33:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panicking::catch_unwind::<core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>, core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   34:     0x590eb17dd3ba - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<test[30224e0cb089acd2]::run_test_in_process::{closure#0}>, core[585f66e14d78f9ba]::result::Result<(), alloc[15e7b27aba85d2e2]::string::String>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   35:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test_in_process
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:686:27
[INFO] [stdout]   36:     0x590eb17dd3ba - test[30224e0cb089acd2]::run_test::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:607:43
[INFO] [stdout]   37:     0x590eb17d7884 - test[30224e0cb089acd2]::run_test::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/test/src/lib.rs:637:41
[INFO] [stdout]   38:     0x590eb17d7884 - std[3f03f8b59f91bef1]::sys::backtrace::__rust_begin_short_backtrace::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/backtrace.rs:166:18
[INFO] [stdout]   39:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:91:13
[INFO] [stdout]   40:     0x590eb17dfeb2 - <core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/panic/unwind_safe.rs:274:9
[INFO] [stdout]   41:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::do_call::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:581:40
[INFO] [stdout]   42:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panicking::catch_unwind::<(), core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panicking.rs:544:19
[INFO] [stdout]   43:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::panic::catch_unwind::<core[585f66e14d78f9ba]::panic::unwind_safe::AssertUnwindSafe<std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}::{closure#0}>, ()>
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/panic.rs:359:14
[INFO] [stdout]   44:     0x590eb17dfeb2 - std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked::<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/thread/lifecycle.rs:89:26
[INFO] [stdout]   45:     0x590eb17dfeb2 - <std[3f03f8b59f91bef1]::thread::lifecycle::spawn_unchecked<test[30224e0cb089acd2]::run_test::{closure#1}, ()>::{closure#1} as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once::{shim:vtable#0}
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   46:     0x590eb1ce7a1f - <alloc[15e7b27aba85d2e2]::boxed::Box<dyn core[585f66e14d78f9ba]::ops::function::FnOnce<(), Output = ()> + core[585f66e14d78f9ba]::marker::Send> as core[585f66e14d78f9ba]::ops::function::FnOnce<()>>::call_once
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/alloc/src/boxed.rs:2206:9
[INFO] [stdout]   47:     0x590eb1ce7a1f - <std[3f03f8b59f91bef1]::sys::thread::unix::Thread>::new::thread_start
[INFO] [stdout]                                at /rustc/db823df02fd0c2cf67b43025ac3fef3f2d743245/library/std/src/sys/thread/unix.rs:119:17
[INFO] [stdout]   48:     0x7436ff8d3aa4 - <unknown>
[INFO] [stdout]   49:     0x7436ff960a64 - clone
[INFO] [stdout]   50:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     front_matter::defaults::tests::test_apply_default_if_matches
[INFO] [stdout]     markdown::renderer::markdown_renderer::tests::test_syntax_highlighting
[INFO] [stdout]     markdown::renderer::markdown_renderer::tests::test_table_of_contents
[INFO] [stdout]     markdown::toc::parser::tests::test_build_toc_hierarchy
[INFO] [stdout]     markdown::toc::parser::tests::test_extract_headings
[INFO] [stdout]     markdown::toc::parser::tests::test_toc_with_levels
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 28 passed; 6 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.47s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "8b5fa220c23a404fd8626673ba750ab7818accc68e07dc3a03eb0258690255d1", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8b5fa220c23a404fd8626673ba750ab7818accc68e07dc3a03eb0258690255d1", kill_on_drop: false }`
[INFO] [stdout] 8b5fa220c23a404fd8626673ba750ab7818accc68e07dc3a03eb0258690255d1
