[INFO] updating cached repository https://github.com/cuviper/rust-git-fs
[INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"`
[INFO] running `"git" "rev-parse" "HEAD"`
[INFO] [stdout] 2b78e986e6ffffff1bdea4f3e784aee398a0bf3e
[INFO] checking cuviper/rust-git-fs against master#209b2be09fcaff937480d1fbbe8b31646e361c7a for pr-70917
[INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fcuviper%2Frust-git-fs" "/workspace/builds/worker-6/source"`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/cuviper/rust-git-fs on toolchain 209b2be09fcaff937480d1fbbe8b31646e361c7a
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking git repo https://github.com/cuviper/rust-git-fs
[INFO] finished tweaking git repo https://github.com/cuviper/rust-git-fs
[INFO] tweaked toml for git repo https://github.com/cuviper/rust-git-fs written to /workspace/builds/worker-6/source/Cargo.toml
[INFO] crate git repo https://github.com/cuviper/rust-git-fs already has a lockfile, it will not be regenerated
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr] error: the lock file /workspace/builds/worker-6/source/Cargo.lock needs to be updated but --locked was passed to prevent this
[INFO] [stderr] If you want to try to generate the lock file without accessing the network, use the --offline flag.
[INFO] the lockfile is outdated, regenerating it
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"/workspace/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/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" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+209b2be09fcaff937480d1fbbe8b31646e361c7a" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] ddf5379ae73a2676c747558f7600681b3d8504303543872cd7c2922f9c9dd5d8
[INFO] running `"docker" "start" "-a" "ddf5379ae73a2676c747558f7600681b3d8504303543872cd7c2922f9c9dd5d8"`
[INFO] [stderr]    Compiling fuse v0.3.1
[INFO] [stderr]    Compiling jobserver v0.1.21
[INFO] [stderr]     Checking log v0.3.9
[INFO] [stderr]     Checking time v0.2.9
[INFO] [stderr]    Compiling cc v1.0.50
[INFO] [stderr]    Compiling libz-sys v1.0.25
[INFO] [stderr]    Compiling openssl-sys v0.9.55
[INFO] [stderr]    Compiling libssh2-sys v0.2.16
[INFO] [stderr]    Compiling libgit2-sys v0.12.3+1.0.0
[INFO] [stderr]     Checking git2 v0.13.2
[INFO] [stderr]     Checking git-fs v0.0.1-pre (/opt/rustwide/workdir)
[INFO] [stderr] error[E0412]: cannot find type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:44:18
[INFO] [stderr]    |
[INFO] [stderr] 44 | const TTY: time::Timespec = time::Timespec { sec: 1, nsec: 0 };
[INFO] [stderr]    |                  ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:44:35
[INFO] [stderr]    |
[INFO] [stderr] 44 | const TTY: time::Timespec = time::Timespec { sec: 1, nsec: 0 };
[INFO] [stderr]    |                                   ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:61:18
[INFO] [stderr]    |
[INFO] [stderr] 61 |     epoch: time::Timespec,
[INFO] [stderr]    |                  ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `get_time` in crate `time`
[INFO] [stderr]   --> src/lib.rs:74:26
[INFO] [stderr]    |
[INFO] [stderr] 74 |             epoch: time::get_time(),
[INFO] [stderr]    |                          ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/lib.rs:73:19
[INFO] [stderr]    |
[INFO] [stderr] 73 |             repo: try!(git2::Repository::open(git_dir.as_ref())),
[INFO] [stderr]    |                   ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/inode.rs:65:26
[INFO] [stderr]    |
[INFO] [stderr] 65 |                _add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:118:40
[INFO] [stderr]     |
[INFO] [stderr] 118 |     inodes: hash_map::HashMap<u64, Box<Inode+'static>>,
[INFO] [stderr]     |                                        ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:122:51
[INFO] [stderr]     |
[INFO] [stderr] 122 |     pub fn insert(&mut self, ino: u64, inode: Box<Inode+'static>) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:122:81
[INFO] [stderr]     |
[INFO] [stderr] 122 |     pub fn insert(&mut self, ino: u64, inode: Box<Inode+'static>) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                                                 ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:126:61
[INFO] [stderr]     |
[INFO] [stderr] 126 |     pub fn find_mut(&mut self, ino: u64) -> Result<&mut Box<Inode+'static>, libc::c_int> {
[INFO] [stderr]     |                                                             ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:131:33
[INFO] [stderr]     |
[INFO] [stderr] 131 |     -> hash_map::Entry<u64, Box<Inode+'static>> {
[INFO] [stderr]     |                                 ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:139:73
[INFO] [stderr]     |
[INFO] [stderr] 139 | pub fn new_inode(repo: &git2::Repository, oid: git2::Oid) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                                         ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/blob.rs:24:41
[INFO] [stderr]    |
[INFO] [stderr] 24 |     pub fn new(blob: git2::Blob) -> Box<inode::Inode+'static> {
[INFO] [stderr]    |                                         ^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn inode::Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/tree.rs:27:41
[INFO] [stderr]    |
[INFO] [stderr] 27 |     pub fn new(tree: git2::Tree) -> Box<Inode+'static> {
[INFO] [stderr]    |                                         ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/tree.rs:62:29
[INFO] [stderr]    |
[INFO] [stderr] 62 |                mut add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/reference.rs:26:25
[INFO] [stderr]    |
[INFO] [stderr] 26 |     pub fn new() -> Box<inode::Inode+'static> {
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn inode::Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/reference.rs:52:29
[INFO] [stderr]    |
[INFO] [stderr] 52 |                mut add: Box<FnMut(inode::Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(inode::Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/root.rs:24:43
[INFO] [stderr]    |
[INFO] [stderr] 24 |     pub fn new(head: Id, refs: Id) -> Box<Inode+'static> {
[INFO] [stderr]    |                                           ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/root.rs:59:29
[INFO] [stderr]    |
[INFO] [stderr] 59 |                mut add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `lookup` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:150:5
[INFO] [stderr]     |
[INFO] [stderr] 150 |     fn lookup(&mut self, _req: &fuse::Request, parent: u64, name: &Path, reply: fuse::ReplyEntry) {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `std::ffi::OsStr`, found struct `std::path::Path`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, &std::ffi::OsStr, fuse::ReplyEntry)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, &std::path::Path, fuse::ReplyEntry)`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `read` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:210:5
[INFO] [stderr]     |
[INFO] [stderr] 210 | /     fn read (&mut self, _req: &fuse::Request, ino: u64, _fh: u64, offset: u64, size: u32,
[INFO] [stderr] 211 | |              reply: fuse::ReplyData) {
[INFO] [stderr] 212 | |         probe!(gitfs, read, ino, offset, size);
[INFO] [stderr] 213 | |
[INFO] [stderr] ...   |
[INFO] [stderr] 219 | |         }
[INFO] [stderr] 220 | |     }
[INFO] [stderr]     | |_____^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, i64, _, fuse::ReplyData)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, u64, _, fuse::ReplyData)`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `readdir` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:234:5
[INFO] [stderr]     |
[INFO] [stderr] 234 | /     fn readdir (&mut self, _req: &fuse::Request, ino: u64, _fh: u64, mut offset: u64,
[INFO] [stderr] 235 | |                 mut reply: fuse::ReplyDirectory) {
[INFO] [stderr] 236 | |         probe!(gitfs, readdir, ino, offset);
[INFO] [stderr] 237 | |
[INFO] [stderr] ...   |
[INFO] [stderr] 257 | |         }
[INFO] [stderr] 258 | |     }
[INFO] [stderr]     | |_____^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, i64, fuse::ReplyDirectory)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, u64, fuse::ReplyDirectory)`
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:44:18
[INFO] [stderr]    |
[INFO] [stderr] 44 | const TTY: time::Timespec = time::Timespec { sec: 1, nsec: 0 };
[INFO] [stderr]    |                  ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0422]: cannot find struct, variant or union type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:44:35
[INFO] [stderr]    |
[INFO] [stderr] 44 | const TTY: time::Timespec = time::Timespec { sec: 1, nsec: 0 };
[INFO] [stderr]    |                                   ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0412]: cannot find type `Timespec` in crate `time`
[INFO] [stderr]   --> src/lib.rs:61:18
[INFO] [stderr]    |
[INFO] [stderr] 61 |     epoch: time::Timespec,
[INFO] [stderr]    |                  ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `get_time` in crate `time`
[INFO] [stderr]   --> src/lib.rs:74:26
[INFO] [stderr]    |
[INFO] [stderr] 74 |             epoch: time::get_time(),
[INFO] [stderr]    |                          ^^^^^^^^ not found in `time`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/lib.rs:73:19
[INFO] [stderr]    |
[INFO] [stderr] 73 |             repo: try!(git2::Repository::open(git_dir.as_ref())),
[INFO] [stderr]    |                   ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/inode.rs:65:26
[INFO] [stderr]    |
[INFO] [stderr] 65 |                _add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:118:40
[INFO] [stderr]     |
[INFO] [stderr] 118 |     inodes: hash_map::HashMap<u64, Box<Inode+'static>>,
[INFO] [stderr]     |                                        ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:122:51
[INFO] [stderr]     |
[INFO] [stderr] 122 |     pub fn insert(&mut self, ino: u64, inode: Box<Inode+'static>) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                   ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:122:81
[INFO] [stderr]     |
[INFO] [stderr] 122 |     pub fn insert(&mut self, ino: u64, inode: Box<Inode+'static>) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                                                 ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:126:61
[INFO] [stderr]     |
[INFO] [stderr] 126 |     pub fn find_mut(&mut self, ino: u64) -> Result<&mut Box<Inode+'static>, libc::c_int> {
[INFO] [stderr]     |                                                             ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:131:33
[INFO] [stderr]     |
[INFO] [stderr] 131 |     -> hash_map::Entry<u64, Box<Inode+'static>> {
[INFO] [stderr]     |                                 ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/inode.rs:139:73
[INFO] [stderr]     |
[INFO] [stderr] 139 | pub fn new_inode(repo: &git2::Repository, oid: git2::Oid) -> Option<Box<Inode+'static>> {
[INFO] [stderr]     |                                                                         ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/blob.rs:24:41
[INFO] [stderr]    |
[INFO] [stderr] 24 |     pub fn new(blob: git2::Blob) -> Box<inode::Inode+'static> {
[INFO] [stderr]    |                                         ^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn inode::Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/tree.rs:27:41
[INFO] [stderr]    |
[INFO] [stderr] 27 |     pub fn new(tree: git2::Tree) -> Box<Inode+'static> {
[INFO] [stderr]    |                                         ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/tree.rs:62:29
[INFO] [stderr]    |
[INFO] [stderr] 62 |                mut add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/reference.rs:26:25
[INFO] [stderr]    |
[INFO] [stderr] 26 |     pub fn new() -> Box<inode::Inode+'static> {
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn inode::Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/reference.rs:52:29
[INFO] [stderr]    |
[INFO] [stderr] 52 |                mut add: Box<FnMut(inode::Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(inode::Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/root.rs:24:43
[INFO] [stderr]    |
[INFO] [stderr] 24 |     pub fn new(head: Id, refs: Id) -> Box<Inode+'static> {
[INFO] [stderr]    |                                           ^^^^^^^^^^^^^ help: use `dyn`: `dyn Inode+'static`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/root.rs:59:29
[INFO] [stderr]    |
[INFO] [stderr] 59 |                mut add: Box<FnMut(Id, FileType, &Path) -> bool + 'a>
[INFO] [stderr]    |                             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn FnMut(Id, FileType, &Path) -> bool + 'a`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `lookup` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:150:5
[INFO] [stderr]     |
[INFO] [stderr] 150 |     fn lookup(&mut self, _req: &fuse::Request, parent: u64, name: &Path, reply: fuse::ReplyEntry) {
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected struct `std::ffi::OsStr`, found struct `std::path::Path`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, &std::ffi::OsStr, fuse::ReplyEntry)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, &std::path::Path, fuse::ReplyEntry)`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `read` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:210:5
[INFO] [stderr]     |
[INFO] [stderr] 210 | /     fn read (&mut self, _req: &fuse::Request, ino: u64, _fh: u64, offset: u64, size: u32,
[INFO] [stderr] 211 | |              reply: fuse::ReplyData) {
[INFO] [stderr] 212 | |         probe!(gitfs, read, ino, offset, size);
[INFO] [stderr] 213 | |
[INFO] [stderr] ...   |
[INFO] [stderr] 219 | |         }
[INFO] [stderr] 220 | |     }
[INFO] [stderr]     | |_____^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, i64, _, fuse::ReplyData)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, u64, _, fuse::ReplyData)`
[INFO] [stderr] 
[INFO] [stderr] error[E0053]: method `readdir` has an incompatible type for trait
[INFO] [stderr]    --> src/lib.rs:234:5
[INFO] [stderr]     |
[INFO] [stderr] 234 | /     fn readdir (&mut self, _req: &fuse::Request, ino: u64, _fh: u64, mut offset: u64,
[INFO] [stderr] 235 | |                 mut reply: fuse::ReplyDirectory) {
[INFO] [stderr] 236 | |         probe!(gitfs, readdir, ino, offset);
[INFO] [stderr] 237 | |
[INFO] [stderr] ...   |
[INFO] [stderr] 257 | |         }
[INFO] [stderr] 258 | |     }
[INFO] [stderr]     | |_____^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, i64, fuse::ReplyDirectory)`
[INFO] [stderr]                found fn pointer `fn(&mut GitFS, &fuse::Request<'_>, _, _, u64, fuse::ReplyDirectory)`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:101:9
[INFO] [stderr]     |
[INFO] [stderr] 96  |     pub fn mount<P: AsRef<Path>>(mut self, mountpoint: &P) {
[INFO] [stderr]     |                                                            - expected `()` because of default return type
[INFO] [stderr] ...
[INFO] [stderr] 101 |         fuse::mount(self, mountpoint, &[&options])
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^- help: try adding a semicolon: `;`
[INFO] [stderr]     |         |
[INFO] [stderr]     |         expected `()`, found enum `std::result::Result`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected unit type `()`
[INFO] [stderr]                     found enum `std::result::Result<(), std::io::Error>`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:101:9
[INFO] [stderr]     |
[INFO] [stderr] 96  |     pub fn mount<P: AsRef<Path>>(mut self, mountpoint: &P) {
[INFO] [stderr]     |                                                            - expected `()` because of default return type
[INFO] [stderr] ...
[INFO] [stderr] 101 |         fuse::mount(self, mountpoint, &[&options])
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^- help: try adding a semicolon: `;`
[INFO] [stderr]     |         |
[INFO] [stderr]     |         expected `()`, found enum `std::result::Result`
[INFO] [stderr]     |
[INFO] [stderr]     = note: expected unit type `()`
[INFO] [stderr]                     found enum `std::result::Result<(), std::io::Error>`
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:244:37
[INFO] [stderr]     |
[INFO] [stderr] 244 |                 reply.add(u64::MAX, offset, FileType::Directory, &Path::new("."));
[INFO] [stderr]     |                                     ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 244 |                 reply.add(u64::MAX, offset.try_into().unwrap(), FileType::Directory, &Path::new("."));
[INFO] [stderr]     |                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:248:37
[INFO] [stderr]     |
[INFO] [stderr] 248 |                 reply.add(u64::MAX, offset, FileType::Directory, &Path::new(".."));
[INFO] [stderr]     |                                     ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 248 |                 reply.add(u64::MAX, offset.try_into().unwrap(), FileType::Directory, &Path::new(".."));
[INFO] [stderr]     |                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:252:47
[INFO] [stderr]     |
[INFO] [stderr] 252 |                 reply.add(mapper.get_ino(id), offset, kind, path)
[INFO] [stderr]     |                                               ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 252 |                 reply.add(mapper.get_ino(id), offset.try_into().unwrap(), kind, path)
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:244:37
[INFO] [stderr]     |
[INFO] [stderr] 244 |                 reply.add(u64::MAX, offset, FileType::Directory, &Path::new("."));
[INFO] [stderr]     |                                     ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 244 |                 reply.add(u64::MAX, offset.try_into().unwrap(), FileType::Directory, &Path::new("."));
[INFO] [stderr]     |                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:248:37
[INFO] [stderr]     |
[INFO] [stderr] 248 |                 reply.add(u64::MAX, offset, FileType::Directory, &Path::new(".."));
[INFO] [stderr]     |                                     ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 248 |                 reply.add(u64::MAX, offset.try_into().unwrap(), FileType::Directory, &Path::new(".."));
[INFO] [stderr]     |                                     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error[E0308]: mismatched types
[INFO] [stderr]    --> src/lib.rs:252:47
[INFO] [stderr]     |
[INFO] [stderr] 252 |                 reply.add(mapper.get_ino(id), offset, kind, path)
[INFO] [stderr]     |                                               ^^^^^^ expected `i64`, found `u64`
[INFO] [stderr]     |
[INFO] [stderr] help: you can convert an `u64` to `i64` and panic if the converted value wouldn't fit
[INFO] [stderr]     |
[INFO] [stderr] 252 |                 reply.add(mapper.get_ino(id), offset.try_into().unwrap(), kind, path)
[INFO] [stderr]     |                                               ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 11 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0053, E0308, E0412, E0422, E0425.
[INFO] [stderr] For more information about an error, try `rustc --explain E0053`.
[INFO] [stderr] error: could not compile `git-fs`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: aborting due to 11 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0053, E0308, E0412, E0422, E0425.
[INFO] [stderr] For more information about an error, try `rustc --explain E0053`.
[INFO] [stderr] error: could not compile `git-fs`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "ddf5379ae73a2676c747558f7600681b3d8504303543872cd7c2922f9c9dd5d8"`
[INFO] running `"docker" "rm" "-f" "ddf5379ae73a2676c747558f7600681b3d8504303543872cd7c2922f9c9dd5d8"`
[INFO] [stdout] ddf5379ae73a2676c747558f7600681b3d8504303543872cd7c2922f9c9dd5d8
