[INFO] fetching crate dbase_parser 0.1.0...
[INFO] testing dbase_parser-0.1.0 against try#c2e32f1c9652b13ed99608599c1e855462f421f3 for pr-146098-7
[INFO] extracting crate dbase_parser 0.1.0 into /workspace/builds/worker-0-tc2/source
[INFO] started tweaking crates.io crate dbase_parser 0.1.0
[INFO] finished tweaking crates.io crate dbase_parser 0.1.0
[INFO] tweaked toml for crates.io crate dbase_parser 0.1.0 written to /workspace/builds/worker-0-tc2/source/Cargo.toml
[INFO] validating manifest of crates.io crate dbase_parser 0.1.0 on toolchain c2e32f1c9652b13ed99608599c1e855462f421f3
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]      Locking 32 packages to latest compatible versions
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] b9956ae9ff8bda09ec565b87a1f6b7231f0d2492a68a8dd71fc3b835893f57ae
[INFO] running `Command { std: "docker" "start" "-a" "b9956ae9ff8bda09ec565b87a1f6b7231f0d2492a68a8dd71fc3b835893f57ae", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "b9956ae9ff8bda09ec565b87a1f6b7231f0d2492a68a8dd71fc3b835893f57ae", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b9956ae9ff8bda09ec565b87a1f6b7231f0d2492a68a8dd71fc3b835893f57ae", kill_on_drop: false }`
[INFO] [stdout] b9956ae9ff8bda09ec565b87a1f6b7231f0d2492a68a8dd71fc3b835893f57ae
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b86aff9200d90467541487656ddd98ff5eca0cc614be4d1bec5a0f4fef3259af
[INFO] running `Command { std: "docker" "start" "-a" "b86aff9200d90467541487656ddd98ff5eca0cc614be4d1bec5a0f4fef3259af", kill_on_drop: false }`
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling dbase_parser v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: variant `dBASE3` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     dBASE3(bool),
[INFO] [stdout]    |     ^^^^^^ help: convert the identifier to upper camel case: `DBase3`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4Table` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     dBASE4Table(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4System` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     dBASE4System(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4system`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/header.rs:1:14
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Date, Utc, TimeZone};
[INFO] [stdout]   |              ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:59:22
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub last_update: Date<Utc>,
[INFO] [stdout]    |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:73:40
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn parse_date(data: Vec<u8>) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/fields.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Utc, Date, DateTime, TimeZone};
[INFO] [stdout]   |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Date(Date<Utc>),
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:93:41
[INFO] [stdout]    |
[INFO] [stdout] 93 | fn to_julian_date(input: u32) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/header.rs:79:20
[INFO] [stdout]    |
[INFO] [stdout] 79 |             Ok(Utc.ymd(year, month.into(), day.into()))
[INFO] [stdout]    |                    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/header.rs:389:34
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<MemoContainer>> = {
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<dyn MemoContainer>> = {
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/header.rs:436:41
[INFO] [stdout]     |
[INFO] [stdout] 436 |                 last_update: Utc::now().date(),
[INFO] [stdout]     |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/fields.rs:51:41
[INFO] [stdout]    |
[INFO] [stdout] 51 |                 Ok(FieldValue::Date(Utc.ymd(year, month, day)))
[INFO] [stdout]    |                                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout] 105 |     Ok(Utc.ymd(j as i32, m as u32, d as u32))
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/fields.rs:126:38
[INFO] [stdout]     |
[INFO] [stdout] 126 |         Ok(FieldValue::DateTime(date.and_hms(hours as u32, minutes as u32, seconds as u32)))
[INFO] [stdout]     |                                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_available`
[INFO] [stdout]    --> src/header.rs:101:13
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let next_available = {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_available`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_type`
[INFO] [stdout]    --> src/header.rs:133:13
[INFO] [stdout]     |
[INFO] [stdout] 133 |         let data_type = {
[INFO] [stdout]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MemoContainer` is more private than the item `Database::memo`
[INFO] [stdout]   --> src/header.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub memo: Option<Box<dyn MemoContainer>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `Database::memo` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `MemoContainer` is only usable at visibility `pub(self)`
[INFO] [stdout]   --> src/header.rs:85:1
[INFO] [stdout]    |
[INFO] [stdout] 85 | trait MemoContainer:Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `data_address` and `decimal_count` are never read
[INFO] [stdout]   --> src/header.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FieldDescriptor {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 51 |     data_address: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 52 |     length: u8,
[INFO] [stdout] 53 |     decimal_count: u8
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FieldDescriptor` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `header_size` and `record_size` are never read
[INFO] [stdout]   --> src/header.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct Header {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 61 |     header_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 62 |     record_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Header` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]   --> src/header.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct Database {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 67 |     path: PathBuf,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `block_size` is never read
[INFO] [stdout]   --> src/header.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 90 | pub struct FoxProMemoContainer {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 93 |     block_size: u32
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FoxProMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `next_available` is never read
[INFO] [stdout]    --> src/header.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 155 | pub struct DBaseMemoContainer {
[INFO] [stdout]     |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 158 |     next_available: usize
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DBaseMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1.81s
[INFO] running `Command { std: "docker" "inspect" "b86aff9200d90467541487656ddd98ff5eca0cc614be4d1bec5a0f4fef3259af", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b86aff9200d90467541487656ddd98ff5eca0cc614be4d1bec5a0f4fef3259af", kill_on_drop: false }`
[INFO] [stdout] b86aff9200d90467541487656ddd98ff5eca0cc614be4d1bec5a0f4fef3259af
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2acbf4788e31ce7189935d886a1edd339f819a21827d2551af05164d4190a6a0
[INFO] running `Command { std: "docker" "start" "-a" "2acbf4788e31ce7189935d886a1edd339f819a21827d2551af05164d4190a6a0", kill_on_drop: false }`
[INFO] [stdout] warning: variant `dBASE3` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     dBASE3(bool),
[INFO] [stdout]    |     ^^^^^^ help: convert the identifier to upper camel case: `DBase3`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4Table` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     dBASE4Table(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4System` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     dBASE4System(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4system`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/header.rs:1:14
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Date, Utc, TimeZone};
[INFO] [stdout]   |              ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:59:22
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub last_update: Date<Utc>,
[INFO] [stdout]    |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:73:40
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn parse_date(data: Vec<u8>) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/fields.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Utc, Date, DateTime, TimeZone};
[INFO] [stdout]   |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Date(Date<Utc>),
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling dbase_parser v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:93:41
[INFO] [stdout]    |
[INFO] [stdout] 93 | fn to_julian_date(input: u32) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/header.rs:79:20
[INFO] [stdout]    |
[INFO] [stdout] 79 |             Ok(Utc.ymd(year, month.into(), day.into()))
[INFO] [stdout]    |                    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/header.rs:389:34
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<MemoContainer>> = {
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<dyn MemoContainer>> = {
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/header.rs:436:41
[INFO] [stdout]     |
[INFO] [stdout] 436 |                 last_update: Utc::now().date(),
[INFO] [stdout]     |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/fields.rs:51:41
[INFO] [stdout]    |
[INFO] [stdout] 51 |                 Ok(FieldValue::Date(Utc.ymd(year, month, day)))
[INFO] [stdout]    |                                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout] 105 |     Ok(Utc.ymd(j as i32, m as u32, d as u32))
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/fields.rs:126:38
[INFO] [stdout]     |
[INFO] [stdout] 126 |         Ok(FieldValue::DateTime(date.and_hms(hours as u32, minutes as u32, seconds as u32)))
[INFO] [stdout]     |                                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_available`
[INFO] [stdout]    --> src/header.rs:101:13
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let next_available = {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_available`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_type`
[INFO] [stdout]    --> src/header.rs:133:13
[INFO] [stdout]     |
[INFO] [stdout] 133 |         let data_type = {
[INFO] [stdout]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MemoContainer` is more private than the item `Database::memo`
[INFO] [stdout]   --> src/header.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub memo: Option<Box<dyn MemoContainer>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `Database::memo` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `MemoContainer` is only usable at visibility `pub(self)`
[INFO] [stdout]   --> src/header.rs:85:1
[INFO] [stdout]    |
[INFO] [stdout] 85 | trait MemoContainer:Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `data_address` and `decimal_count` are never read
[INFO] [stdout]   --> src/header.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FieldDescriptor {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 51 |     data_address: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 52 |     length: u8,
[INFO] [stdout] 53 |     decimal_count: u8
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FieldDescriptor` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `header_size` and `record_size` are never read
[INFO] [stdout]   --> src/header.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct Header {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 61 |     header_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 62 |     record_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Header` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]   --> src/header.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct Database {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 67 |     path: PathBuf,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `block_size` is never read
[INFO] [stdout]   --> src/header.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 90 | pub struct FoxProMemoContainer {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 93 |     block_size: u32
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FoxProMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `next_available` is never read
[INFO] [stdout]    --> src/header.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 155 | pub struct DBaseMemoContainer {
[INFO] [stdout]     |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 158 |     next_available: usize
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DBaseMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dbase_parser::header::Record`
[INFO] [stdout]  --> tests/dbase.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 |     use dbase_parser::header::Record;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE3` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     dBASE3(bool),
[INFO] [stdout]    |     ^^^^^^ help: convert the identifier to upper camel case: `DBase3`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4Table` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 |     dBASE4Table(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4table`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `dBASE4System` should have an upper camel case name
[INFO] [stdout]   --> src/header.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |     dBASE4System(bool),
[INFO] [stdout]    |     ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4system`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> tests/dbase.rs:17:85
[INFO] [stdout]    |
[INFO] [stdout] 17 |             assert_eq!(record.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 6, 0)));
[INFO] [stdout]    |                                                                                     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]   --> tests/dbase.rs:17:103
[INFO] [stdout]    |
[INFO] [stdout] 17 |             assert_eq!(record.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 6, 0)));
[INFO] [stdout]    |                                                                                                       ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> tests/dbase.rs:18:75
[INFO] [stdout]    |
[INFO] [stdout] 18 |             assert_eq!(record.get("join").unwrap(), &FieldValue::Date(Utc.ymd(1999, 09, 03)));
[INFO] [stdout]    |                                                                           ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> tests/dbase.rs:25:86
[INFO] [stdout]    |
[INFO] [stdout] 25 |             assert_eq!(record2.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 40, 0)));
[INFO] [stdout]    |                                                                                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]   --> tests/dbase.rs:25:104
[INFO] [stdout]    |
[INFO] [stdout] 25 |             assert_eq!(record2.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 40, 0)));
[INFO] [stdout]    |                                                                                                        ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> tests/dbase.rs:26:76
[INFO] [stdout]    |
[INFO] [stdout] 26 |             assert_eq!(record2.get("join").unwrap(), &FieldValue::Date(Utc.ymd(2019, 09, 04)));
[INFO] [stdout]    |                                                                            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/header.rs:1:14
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Date, Utc, TimeZone};
[INFO] [stdout]   |              ^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:59:22
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub last_update: Date<Utc>,
[INFO] [stdout]    |                      ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/header.rs:73:40
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn parse_date(data: Vec<u8>) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]  --> src/fields.rs:1:19
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{Utc, Date, DateTime, TimeZone};
[INFO] [stdout]   |                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:17:10
[INFO] [stdout]    |
[INFO] [stdout] 17 |     Date(Date<Utc>),
[INFO] [stdout]    |          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stdout]   --> src/fields.rs:93:41
[INFO] [stdout]    |
[INFO] [stdout] 93 | fn to_julian_date(input: u32) -> Result<Date<Utc>, io::Error> {
[INFO] [stdout]    |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/header.rs:79:20
[INFO] [stdout]    |
[INFO] [stdout] 79 |             Ok(Utc.ymd(year, month.into(), day.into()))
[INFO] [stdout]    |                    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stdout]    --> src/header.rs:389:34
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<MemoContainer>> = {
[INFO] [stdout]     |                                  ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stdout]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stdout] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stdout]     |
[INFO] [stdout] 389 |         let memo_file:Option<Box<dyn MemoContainer>> = {
[INFO] [stdout]     |                                  +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stdout]    --> src/header.rs:436:41
[INFO] [stdout]     |
[INFO] [stdout] 436 |                 last_update: Utc::now().date(),
[INFO] [stdout]     |                                         ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]   --> src/fields.rs:51:41
[INFO] [stdout]    |
[INFO] [stdout] 51 |                 Ok(FieldValue::Date(Utc.ymd(year, month, day)))
[INFO] [stdout]    |                                         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:105:12
[INFO] [stdout]     |
[INFO] [stdout] 105 |     Ok(Utc.ymd(j as i32, m as u32, d as u32))
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/fields.rs:126:38
[INFO] [stdout]     |
[INFO] [stdout] 126 |         Ok(FieldValue::DateTime(date.and_hms(hours as u32, minutes as u32, seconds as u32)))
[INFO] [stdout]     |                                      ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:159:70
[INFO] [stdout]     |
[INFO] [stdout] 159 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::Date(Utc.ymd(2019, 09, 01)));
[INFO] [stdout]     |                                                                      ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:166:26
[INFO] [stdout]     |
[INFO] [stdout] 166 |     assert_eq!(date, Utc.ymd(2019,09,03));
[INFO] [stdout]     |                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stdout]    --> src/fields.rs:172:74
[INFO] [stdout]     |
[INFO] [stdout] 172 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::DateTime(Utc.ymd(2019, 03, 09).and_hms(01, 0, 0))); 
[INFO] [stdout]     |                                                                          ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stdout]    --> src/fields.rs:172:92
[INFO] [stdout]     |
[INFO] [stdout] 172 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::DateTime(Utc.ymd(2019, 03, 09).and_hms(01, 0, 0))); 
[INFO] [stdout]     |                                                                                            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_available`
[INFO] [stdout]    --> src/header.rs:101:13
[INFO] [stdout]     |
[INFO] [stdout] 101 |         let next_available = {
[INFO] [stdout]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_available`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data_type`
[INFO] [stdout]    --> src/header.rs:133:13
[INFO] [stdout]     |
[INFO] [stdout] 133 |         let data_type = {
[INFO] [stdout]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_type`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/fields.rs:158:9
[INFO] [stdout]     |
[INFO] [stdout] 158 |     let mut o = FieldTypeD;
[INFO] [stdout]     |         ----^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `MemoContainer` is more private than the item `Database::memo`
[INFO] [stdout]   --> src/header.rs:69:5
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub memo: Option<Box<dyn MemoContainer>>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `Database::memo` is reachable at visibility `pub`
[INFO] [stdout]    |
[INFO] [stdout] note: but trait `MemoContainer` is only usable at visibility `pub(self)`
[INFO] [stdout]   --> src/header.rs:85:1
[INFO] [stdout]    |
[INFO] [stdout] 85 | trait MemoContainer:Debug {
[INFO] [stdout]    | ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `data_address` and `decimal_count` are never read
[INFO] [stdout]   --> src/header.rs:51:5
[INFO] [stdout]    |
[INFO] [stdout] 48 | pub struct FieldDescriptor {
[INFO] [stdout]    |            --------------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 51 |     data_address: u32,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 52 |     length: u8,
[INFO] [stdout] 53 |     decimal_count: u8
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FieldDescriptor` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `header_size` and `record_size` are never read
[INFO] [stdout]   --> src/header.rs:61:5
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct Header {
[INFO] [stdout]    |            ------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 61 |     header_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 62 |     record_size: u16,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Header` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `path` is never read
[INFO] [stdout]   --> src/header.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct Database {
[INFO] [stdout]    |            -------- field in this struct
[INFO] [stdout] 67 |     path: PathBuf,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `block_size` is never read
[INFO] [stdout]   --> src/header.rs:93:5
[INFO] [stdout]    |
[INFO] [stdout] 90 | pub struct FoxProMemoContainer {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 93 |     block_size: u32
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `FoxProMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `next_available` is never read
[INFO] [stdout]    --> src/header.rs:158:5
[INFO] [stdout]     |
[INFO] [stdout] 155 | pub struct DBaseMemoContainer {
[INFO] [stdout]     |            ------------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 158 |     next_available: usize
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `DBaseMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.57s
[INFO] running `Command { std: "docker" "inspect" "2acbf4788e31ce7189935d886a1edd339f819a21827d2551af05164d4190a6a0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2acbf4788e31ce7189935d886a1edd339f819a21827d2551af05164d4190a6a0", kill_on_drop: false }`
[INFO] [stdout] 2acbf4788e31ce7189935d886a1edd339f819a21827d2551af05164d4190a6a0
[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:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+c2e32f1c9652b13ed99608599c1e855462f421f3" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 65f940d58dd741e12365f7056f3dcd42dc266026041f87ac06b8168481d937cc
[INFO] running `Command { std: "docker" "start" "-a" "65f940d58dd741e12365f7056f3dcd42dc266026041f87ac06b8168481d937cc", kill_on_drop: false }`
[INFO] [stderr] warning: variant `dBASE3` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     dBASE3(bool),
[INFO] [stderr]    |     ^^^^^^ help: convert the identifier to upper camel case: `DBase3`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant `dBASE4Table` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     dBASE4Table(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4table`
[INFO] [stderr] 
[INFO] [stderr] warning: variant `dBASE4System` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     dBASE4System(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4system`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]  --> src/header.rs:1:14
[INFO] [stderr]   |
[INFO] [stderr] 1 | use chrono::{Date, Utc, TimeZone};
[INFO] [stderr]   |              ^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]   --> src/header.rs:59:22
[INFO] [stderr]    |
[INFO] [stderr] 59 |     pub last_update: Date<Utc>,
[INFO] [stderr]    |                      ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]   --> src/header.rs:73:40
[INFO] [stderr]    |
[INFO] [stderr] 73 | fn parse_date(data: Vec<u8>) -> Result<Date<Utc>, io::Error> {
[INFO] [stderr]    |                                        ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]  --> src/fields.rs:1:19
[INFO] [stderr]   |
[INFO] [stderr] 1 | use chrono::{Utc, Date, DateTime, TimeZone};
[INFO] [stderr]   |                   ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]   --> src/fields.rs:17:10
[INFO] [stderr]    |
[INFO] [stderr] 17 |     Date(Date<Utc>),
[INFO] [stderr]    |          ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated struct `chrono::Date`: Use `NaiveDate` or `DateTime<Tz>` instead
[INFO] [stderr]   --> src/fields.rs:93:41
[INFO] [stderr]    |
[INFO] [stderr] 93 | fn to_julian_date(input: u32) -> Result<Date<Utc>, io::Error> {
[INFO] [stderr]    |                                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> src/header.rs:79:20
[INFO] [stderr]    |
[INFO] [stderr] 79 |             Ok(Utc.ymd(year, month.into(), day.into()))
[INFO] [stderr]    |                    ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/header.rs:389:34
[INFO] [stderr]     |
[INFO] [stderr] 389 |         let memo_file:Option<Box<MemoContainer>> = {
[INFO] [stderr]     |                                  ^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this is accepted in the current edition (Rust 2018) but is a hard error in Rust 2021!
[INFO] [stderr]     = note: for more information, see <https://doc.rust-lang.org/edition-guide/rust-2021/warnings-promoted-to-error.html>
[INFO] [stderr]     = note: `#[warn(bare_trait_objects)]` (part of `#[warn(rust_2021_compatibility)]`) on by default
[INFO] [stderr] help: if this is a dyn-compatible trait, use `dyn`
[INFO] [stderr]     |
[INFO] [stderr] 389 |         let memo_file:Option<Box<dyn MemoContainer>> = {
[INFO] [stderr]     |                                  +++
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::DateTime::<Tz>::date`: Use `date_naive()` instead
[INFO] [stderr]    --> src/header.rs:436:41
[INFO] [stderr]     |
[INFO] [stderr] 436 |                 last_update: Utc::now().date(),
[INFO] [stderr]     |                                         ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> src/fields.rs:51:41
[INFO] [stderr]    |
[INFO] [stderr] 51 |                 Ok(FieldValue::Date(Utc.ymd(year, month, day)))
[INFO] [stderr]    |                                         ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]    --> src/fields.rs:105:12
[INFO] [stderr]     |
[INFO] [stderr] 105 |     Ok(Utc.ymd(j as i32, m as u32, d as u32))
[INFO] [stderr]     |            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stderr]    --> src/fields.rs:126:38
[INFO] [stderr]     |
[INFO] [stderr] 126 |         Ok(FieldValue::DateTime(date.and_hms(hours as u32, minutes as u32, seconds as u32)))
[INFO] [stderr]     |                                      ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `next_available`
[INFO] [stderr]    --> src/header.rs:101:13
[INFO] [stderr]     |
[INFO] [stderr] 101 |         let next_available = {
[INFO] [stderr]     |             ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_available`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `data_type`
[INFO] [stderr]    --> src/header.rs:133:13
[INFO] [stderr]     |
[INFO] [stderr] 133 |         let data_type = {
[INFO] [stderr]     |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_data_type`
[INFO] [stderr] 
[INFO] [stderr] warning: trait `MemoContainer` is more private than the item `Database::memo`
[INFO] [stderr]   --> src/header.rs:69:5
[INFO] [stderr]    |
[INFO] [stderr] 69 |     pub memo: Option<Box<dyn MemoContainer>>,
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ field `Database::memo` is reachable at visibility `pub`
[INFO] [stderr]    |
[INFO] [stderr] note: but trait `MemoContainer` is only usable at visibility `pub(self)`
[INFO] [stderr]   --> src/header.rs:85:1
[INFO] [stderr]    |
[INFO] [stderr] 85 | trait MemoContainer:Debug {
[INFO] [stderr]    | ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    = note: `#[warn(private_interfaces)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `data_address` and `decimal_count` are never read
[INFO] [stderr]   --> src/header.rs:51:5
[INFO] [stderr]    |
[INFO] [stderr] 48 | pub struct FieldDescriptor {
[INFO] [stderr]    |            --------------- fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 51 |     data_address: u32,
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 52 |     length: u8,
[INFO] [stderr] 53 |     decimal_count: u8
[INFO] [stderr]    |     ^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FieldDescriptor` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: fields `header_size` and `record_size` are never read
[INFO] [stderr]   --> src/header.rs:61:5
[INFO] [stderr]    |
[INFO] [stderr] 57 | pub struct Header {
[INFO] [stderr]    |            ------ fields in this struct
[INFO] [stderr] ...
[INFO] [stderr] 61 |     header_size: u16,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr] 62 |     record_size: u16,
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `Header` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `path` is never read
[INFO] [stderr]   --> src/header.rs:67:5
[INFO] [stderr]    |
[INFO] [stderr] 66 | pub struct Database {
[INFO] [stderr]    |            -------- field in this struct
[INFO] [stderr] 67 |     path: PathBuf,
[INFO] [stderr]    |     ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: field `block_size` is never read
[INFO] [stderr]   --> src/header.rs:93:5
[INFO] [stderr]    |
[INFO] [stderr] 90 | pub struct FoxProMemoContainer {
[INFO] [stderr]    |            ------------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 93 |     block_size: u32
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `FoxProMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: field `next_available` is never read
[INFO] [stderr]    --> src/header.rs:158:5
[INFO] [stderr]     |
[INFO] [stderr] 155 | pub struct DBaseMemoContainer {
[INFO] [stderr]     |            ------------------ field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 158 |     next_available: usize
[INFO] [stderr]     |     ^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `DBaseMemoContainer` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]    --> src/fields.rs:159:70
[INFO] [stderr]     |
[INFO] [stderr] 159 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::Date(Utc.ymd(2019, 09, 01)));
[INFO] [stderr]     |                                                                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]    --> src/fields.rs:166:26
[INFO] [stderr]     |
[INFO] [stderr] 166 |     assert_eq!(date, Utc.ymd(2019,09,03));
[INFO] [stderr]     |                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]    --> src/fields.rs:172:74
[INFO] [stderr]     |
[INFO] [stderr] 172 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::DateTime(Utc.ymd(2019, 03, 09).and_hms(01, 0, 0))); 
[INFO] [stderr]     |                                                                          ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stderr]    --> src/fields.rs:172:92
[INFO] [stderr]     |
[INFO] [stderr] 172 |     assert_eq!(o.parse(&mut db, data).unwrap(), FieldValue::DateTime(Utc.ymd(2019, 03, 09).and_hms(01, 0, 0))); 
[INFO] [stderr]     |                                                                                            ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/fields.rs:158:9
[INFO] [stderr]     |
[INFO] [stderr] 158 |     let mut o = FieldTypeD;
[INFO] [stderr]     |         ----^
[INFO] [stderr]     |         |
[INFO] [stderr]     |         help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `dbase_parser` (lib) generated 23 warnings (run `cargo fix --lib -p dbase_parser` to apply 3 suggestions)
[INFO] [stderr] warning: `dbase_parser` (lib test) generated 28 warnings (23 duplicates) (run `cargo fix --lib -p dbase_parser --tests` to apply 1 suggestion)
[INFO] [stderr] warning: unused import: `dbase_parser::header::Record`
[INFO] [stderr]  --> tests/dbase.rs:7:9
[INFO] [stderr]   |
[INFO] [stderr] 7 |     use dbase_parser::header::Record;
[INFO] [stderr]   |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> tests/dbase.rs:17:85
[INFO] [stderr]    |
[INFO] [stderr] 17 |             assert_eq!(record.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 6, 0)));
[INFO] [stderr]    |                                                                                     ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stderr]   --> tests/dbase.rs:17:103
[INFO] [stderr]    |
[INFO] [stderr] 17 |             assert_eq!(record.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 6, 0)));
[INFO] [stderr]    |                                                                                                       ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> tests/dbase.rs:18:75
[INFO] [stderr]    |
[INFO] [stderr] 18 |             assert_eq!(record.get("join").unwrap(), &FieldValue::Date(Utc.ymd(1999, 09, 03)));
[INFO] [stderr]    |                                                                           ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> tests/dbase.rs:25:86
[INFO] [stderr]    |
[INFO] [stderr] 25 |             assert_eq!(record2.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 40, 0)));
[INFO] [stderr]    |                                                                                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::Date::<Tz>::and_hms`: Use and_hms_opt() instead
[INFO] [stderr]   --> tests/dbase.rs:25:104
[INFO] [stderr]    |
[INFO] [stderr] 25 |             assert_eq!(record2.get("created_at").unwrap(), &FieldValue::DateTime(Utc.ymd(2019, 09, 04).and_hms(11, 40, 0)));
[INFO] [stderr]    |                                                                                                        ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `chrono::TimeZone::ymd`: use `with_ymd_and_hms()` instead
[INFO] [stderr]   --> tests/dbase.rs:26:76
[INFO] [stderr]    |
[INFO] [stderr] 26 |             assert_eq!(record2.get("join").unwrap(), &FieldValue::Date(Utc.ymd(2019, 09, 04)));
[INFO] [stderr]    |                                                                            ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `dbase_parser` (test "dbase") generated 7 warnings (run `cargo fix --test "dbase" -p dbase_parser` to apply 1 suggestion)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.07s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/dbase_parser-0591109f4741d8cd)
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test fields::datetime_works ... ok
[INFO] [stderr]      Running tests/dbase.rs (/opt/rustwide/target/debug/deps/dbase-38fd805b3d1ec23c)
[INFO] [stdout] test fields::date_works ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 2 tests
[INFO] [stdout] test tests::parse_file_fpt ... ok
[INFO] [stdout] test tests::parse_file_dpt ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests dbase_parser
[INFO] [stderr] warning: variant `dBASE3` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 |     dBASE3(bool),
[INFO] [stderr]    |     ^^^^^^ help: convert the identifier to upper camel case: `DBase3`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant `dBASE4Table` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 |     dBASE4Table(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4table`
[INFO] [stderr] 
[INFO] [stderr] warning: variant `dBASE4System` should have an upper camel case name
[INFO] [stderr]   --> src/header.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 |     dBASE4System(bool),
[INFO] [stderr]    |     ^^^^^^^^^^^^ help: convert the identifier to upper camel case: `DBase4system`
[INFO] [stderr] 
[INFO] [stderr] warning: 3 warnings emitted
[INFO] [stderr] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "65f940d58dd741e12365f7056f3dcd42dc266026041f87ac06b8168481d937cc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "65f940d58dd741e12365f7056f3dcd42dc266026041f87ac06b8168481d937cc", kill_on_drop: false }`
[INFO] [stdout] 65f940d58dd741e12365f7056f3dcd42dc266026041f87ac06b8168481d937cc
