Oct 31 23:55:52.378 INFO checking nilq/ketchup against master#05812fa8c588473f03e3fa7cf59cd84f4f37c715 for pr-55538 Oct 31 23:55:52.378 INFO running `"docker" "create" "-v" "/mnt/big/crater/work/local/target-dirs/pr-55538/worker-6/master#05812fa8c588473f03e3fa7cf59cd84f4f37c715:/target:rw,Z" "-v" "/mnt/big/crater/work/local/test-source/worker-6/pr-55538/master#05812fa8c588473f03e3fa7cf59cd84f4f37c715:/source:ro,Z" "-v" "/mnt/big/crater/work/local/cargo-home:/cargo-home:ro,Z" "-v" "/mnt/big/crater/work/local/rustup-home:/rustup-home:ro,Z" "-e" "USER_ID=1000" "-e" "SOURCE_DIR=/source" "-e" "USER_ID=1000" "-e" "CMD=cargo +05812fa8c588473f03e3fa7cf59cd84f4f37c715-alt check --frozen --all --all-targets" "-e" "CARGO_TARGET_DIR=/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/cargo-home" "-e" "RUSTUP_HOME=/rustup-home" "-m" "1536M" "--network" "none" "crater"` Oct 31 23:55:52.824 INFO blam! cb011f4d99d82d0534006b6206b12f77d664dbb931e3ce9e783a1c8f02ee79bf Oct 31 23:55:52.836 INFO running `"docker" "start" "-a" "cb011f4d99d82d0534006b6206b12f77d664dbb931e3ce9e783a1c8f02ee79bf"` Oct 31 23:55:54.743 INFO kablam! usermod: no changes Oct 31 23:55:54.788 INFO kablam! Checking ketchup v0.1.0 (/source) Oct 31 23:55:55.464 INFO kablam! warning: unused import: `Op` Oct 31 23:55:55.464 INFO kablam! --> src/language/mod.rs:11:14 Oct 31 23:55:55.464 INFO kablam! | Oct 31 23:55:55.464 INFO kablam! 11 | use vm::{Op, Value, Object, Native}; Oct 31 23:55:55.464 INFO kablam! | ^^ Oct 31 23:55:55.464 INFO kablam! | Oct 31 23:55:55.464 INFO kablam! = note: #[warn(unused_imports)] on by default Oct 31 23:55:55.464 INFO kablam! Oct 31 23:55:55.600 INFO kablam! warning: unused import: `Op` Oct 31 23:55:55.600 INFO kablam! --> src/language/mod.rs:11:14 Oct 31 23:55:55.600 INFO kablam! | Oct 31 23:55:55.600 INFO kablam! 11 | use vm::{Op, Value, Object, Native}; Oct 31 23:55:55.600 INFO kablam! | ^^ Oct 31 23:55:55.600 INFO kablam! | Oct 31 23:55:55.600 INFO kablam! = note: #[warn(unused_imports)] on by default Oct 31 23:55:55.600 INFO kablam! Oct 31 23:55:55.620 INFO kablam! warning: unreachable expression Oct 31 23:55:55.620 INFO kablam! --> src/language/mod.rs:50:9 Oct 31 23:55:55.620 INFO kablam! | Oct 31 23:55:55.620 INFO kablam! 50 | Value::Nil Oct 31 23:55:55.620 INFO kablam! | ^^^^^^^^^^ Oct 31 23:55:55.621 INFO kablam! | Oct 31 23:55:55.621 INFO kablam! = note: #[warn(unreachable_code)] on by default Oct 31 23:55:55.621 INFO kablam! Oct 31 23:55:55.792 INFO kablam! warning: unreachable expression Oct 31 23:55:55.792 INFO kablam! --> src/language/mod.rs:50:9 Oct 31 23:55:55.792 INFO kablam! | Oct 31 23:55:55.792 INFO kablam! 50 | Value::Nil Oct 31 23:55:55.792 INFO kablam! | ^^^^^^^^^^ Oct 31 23:55:55.792 INFO kablam! | Oct 31 23:55:55.792 INFO kablam! = note: #[warn(unreachable_code)] on by default Oct 31 23:55:55.792 INFO kablam! Oct 31 23:55:55.956 INFO kablam! warning: unreachable pattern Oct 31 23:55:55.956 INFO kablam! --> src/language/mod.rs:114:13 Oct 31 23:55:55.956 INFO kablam! | Oct 31 23:55:55.956 INFO kablam! 114 | _ => panic!("unimplemented expression!") , Oct 31 23:55:55.956 INFO kablam! | ^ Oct 31 23:55:55.956 INFO kablam! | Oct 31 23:55:55.956 INFO kablam! = note: #[warn(unreachable_patterns)] on by default Oct 31 23:55:55.956 INFO kablam! Oct 31 23:55:55.956 INFO kablam! warning: unreachable pattern Oct 31 23:55:55.956 INFO kablam! --> src/language/mod.rs:157:17 Oct 31 23:55:55.956 INFO kablam! | Oct 31 23:55:55.956 INFO kablam! 157 | _ => panic!("unstable/unimplemented statement!?") Oct 31 23:55:55.956 INFO kablam! | ^ Oct 31 23:55:55.956 INFO kablam! Oct 31 23:55:55.957 INFO kablam! warning: unreachable pattern Oct 31 23:55:55.957 INFO kablam! --> src/language/vm/mod.rs:63:17 Oct 31 23:55:55.957 INFO kablam! | Oct 31 23:55:55.957 INFO kablam! 63 | Op::Name(ref n) => { Oct 31 23:55:55.957 INFO kablam! | ^^^^^^^^^^^^^^^ Oct 31 23:55:55.957 INFO kablam! Oct 31 23:55:55.964 INFO kablam! warning: unreachable pattern Oct 31 23:55:55.964 INFO kablam! --> src/language/vm/mod.rs:129:17 Oct 31 23:55:55.964 INFO kablam! | Oct 31 23:55:55.964 INFO kablam! 129 | _ => panic!("angery, not covered!?!"), Oct 31 23:55:55.964 INFO kablam! | ^ Oct 31 23:55:55.964 INFO kablam! Oct 31 23:55:55.964 INFO kablam! warning: value assigned to `body` is never read Oct 31 23:55:55.964 INFO kablam! --> src/language/syntax/parser/mod.rs:186:29 Oct 31 23:55:55.964 INFO kablam! | Oct 31 23:55:55.964 INFO kablam! 186 | let mut body: Option> = None; Oct 31 23:55:55.964 INFO kablam! | ^^^^ Oct 31 23:55:55.964 INFO kablam! | Oct 31 23:55:55.964 INFO kablam! = note: #[warn(unused_assignments)] on by default Oct 31 23:55:55.964 INFO kablam! Oct 31 23:55:55.964 INFO kablam! warning: unused variable: `t` Oct 31 23:55:55.964 INFO kablam! --> src/language/syntax/parser/mod.rs:215:25 Oct 31 23:55:55.964 INFO kablam! | Oct 31 23:55:55.964 INFO kablam! 215 | t => body = Some(vec!(Statement::Expression(Box::new(self.expression())))), Oct 31 23:55:55.964 INFO kablam! | ^ help: consider using `_t` instead Oct 31 23:55:55.964 INFO kablam! | Oct 31 23:55:55.964 INFO kablam! = note: #[warn(unused_variables)] on by default Oct 31 23:55:55.964 INFO kablam! Oct 31 23:55:55.972 INFO kablam! warning: variable does not need to be mutable Oct 31 23:55:55.972 INFO kablam! --> src/main.rs:65:9 Oct 31 23:55:55.972 INFO kablam! | Oct 31 23:55:55.972 INFO kablam! 65 | let mut test = r#" Oct 31 23:55:55.972 INFO kablam! | ----^^^^ Oct 31 23:55:55.972 INFO kablam! | | Oct 31 23:55:55.972 INFO kablam! | help: remove this `mut` Oct 31 23:55:55.972 INFO kablam! | Oct 31 23:55:55.972 INFO kablam! = note: #[warn(unused_mut)] on by default Oct 31 23:55:55.972 INFO kablam! Oct 31 23:55:56.152 INFO kablam! warning: variant is never constructed: `Block` Oct 31 23:55:56.152 INFO kablam! --> src/language/syntax/lexer/token.rs:3:5 Oct 31 23:55:56.152 INFO kablam! | Oct 31 23:55:56.152 INFO kablam! 3 | Block(Vec), Oct 31 23:55:56.152 INFO kablam! | ^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.152 INFO kablam! | Oct 31 23:55:56.152 INFO kablam! = note: #[warn(dead_code)] on by default Oct 31 23:55:56.152 INFO kablam! Oct 31 23:55:56.152 INFO kablam! warning: variant is never constructed: `Tokens` Oct 31 23:55:56.152 INFO kablam! --> src/language/syntax/lexer/block_tree.rs:6:5 Oct 31 23:55:56.152 INFO kablam! | Oct 31 23:55:56.152 INFO kablam! 6 | Tokens(Vec), Oct 31 23:55:56.152 INFO kablam! | ^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.152 INFO kablam! Oct 31 23:55:56.152 INFO kablam! warning: method is never used: `value` Oct 31 23:55:56.152 INFO kablam! --> src/language/syntax/lexer/block_tree.rs:22:5 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 22 | pub fn value(&self) -> &ChunkValue { Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: function is never used: `lex_branch` Oct 31 23:55:56.153 INFO kablam! --> src/language/syntax/lexer/lexer.rs:80:1 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 80 | pub fn lex_branch(branch: &Branch) -> Branch { Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: function is never used: `flatten_branch` Oct 31 23:55:56.153 INFO kablam! --> src/language/syntax/lexer/lexer.rs:98:1 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 98 | pub fn flatten_branch(branch: &Branch) -> Vec { Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: function is never used: `process_branch` Oct 31 23:55:56.153 INFO kablam! --> src/language/syntax/lexer/lexer.rs:110:1 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 110 | pub fn process_branch(branch: &Branch) -> Vec { Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: variant is never constructed: `Block` Oct 31 23:55:56.153 INFO kablam! --> src/language/syntax/parser/ast.rs:15:5 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 15 | Block(Box>), Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: variant is never constructed: `Jump` Oct 31 23:55:56.153 INFO kablam! --> src/language/vm/op.rs:21:5 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 21 | Jump(i32), Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.153 INFO kablam! warning: function is never used: `test` Oct 31 23:55:56.153 INFO kablam! --> src/main.rs:61:1 Oct 31 23:55:56.153 INFO kablam! | Oct 31 23:55:56.153 INFO kablam! 61 | fn test() { Oct 31 23:55:56.153 INFO kablam! | ^^^^^^^^^ Oct 31 23:55:56.153 INFO kablam! Oct 31 23:55:56.164 INFO kablam! warning: unused `std::result::Result` that must be used Oct 31 23:55:56.164 INFO kablam! --> src/main.rs:53:17 Oct 31 23:55:56.164 INFO kablam! | Oct 31 23:55:56.164 INFO kablam! 53 | vm.run(&mut scopes); Oct 31 23:55:56.164 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.164 INFO kablam! | Oct 31 23:55:56.164 INFO kablam! = note: #[warn(unused_must_use)] on by default Oct 31 23:55:56.164 INFO kablam! = note: this `Result` may be an `Err` variant, which should be handled Oct 31 23:55:56.164 INFO kablam! Oct 31 23:55:56.164 INFO kablam! warning: unused `std::result::Result` that must be used Oct 31 23:55:56.164 INFO kablam! --> src/main.rs:92:5 Oct 31 23:55:56.164 INFO kablam! | Oct 31 23:55:56.164 INFO kablam! 92 | vm.run(&mut scopes); Oct 31 23:55:56.164 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.164 INFO kablam! | Oct 31 23:55:56.164 INFO kablam! = note: this `Result` may be an `Err` variant, which should be handled Oct 31 23:55:56.164 INFO kablam! Oct 31 23:55:56.252 INFO kablam! warning: unreachable pattern Oct 31 23:55:56.252 INFO kablam! --> src/language/mod.rs:114:13 Oct 31 23:55:56.252 INFO kablam! | Oct 31 23:55:56.252 INFO kablam! 114 | _ => panic!("unimplemented expression!") , Oct 31 23:55:56.252 INFO kablam! | ^ Oct 31 23:55:56.252 INFO kablam! | Oct 31 23:55:56.252 INFO kablam! = note: #[warn(unreachable_patterns)] on by default Oct 31 23:55:56.252 INFO kablam! Oct 31 23:55:56.252 INFO kablam! warning: unreachable pattern Oct 31 23:55:56.252 INFO kablam! --> src/language/mod.rs:157:17 Oct 31 23:55:56.252 INFO kablam! | Oct 31 23:55:56.252 INFO kablam! 157 | _ => panic!("unstable/unimplemented statement!?") Oct 31 23:55:56.252 INFO kablam! | ^ Oct 31 23:55:56.252 INFO kablam! Oct 31 23:55:56.252 INFO kablam! warning: unreachable pattern Oct 31 23:55:56.252 INFO kablam! --> src/language/vm/mod.rs:63:17 Oct 31 23:55:56.252 INFO kablam! | Oct 31 23:55:56.252 INFO kablam! 63 | Op::Name(ref n) => { Oct 31 23:55:56.253 INFO kablam! | ^^^^^^^^^^^^^^^ Oct 31 23:55:56.253 INFO kablam! Oct 31 23:55:56.253 INFO kablam! warning: unreachable pattern Oct 31 23:55:56.253 INFO kablam! --> src/language/vm/mod.rs:129:17 Oct 31 23:55:56.253 INFO kablam! | Oct 31 23:55:56.253 INFO kablam! 129 | _ => panic!("angery, not covered!?!"), Oct 31 23:55:56.253 INFO kablam! | ^ Oct 31 23:55:56.253 INFO kablam! Oct 31 23:55:56.253 INFO kablam! warning: value assigned to `body` is never read Oct 31 23:55:56.253 INFO kablam! --> src/language/syntax/parser/mod.rs:186:29 Oct 31 23:55:56.253 INFO kablam! | Oct 31 23:55:56.253 INFO kablam! 186 | let mut body: Option> = None; Oct 31 23:55:56.253 INFO kablam! | ^^^^ Oct 31 23:55:56.253 INFO kablam! | Oct 31 23:55:56.253 INFO kablam! = note: #[warn(unused_assignments)] on by default Oct 31 23:55:56.253 INFO kablam! Oct 31 23:55:56.253 INFO kablam! warning: unused variable: `t` Oct 31 23:55:56.253 INFO kablam! --> src/language/syntax/parser/mod.rs:215:25 Oct 31 23:55:56.253 INFO kablam! | Oct 31 23:55:56.253 INFO kablam! 215 | t => body = Some(vec!(Statement::Expression(Box::new(self.expression())))), Oct 31 23:55:56.253 INFO kablam! | ^ help: consider using `_t` instead Oct 31 23:55:56.253 INFO kablam! | Oct 31 23:55:56.253 INFO kablam! = note: #[warn(unused_variables)] on by default Oct 31 23:55:56.253 INFO kablam! Oct 31 23:55:56.268 INFO kablam! warning: variable does not need to be mutable Oct 31 23:55:56.268 INFO kablam! --> src/main.rs:65:9 Oct 31 23:55:56.268 INFO kablam! | Oct 31 23:55:56.268 INFO kablam! 65 | let mut test = r#" Oct 31 23:55:56.268 INFO kablam! | ----^^^^ Oct 31 23:55:56.268 INFO kablam! | | Oct 31 23:55:56.268 INFO kablam! | help: remove this `mut` Oct 31 23:55:56.268 INFO kablam! | Oct 31 23:55:56.268 INFO kablam! = note: #[warn(unused_mut)] on by default Oct 31 23:55:56.268 INFO kablam! Oct 31 23:55:56.408 INFO kablam! warning: variant is never constructed: `Block` Oct 31 23:55:56.408 INFO kablam! --> src/language/syntax/lexer/token.rs:3:5 Oct 31 23:55:56.408 INFO kablam! | Oct 31 23:55:56.408 INFO kablam! 3 | Block(Vec), Oct 31 23:55:56.408 INFO kablam! | ^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.408 INFO kablam! | Oct 31 23:55:56.408 INFO kablam! = note: #[warn(dead_code)] on by default Oct 31 23:55:56.408 INFO kablam! Oct 31 23:55:56.408 INFO kablam! warning: variant is never constructed: `Tokens` Oct 31 23:55:56.408 INFO kablam! --> src/language/syntax/lexer/block_tree.rs:6:5 Oct 31 23:55:56.408 INFO kablam! | Oct 31 23:55:56.408 INFO kablam! 6 | Tokens(Vec), Oct 31 23:55:56.408 INFO kablam! | ^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: method is never used: `value` Oct 31 23:55:56.409 INFO kablam! --> src/language/syntax/lexer/block_tree.rs:22:5 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 22 | pub fn value(&self) -> &ChunkValue { Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: function is never used: `lex_branch` Oct 31 23:55:56.409 INFO kablam! --> src/language/syntax/lexer/lexer.rs:80:1 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 80 | pub fn lex_branch(branch: &Branch) -> Branch { Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: function is never used: `flatten_branch` Oct 31 23:55:56.409 INFO kablam! --> src/language/syntax/lexer/lexer.rs:98:1 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 98 | pub fn flatten_branch(branch: &Branch) -> Vec { Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: function is never used: `process_branch` Oct 31 23:55:56.409 INFO kablam! --> src/language/syntax/lexer/lexer.rs:110:1 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 110 | pub fn process_branch(branch: &Branch) -> Vec { Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: variant is never constructed: `Block` Oct 31 23:55:56.409 INFO kablam! --> src/language/syntax/parser/ast.rs:15:5 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 15 | Block(Box>), Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: variant is never constructed: `Jump` Oct 31 23:55:56.409 INFO kablam! --> src/language/vm/op.rs:21:5 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 21 | Jump(i32), Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.409 INFO kablam! warning: function is never used: `test` Oct 31 23:55:56.409 INFO kablam! --> src/main.rs:61:1 Oct 31 23:55:56.409 INFO kablam! | Oct 31 23:55:56.409 INFO kablam! 61 | fn test() { Oct 31 23:55:56.409 INFO kablam! | ^^^^^^^^^ Oct 31 23:55:56.409 INFO kablam! Oct 31 23:55:56.412 INFO kablam! warning: unused `std::result::Result` that must be used Oct 31 23:55:56.412 INFO kablam! --> src/main.rs:53:17 Oct 31 23:55:56.412 INFO kablam! | Oct 31 23:55:56.412 INFO kablam! 53 | vm.run(&mut scopes); Oct 31 23:55:56.412 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.412 INFO kablam! | Oct 31 23:55:56.412 INFO kablam! = note: #[warn(unused_must_use)] on by default Oct 31 23:55:56.412 INFO kablam! = note: this `Result` may be an `Err` variant, which should be handled Oct 31 23:55:56.412 INFO kablam! Oct 31 23:55:56.412 INFO kablam! warning: unused `std::result::Result` that must be used Oct 31 23:55:56.412 INFO kablam! --> src/main.rs:92:5 Oct 31 23:55:56.412 INFO kablam! | Oct 31 23:55:56.412 INFO kablam! 92 | vm.run(&mut scopes); Oct 31 23:55:56.412 INFO kablam! | ^^^^^^^^^^^^^^^^^^^^ Oct 31 23:55:56.412 INFO kablam! | Oct 31 23:55:56.412 INFO kablam! = note: this `Result` may be an `Err` variant, which should be handled Oct 31 23:55:56.412 INFO kablam! Oct 31 23:55:56.464 INFO kablam! Finished dev [unoptimized + debuginfo] target(s) in 1.70s Oct 31 23:55:56.464 INFO kablam! su: No module specific data is present Oct 31 23:55:57.359 INFO running `"docker" "rm" "-f" "cb011f4d99d82d0534006b6206b12f77d664dbb931e3ce9e783a1c8f02ee79bf"` Oct 31 23:55:57.748 INFO blam! cb011f4d99d82d0534006b6206b12f77d664dbb931e3ce9e783a1c8f02ee79bf