[INFO] updating cached repository nsqio/rust-nsq [INFO] running `"git" "fetch" "--all"` [INFO] [stdout] Fetching origin [INFO] [stderr] From git://github.com/nsqio/rust-nsq [INFO] [stderr] * branch HEAD -> FETCH_HEAD [INFO] running `"git" "clone" "work/cache/sources/gh/nsqio/rust-nsq" "work/ex/pr-62133/sources/master#5f9c0448dde167128d668da4555879f64e56af1d/gh/nsqio/rust-nsq"` [INFO] [stderr] Cloning into 'work/ex/pr-62133/sources/master#5f9c0448dde167128d668da4555879f64e56af1d/gh/nsqio/rust-nsq'... [INFO] [stderr] done. [INFO] running `"git" "clone" "work/cache/sources/gh/nsqio/rust-nsq" "work/ex/pr-62133/sources/try#8ec8125bea94852768b56958f05da47666c21ab0/gh/nsqio/rust-nsq"` [INFO] [stderr] Cloning into 'work/ex/pr-62133/sources/try#8ec8125bea94852768b56958f05da47666c21ab0/gh/nsqio/rust-nsq'... [INFO] [stderr] done. [INFO] running `"git" "rev-parse" "HEAD"` [INFO] [stdout] 253dbee7f882099e7de8accc43adc0074b122415 [INFO] sha for GitHub repo nsqio/rust-nsq: 253dbee7f882099e7de8accc43adc0074b122415 [INFO] validating manifest of nsqio/rust-nsq on toolchain master#5f9c0448dde167128d668da4555879f64e56af1d [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+5f9c0448dde167128d668da4555879f64e56af1d-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] validating manifest of nsqio/rust-nsq on toolchain try#8ec8125bea94852768b56958f05da47666c21ab0 [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+8ec8125bea94852768b56958f05da47666c21ab0-alt" "read-manifest" "--manifest-path" "Cargo.toml"` [INFO] started frobbing nsqio/rust-nsq [INFO] finished frobbing nsqio/rust-nsq [INFO] frobbed toml for nsqio/rust-nsq written to work/ex/pr-62133/sources/master#5f9c0448dde167128d668da4555879f64e56af1d/gh/nsqio/rust-nsq/Cargo.toml [INFO] started frobbing nsqio/rust-nsq [INFO] finished frobbing nsqio/rust-nsq [INFO] frobbed toml for nsqio/rust-nsq written to work/ex/pr-62133/sources/try#8ec8125bea94852768b56958f05da47666c21ab0/gh/nsqio/rust-nsq/Cargo.toml [INFO] crate nsqio/rust-nsq already has a lockfile, it will not be regenerated [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+5f9c0448dde167128d668da4555879f64e56af1d-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] running `"/mnt/big/crater/work/local/cargo-home/bin/cargo" "+8ec8125bea94852768b56958f05da47666c21ab0-alt" "fetch" "--locked" "--manifest-path" "Cargo.toml"` [INFO] checking nsqio/rust-nsq against try#8ec8125bea94852768b56958f05da47666c21ab0 for pr-62133 [INFO] running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-62133/worker-4/try#8ec8125bea94852768b56958f05da47666c21ab0:/opt/crater/target:rw,Z" "-v" "/mnt/big/crater/work/ex/pr-62133/sources/try#8ec8125bea94852768b56958f05da47666c21ab0/gh/nsqio/rust-nsq:/opt/crater/workdir:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/opt/crater/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/opt/crater/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/opt/crater/workdir" "-e" "MAP_USER_ID=1000" "-e" "CARGO_TARGET_DIR=/opt/crater/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/crater/cargo-home" "-e" "RUSTUP_HOME=/opt/crater/rustup-home" "-w" "/opt/crater/workdir" "-m" "1536M" "--network" "none" "rustops/crates-build-env" "/opt/crater/cargo-home/bin/cargo" "+8ec8125bea94852768b56958f05da47666c21ab0-alt" "check" "--frozen" "--all" "--all-targets"` [INFO] [stdout] bc6e3460b0cceac3071f51f1fc416e29e6d9a078b0b886d81e5d5043b771ddba [INFO] running `"docker" "start" "-a" "bc6e3460b0cceac3071f51f1fc416e29e6d9a078b0b886d81e5d5043b771ddba"` [INFO] [stderr] Checking nsq v0.0.1 (/opt/crater/workdir) [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:22:3 [INFO] [stderr] | [INFO] [stderr] 22 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:37:3 [INFO] [stderr] | [INFO] [stderr] 37 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:22:3 [INFO] [stderr] | [INFO] [stderr] 22 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:28:3 [INFO] [stderr] | [INFO] [stderr] 28 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0658]: The attribute `deriving` is currently unknown to the compiler and may have meaning added to it in the future [INFO] [stderr] --> src/lib.rs:37:3 [INFO] [stderr] | [INFO] [stderr] 37 | #[deriving(Show)] [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: for more information, see https://github.com/rust-lang/rust/issues/29642 [INFO] [stderr] = help: add #![feature(custom_attribute)] to the crate attributes to enable [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: could not find `net` in `io` [INFO] [stderr] --> src/lib.rs:4:14 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::net::tcp::TcpStream; [INFO] [stderr] | ^^^ could not find `net` in `io` [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved imports `std::io::MemReader`, `std::io::Reader`, `std::io::Writer`, `std::io::IoResult`, `std::io::IoError` [INFO] [stderr] --> src/lib.rs:3:15 [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^ ^^^^^^ ^^^^^^^^ ^^^^^^^ no `IoError` in `io` [INFO] [stderr] | | | | | [INFO] [stderr] | | | | no `IoResult` in `io` [INFO] [stderr] | | | no `Writer` in `io` [INFO] [stderr] | | no `Reader` in `io` [INFO] [stderr] | no `MemReader` in `io` [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{BufReader, Reader, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Read, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Write, IoResult, IoError}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, Result, IoError}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, IoResult, Error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `TcpStream` [INFO] [stderr] --> src/lib.rs:49:25 [INFO] [stderr] | [INFO] [stderr] 49 | let sock = try!(TcpStream::connect(addr, port)); [INFO] [stderr] | ^^^^^^^^^ use of undeclared type or module `TcpStream` [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `TcpStream` in this scope [INFO] [stderr] --> src/lib.rs:44:11 [INFO] [stderr] | [INFO] [stderr] 44 | sock: TcpStream, [INFO] [stderr] | ^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use std::net::TcpStream; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 67 | let size = try_io!(r.read_be_u32()); [INFO] [stderr] | ------------------------ in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `uint` in this scope [INFO] [stderr] --> src/lib.rs:68:49 [INFO] [stderr] | [INFO] [stderr] 68 | let data = try_io!(r.read_exact(size as uint)); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: could not find `net` in `io` [INFO] [stderr] --> src/lib.rs:4:14 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::net::tcp::TcpStream; [INFO] [stderr] | ^^^ could not find `net` in `io` [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 68 | let data = try_io!(r.read_exact(size as uint)); [INFO] [stderr] | ----------------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0432]: unresolved imports `std::io::MemReader`, `std::io::Reader`, `std::io::Writer`, `std::io::IoResult`, `std::io::IoError` [INFO] [stderr] --> src/lib.rs:3:15 [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^ ^^^^^^ ^^^^^^^^ ^^^^^^^ no `IoError` in `io` [INFO] [stderr] | | | | | [INFO] [stderr] | | | | no `IoResult` in `io` [INFO] [stderr] | | | no `Writer` in `io` [INFO] [stderr] | | no `Reader` in `io` [INFO] [stderr] | no `MemReader` in `io` [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 70 | let frame_type = try_io!(frame.read_be_u32()); [INFO] [stderr] | ---------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 71 | let body = try_io!(frame.read_to_end()); [INFO] [stderr] | ---------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `ResponseError` in this scope [INFO] [stderr] --> src/lib.rs:74:23 [INFO] [stderr] | [INFO] [stderr] 74 | kind: ResponseError, [INFO] [stderr] | ^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::ResponseError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::net::tcp::TcpStream` [INFO] [stderr] --> src/lib.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::net::tcp::TcpStream; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unused_imports)] on by default [INFO] [stderr] [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{BufReader, Reader, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Read, Writer, IoResult, IoError}; [INFO] [stderr] | ^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Write, IoResult, IoError}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, Result, IoError}; [INFO] [stderr] | ^^^^^^ [INFO] [stderr] help: a similar name exists in the module [INFO] [stderr] | [INFO] [stderr] 3 | use std::io::{MemReader, Reader, Writer, IoResult, Error}; [INFO] [stderr] | ^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `TcpStream` [INFO] [stderr] --> src/lib.rs:49:25 [INFO] [stderr] | [INFO] [stderr] 49 | let sock = try!(TcpStream::connect(addr, port)); [INFO] [stderr] | ^^^^^^^^^ use of undeclared type or module `TcpStream` [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `TcpStream` in this scope [INFO] [stderr] --> src/lib.rs:44:11 [INFO] [stderr] | [INFO] [stderr] 44 | sock: TcpStream, [INFO] [stderr] | ^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use std::net::TcpStream; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 67 | let size = try_io!(r.read_be_u32()); [INFO] [stderr] | ------------------------ in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0412]: cannot find type `uint` in this scope [INFO] [stderr] --> src/lib.rs:68:49 [INFO] [stderr] | [INFO] [stderr] 68 | let data = try_io!(r.read_exact(size as uint)); [INFO] [stderr] | ^^^^ not found in this scope [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 68 | let data = try_io!(r.read_exact(size as uint)); [INFO] [stderr] | ----------------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 70 | let frame_type = try_io!(frame.read_be_u32()); [INFO] [stderr] | ---------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find function `InternalIoError` in this scope [INFO] [stderr] --> src/lib.rs:12:27 [INFO] [stderr] | [INFO] [stderr] 12 | kind: InternalIoError(err), [INFO] [stderr] | ^^^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] ... [INFO] [stderr] 71 | let body = try_io!(frame.read_to_end()); [INFO] [stderr] | ---------------------------- in this macro invocation [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::InternalIoError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] error[E0425]: cannot find value `ResponseError` in this scope [INFO] [stderr] --> src/lib.rs:74:23 [INFO] [stderr] | [INFO] [stderr] 74 | kind: ResponseError, [INFO] [stderr] | ^^^^^^^^^^^^^ not found in this scope [INFO] [stderr] help: possible candidate is found in another module, you can import it into scope [INFO] [stderr] | [INFO] [stderr] 3 | use ErrorKind::ResponseError; [INFO] [stderr] | [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::io::net::tcp::TcpStream` [INFO] [stderr] --> src/lib.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use std::io::net::tcp::TcpStream; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: #[warn(unused_imports)] on by default [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&[u8]` in the current scope [INFO] [stderr] --> src/lib.rs:62:22 [INFO] [stderr] | [INFO] [stderr] 62 | w.write(data.as_slice()) [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] error[E0599]: no method named `as_slice` found for type `&[u8]` in the current scope [INFO] [stderr] --> src/lib.rs:62:22 [INFO] [stderr] | [INFO] [stderr] 62 | w.write(data.as_slice()) [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] error: aborting due to 14 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599, E0658. [INFO] [stderr] For more information about an error, try `rustc --explain E0412`. [INFO] [stderr] [INFO] [stderr] error: Could not compile `nsq`. [INFO] [stderr] warning: build failed, waiting for other jobs to finish... [INFO] [stderr] error: aborting due to 14 previous errors [INFO] [stderr] [INFO] [stderr] Some errors have detailed explanations: E0412, E0425, E0432, E0433, E0599, E0658. [INFO] [stderr] For more information about an error, try `rustc --explain E0412`. [INFO] [stderr] error: Could not compile `nsq`. [INFO] [stderr] [INFO] [stderr] To learn more, run the command again with --verbose. [INFO] running `"docker" "inspect" "bc6e3460b0cceac3071f51f1fc416e29e6d9a078b0b886d81e5d5043b771ddba"` [INFO] running `"docker" "rm" "-f" "bc6e3460b0cceac3071f51f1fc416e29e6d9a078b0b886d81e5d5043b771ddba"` [INFO] [stdout] bc6e3460b0cceac3071f51f1fc416e29e6d9a078b0b886d81e5d5043b771ddba