[INFO] cloning repository https://github.com/andreasots/motd-generator [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/andreasots/motd-generator" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fandreasots%2Fmotd-generator", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fandreasots%2Fmotd-generator'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 77d8e0193e6d1ae0680a22f4b6e53020e3d1f046 [INFO] checking andreasots/motd-generator against master#0dce3f606e05cffab7361c132a399d3550ab0df8 for pr-78376 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fandreasots%2Fmotd-generator" "/workspace/builds/worker-1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1/source'... [INFO] [stderr] done. [INFO] validating manifest of git repo https://github.com/andreasots/motd-generator on toolchain 0dce3f606e05cffab7361c132a399d3550ab0df8 [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "read-manifest" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] started tweaking git repo https://github.com/andreasots/motd-generator [INFO] finished tweaking git repo https://github.com/andreasots/motd-generator [INFO] tweaked toml for git repo https://github.com/andreasots/motd-generator written to /workspace/builds/worker-1/source/Cargo.toml [INFO] crate git repo https://github.com/andreasots/motd-generator already has a lockfile, it will not be regenerated [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] error: the lock file /workspace/builds/worker-1/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 `Command { std: "/workspace/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "/workspace/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "fetch" "--locked" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/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" "rustops/crates-build-env@sha256:d92eaeed33fa75130ca1ee6c8a01d1ffb62bac859dfdfb3450e3e5d1c0146529" "/opt/rustwide/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 09823ef6de5b90c4c030b273f5524b5ce24973fd977fe2d1bad8e97eb803a219 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "09823ef6de5b90c4c030b273f5524b5ce24973fd977fe2d1bad8e97eb803a219", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "09823ef6de5b90c4c030b273f5524b5ce24973fd977fe2d1bad8e97eb803a219", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "09823ef6de5b90c4c030b273f5524b5ce24973fd977fe2d1bad8e97eb803a219", kill_on_drop: false }` [INFO] [stdout] 09823ef6de5b90c4c030b273f5524b5ce24973fd977fe2d1bad8e97eb803a219 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "rustops/crates-build-env@sha256:d92eaeed33fa75130ca1ee6c8a01d1ffb62bac859dfdfb3450e3e5d1c0146529" "/opt/rustwide/cargo-home/bin/cargo" "+0dce3f606e05cffab7361c132a399d3550ab0df8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 5381d7e13fba4dd0d745953bb5864af9f31960c5956c3b09407fc780dee99594 [INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap. [INFO] running `Command { std: "docker" "start" "-a" "5381d7e13fba4dd0d745953bb5864af9f31960c5956c3b09407fc780dee99594", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.80 [INFO] [stderr] Compiling winapi-build v0.1.1 [INFO] [stderr] Compiling pq-sys v0.2.7 [INFO] [stderr] Checking winapi v0.2.8 [INFO] [stderr] Checking byteorder v0.3.13 [INFO] [stderr] Checking rustc-serialize v0.3.24 [INFO] [stderr] Checking unicode-width v0.1.8 [INFO] [stderr] Checking utf8-ranges v0.1.3 [INFO] [stderr] Checking bitflags v0.4.0 [INFO] [stderr] Checking regex-syntax v0.3.9 [INFO] [stderr] Checking term v0.4.6 [INFO] [stderr] Checking encode_unicode v0.3.6 [INFO] [stderr] Compiling num-traits v0.2.14 [INFO] [stderr] Compiling num-integer v0.1.44 [INFO] [stderr] Compiling num-iter v0.1.42 [INFO] [stderr] Compiling kernel32-sys v0.2.2 [INFO] [stderr] Checking memchr v0.1.11 [INFO] [stderr] Checking memchr v1.0.2 [INFO] [stderr] Checking thread-id v2.0.0 [INFO] [stderr] Checking time v0.1.44 [INFO] [stderr] Checking rand v0.4.6 [INFO] [stderr] Checking atty v0.2.14 [INFO] [stderr] Checking nix v0.5.1 [INFO] [stderr] Checking thread_local v0.2.7 [INFO] [stderr] Checking aho-corasick v0.5.3 [INFO] [stderr] Checking diesel v0.7.1 [INFO] [stderr] Checking regex v0.1.80 [INFO] [stderr] Checking rand v0.3.23 [INFO] [stderr] Checking num v0.1.42 [INFO] [stderr] Checking chrono v0.2.25 [INFO] [stderr] Checking tempfile v2.2.0 [INFO] [stderr] Checking csv v0.15.0 [INFO] [stderr] Checking prettytable-rs v0.6.7 [INFO] [stderr] Checking diesel v0.6.2 [INFO] [stderr] Checking diesel_full_text_search v0.5.2 [INFO] [stderr] Checking motd-generator v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | try!(try!(File::open("/proc/loadavg")).read_to_string(&mut line)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:8:10 [INFO] [stdout] | [INFO] [stdout] 8 | try!(try!(File::open("/proc/loadavg")).read_to_string(&mut line)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:9:17 [INFO] [stdout] | [INFO] [stdout] 9 | let regex = try!(Regex::new(r"^(\d+\.\d+) (\d+\.\d+) (\d+\.\d+) (\d+)/(\d+) (\d+)$")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:24 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:43 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:63 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:13:17 [INFO] [stdout] | [INFO] [stdout] 13 | let regex = try!(Regex::new(r"^([^:]+):\s*(\d+)(?: kB)?$")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:17:32 [INFO] [stdout] | [INFO] [stdout] 17 | for line in BufReader::new(try!(File::open("/proc/meminfo"))).lines() { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:18:20 [INFO] [stdout] | [INFO] [stdout] 18 | let line = try!(line); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:22:55 [INFO] [stdout] | [INFO] [stdout] 22 | meminfo.insert(String::from(key), try!(value.parse::())) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/statfs.rs:29:5 [INFO] [stdout] | [INFO] [stdout] 29 | try!(statfs(path, &mut stat)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | try!(write!(formatter, "Quote #{}: \"{}\"", self.id, self.quote)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:62:13 [INFO] [stdout] | [INFO] [stdout] 62 | try!(write!(formatter, " —{}", name)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:8:5 [INFO] [stdout] | [INFO] [stdout] 8 | try!(try!(File::open("/proc/loadavg")).read_to_string(&mut line)); [INFO] [stdout] | ^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(deprecated)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:65:13 [INFO] [stdout] | [INFO] [stdout] 65 | try!(write!(formatter, " [{}]", date)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:8:10 [INFO] [stdout] | [INFO] [stdout] 8 | try!(try!(File::open("/proc/loadavg")).read_to_string(&mut line)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:75:16 [INFO] [stdout] | [INFO] [stdout] 75 | let conn = try!(PgConnection::establish("postgres:///lrrbot")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:76:15 [INFO] [stdout] | [INFO] [stdout] 76 | let res = try!(quotes.filter(deleted.eq(false).and(to_tsvector(quote) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:9:17 [INFO] [stdout] | [INFO] [stdout] 9 | let regex = try!(Regex::new(r"^(\d+\.\d+) (\d+\.\d+) (\d+\.\d+) (\d+)/(\d+) (\d+)$")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:24 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:43 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/loadavg.rs:6:49 [INFO] [stdout] | [INFO] [stdout] 6 | pub fn loadavg() -> Result<(f32, f32, f32), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/loadavg.rs:14:63 [INFO] [stdout] | [INFO] [stdout] 14 | return Ok((try!(one.parse()), try!(five.parse()), try!(fifteen.parse()))); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:13:17 [INFO] [stdout] | [INFO] [stdout] 13 | let regex = try!(Regex::new(r"^([^:]+):\s*(\d+)(?: kB)?$")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:17:32 [INFO] [stdout] | [INFO] [stdout] 17 | for line in BufReader::new(try!(File::open("/proc/meminfo"))).lines() { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/memory.rs:12:62 [INFO] [stdout] | [INFO] [stdout] 12 | pub fn get_memory_stats(table: &mut Table) -> Result<(), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:18:20 [INFO] [stdout] | [INFO] [stdout] 18 | let line = try!(line); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/memory.rs:22:55 [INFO] [stdout] | [INFO] [stdout] 22 | meminfo.insert(String::from(key), try!(value.parse::())) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/statfs.rs:29:5 [INFO] [stdout] | [INFO] [stdout] 29 | try!(statfs(path, &mut stat)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/statfs.rs:14:68 [INFO] [stdout] | [INFO] [stdout] 14 | ... -> Result<(), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/quote.rs:71:42 [INFO] [stdout] | [INFO] [stdout] 71 | pub fn get_quote() -> Result> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:47:30 [INFO] [stdout] | [INFO] [stdout] 47 | .map_err(Box::::from) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn std::error::Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:49:64 [INFO] [stdout] | [INFO] [stdout] 49 | std::str::from_utf8(&host[..]).map_err(Box::::from) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn std::error::Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:8:1 [INFO] [stdout] | [INFO] [stdout] 8 | / table! { [INFO] [stdout] 9 | | quotes { [INFO] [stdout] 10 | | id -> Integer, [INFO] [stdout] 11 | | quote -> Text, [INFO] [stdout] ... | [INFO] [stdout] 18 | | } [INFO] [stdout] 19 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = note: this warning originates in a macro (in Nightly builds, run with -Z macro-backtrace for more info) [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:60:9 [INFO] [stdout] | [INFO] [stdout] 60 | try!(write!(formatter, "Quote #{}: \"{}\"", self.id, self.quote)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:62:13 [INFO] [stdout] | [INFO] [stdout] 62 | try!(write!(formatter, " —{}", name)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:65:13 [INFO] [stdout] | [INFO] [stdout] 65 | try!(write!(formatter, " [{}]", date)); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:75:16 [INFO] [stdout] | [INFO] [stdout] 75 | let conn = try!(PgConnection::establish("postgres:///lrrbot")); [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated macro `try`: use the `?` operator instead [INFO] [stdout] --> src/quote.rs:76:15 [INFO] [stdout] | [INFO] [stdout] 76 | let res = try!(quotes.filter(deleted.eq(false).and(to_tsvector(quote) [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/loadavg.rs:6:49 [INFO] [stdout] | [INFO] [stdout] 6 | pub fn loadavg() -> Result<(f32, f32, f32), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(bare_trait_objects)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/memory.rs:12:62 [INFO] [stdout] | [INFO] [stdout] 12 | pub fn get_memory_stats(table: &mut Table) -> Result<(), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/statfs.rs:14:68 [INFO] [stdout] | [INFO] [stdout] 14 | ... -> Result<(), Box> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/quote.rs:71:42 [INFO] [stdout] | [INFO] [stdout] 71 | pub fn get_quote() -> Result> { [INFO] [stdout] | ^^^^^ help: use `dyn`: `dyn Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:47:30 [INFO] [stdout] | [INFO] [stdout] 47 | .map_err(Box::::from) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn std::error::Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: trait objects without an explicit `dyn` are deprecated [INFO] [stdout] --> src/main.rs:49:64 [INFO] [stdout] | [INFO] [stdout] 49 | std::str::from_utf8(&host[..]).map_err(Box::::from) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn std::error::Error` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `rand::sample`: renamed to seq::sample_iter [INFO] [stdout] --> src/quote.rs:80:11 [INFO] [stdout] | [INFO] [stdout] 80 | match rand::sample(&mut rand::thread_rng(), res, 1).get(0) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated function `rand::sample`: renamed to seq::sample_iter [INFO] [stdout] --> src/quote.rs:80:11 [INFO] [stdout] | [INFO] [stdout] 80 | match rand::sample(&mut rand::thread_rng(), res, 1).get(0) { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `core::str::::trim_right_matches`: superseded by `trim_end_matches` [INFO] [stdout] --> src/main.rs:51:32 [INFO] [stdout] | [INFO] [stdout] 51 | .map(|host| host.trim_right_matches('\0')) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_end_matches` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: use of deprecated associated function `core::str::::trim_right_matches`: superseded by `trim_end_matches` [INFO] [stdout] --> src/main.rs:51:32 [INFO] [stdout] | [INFO] [stdout] 51 | .map(|host| host.trim_right_matches('\0')) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated associated function: `trim_end_matches` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0277]: the trait bound `quote::quotes::columns::quote: diesel::expression::Expression` is not satisfied [INFO] [stdout] --> src/quote.rs:76:68 [INFO] [stdout] | [INFO] [stdout] 76 | let res = try!(quotes.filter(deleted.eq(false).and(to_tsvector(quote) [INFO] [stdout] | ^^^^^ the trait `diesel::expression::Expression` is not implemented for `quote::quotes::columns::quote` [INFO] [stdout] | [INFO] [stdout] ::: /opt/rustwide/cargo-home/registry/src/github.com-1ecc6299db9ec823/diesel_full_text_search-0.5.2/src/lib.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | sql_function!(to_tsvector, to_tsvector_t, (x: Text) -> TsVector); [INFO] [stdout] | ----------------------------------------------------------------- required by this bound in `to_tsvector` [INFO] [stdout] | [INFO] [stdout] = note: required because of the requirements on the impl of `diesel::expression::AsExpression` for `quote::quotes::columns::quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0599]: no method named `matches` found for struct `to_tsvector_t` in the current scope [INFO] [stdout] --> src/quote.rs:77:61 [INFO] [stdout] | [INFO] [stdout] 77 | ... .matches(plainto_tsquery("butts")))) [INFO] [stdout] | ^^^^^^^ method not found in `to_tsvector_t` [INFO] [stdout] | [INFO] [stdout] ::: /opt/rustwide/cargo-home/registry/src/github.com-1ecc6299db9ec823/diesel_full_text_search-0.5.2/src/lib.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | sql_function!(to_tsvector, to_tsvector_t, (x: Text) -> TsVector); [INFO] [stdout] | ----------------------------------------------------------------- [INFO] [stdout] | | [INFO] [stdout] | doesn't satisfy `<_ as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] | doesn't satisfy `_: TsVectorExtensions` [INFO] [stdout] | doesn't satisfy `_: diesel::expression::Expression` [INFO] [stdout] | [INFO] [stdout] = note: the method `matches` exists but the following trait bounds were not satisfied: [INFO] [stdout] ` as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `<&to_tsvector_t as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `&to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `&to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `&to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `<&mut to_tsvector_t as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `&mut to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `&mut to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `&mut to_tsvector_t: TsVectorExtensions` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused import: `TsVectorExtensions` [INFO] [stdout] --> src/quote.rs:72:65 [INFO] [stdout] | [INFO] [stdout] 72 | use diesel_full_text_search::{plainto_tsquery, to_tsvector, TsVectorExtensions}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 2 previous errors; 34 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0277, E0599. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] [stderr] error: could not compile `motd-generator` [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] [stdout] error[E0277]: the trait bound `quote::quotes::columns::quote: diesel::expression::Expression` is not satisfied [INFO] [stdout] --> src/quote.rs:76:68 [INFO] [stdout] | [INFO] [stdout] 76 | let res = try!(quotes.filter(deleted.eq(false).and(to_tsvector(quote) [INFO] [stdout] | ^^^^^ the trait `diesel::expression::Expression` is not implemented for `quote::quotes::columns::quote` [INFO] [stdout] | [INFO] [stdout] ::: /opt/rustwide/cargo-home/registry/src/github.com-1ecc6299db9ec823/diesel_full_text_search-0.5.2/src/lib.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | sql_function!(to_tsvector, to_tsvector_t, (x: Text) -> TsVector); [INFO] [stdout] | ----------------------------------------------------------------- required by this bound in `to_tsvector` [INFO] [stdout] | [INFO] [stdout] = note: required because of the requirements on the impl of `diesel::expression::AsExpression` for `quote::quotes::columns::quote` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error[E0599]: no method named `matches` found for struct `to_tsvector_t` in the current scope [INFO] [stdout] --> src/quote.rs:77:61 [INFO] [stdout] | [INFO] [stdout] 77 | ... .matches(plainto_tsquery("butts")))) [INFO] [stdout] | ^^^^^^^ method not found in `to_tsvector_t` [INFO] [stdout] | [INFO] [stdout] ::: /opt/rustwide/cargo-home/registry/src/github.com-1ecc6299db9ec823/diesel_full_text_search-0.5.2/src/lib.rs:40:5 [INFO] [stdout] | [INFO] [stdout] 40 | sql_function!(to_tsvector, to_tsvector_t, (x: Text) -> TsVector); [INFO] [stdout] | ----------------------------------------------------------------- [INFO] [stdout] | | [INFO] [stdout] | doesn't satisfy `<_ as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] | doesn't satisfy `_: TsVectorExtensions` [INFO] [stdout] | doesn't satisfy `_: diesel::expression::Expression` [INFO] [stdout] | [INFO] [stdout] = note: the method `matches` exists but the following trait bounds were not satisfied: [INFO] [stdout] ` as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `<&to_tsvector_t as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `&to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `&to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `&to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `<&mut to_tsvector_t as diesel::expression::Expression>::SqlType = TsVector` [INFO] [stdout] which is required by `&mut to_tsvector_t: TsVectorExtensions` [INFO] [stdout] `&mut to_tsvector_t: diesel::expression::Expression` [INFO] [stdout] which is required by `&mut to_tsvector_t: TsVectorExtensions` [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] error: build failed [INFO] [stdout] warning: unused import: `TsVectorExtensions` [INFO] [stdout] --> src/quote.rs:72:65 [INFO] [stdout] | [INFO] [stdout] 72 | use diesel_full_text_search::{plainto_tsquery, to_tsvector, TsVectorExtensions}; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] error: aborting due to 2 previous errors; 34 warnings emitted [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] Some errors have detailed explanations: E0277, E0599. [INFO] [stdout] [INFO] [stdout] For more information about an error, try `rustc --explain E0277`. [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "5381d7e13fba4dd0d745953bb5864af9f31960c5956c3b09407fc780dee99594", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "5381d7e13fba4dd0d745953bb5864af9f31960c5956c3b09407fc780dee99594", kill_on_drop: false }` [INFO] [stdout] 5381d7e13fba4dd0d745953bb5864af9f31960c5956c3b09407fc780dee99594