; assembly | /* r2dec pseudo code output */ | /* balber_berdecoder.t/assume @ 0x447440 */ | #include | ; (fcn) method.void_BloombergLP::bdlb::VariantImp_BloombergLP::bslmf::TypeList_BloombergLP::bdlt::Time__BloombergLP::bdlt::TimeTz___::doApply_BloombergLP::bdlb.Variant_PrintVisitor_const__BloombergLP::bdlb::Variant_PrintVisitor_const__int__const () | uint64_t method_void_BloombergLP::bdlb::VariantImp_BloombergLP::bslmf::TypeList_BloombergLP::bdlt::Time_BloombergLP::bdlt::TimeTz_::doApply_BloombergLP::bdlb_Variant_PrintVisitor_const_BloombergLP::bdlb::Variant_PrintVisitor_const_int_const (uint32_t arg3, int64_t arg2, uint32_t arg1) { | int64_t var_eh; | int64_t var_fh; | rdx = arg3; | rsi = arg2; | rdi = arg1; | /* void BloombergLP::bdlb::VariantImp >::doApply(BloombergLP::bdlb::Variant_PrintVisitor const&, int) const */ 0x00447440 push rbp | 0x00447441 push r14 | 0x00447443 push rbx | 0x00447444 sub rsp, 0x10 | 0x00447448 lea eax, [rdx - 3] | eax = rdx - 3; 0x0044744b cmp eax, 0x12 | 0x0044744e jae 0x447459 | | while ((*((r14 + rax + 0x20)) & 1) != 0) { | label_0: 0x00447450 add rsp, 0x10 | 0x00447454 pop rbx | 0x00447455 pop r14 | 0x00447457 pop rbp | 0x00447458 ret | return eax; 0x00447459 mov rbx, rdi | rbx = rdi; 0x0044745c cmp edx, 2 | | if (edx != 2) { 0x0044745f jne 0x4474a5 | goto label_1; | } 0x00447461 mov r14, qword [rsi] | r14 = *(rsi); 0x00447464 mov rax, qword [r14] | rax = *(r14); 0x00447467 mov rax, qword [rax - 0x18] | rax = *((rax - 0x18)); 0x0044746b test byte [r14 + rax + 0x20], 1 | 0x00447471 jne 0x447450 | | } 0x00447473 mov ebp, dword [rsi + 0xc] | ebp = *((rsi + 0xc)); 0x00447476 mov esi, dword [rsi + 8] | 0x00447479 mov rdi, r14 | 0x0044747c mov edx, ebp | edx = ebp; 0x0044747e call 0x461030 | BloombergLP::bdlb::Print::indent(std::_1::basic_ostream>&,int,int) (r14, *((rsi + 8))); 0x00447483 mov rdi, rbx | 0x00447486 mov rsi, r14 | 0x00447489 xor edx, edx | 0x0044748b mov ecx, 0xffffffff | 0x00447490 call 0x46c220 | BloombergLP::bdlt::TimeTz::print(std::_1::basic_ostream>&,int,int)const (rbx, r14, 0, 0xffffffff); 0x00447495 test ebp, ebp | | if (ebp < 0) { 0x00447497 js 0x447450 | goto label_0; | } 0x00447499 mov byte [rsp + 0xf], 0xa | *((rsp + 0xf)) = 0xa; 0x0044749e lea rsi, [rsp + 0xf] | rsi = rsp + 0xf; 0x004474a3 jmp 0x4474eb | goto label_2; | label_1: 0x004474a5 mov r14, qword [rsi] | r14 = *(rsi); 0x004474a8 mov rax, qword [r14] | rax = *(r14); 0x004474ab mov rax, qword [rax - 0x18] | rax = *((rax - 0x18)); 0x004474af test byte [r14 + rax + 0x20], 1 | | if ((*((r14 + rax + 0x20)) & 1) != 0) { 0x004474b5 jne 0x447450 | goto label_0; | } 0x004474b7 mov ebp, dword [rsi + 0xc] | ebp = *((rsi + 0xc)); 0x004474ba mov esi, dword [rsi + 8] | 0x004474bd mov rdi, r14 | 0x004474c0 mov edx, ebp | edx = ebp; 0x004474c2 call 0x461030 | BloombergLP::bdlb::Print::indent(std::_1::basic_ostream>&,int,int) (r14, *((rsi + 8))); 0x004474c7 mov rdi, rbx | 0x004474ca mov rsi, r14 | 0x004474cd xor edx, edx | 0x004474cf mov ecx, 0xffffffff | 0x004474d4 call 0x46c070 | BloombergLP::bdlt::Time::print(std::_1::basic_ostream>&,int,int)const (rbx, r14, 0, 0xffffffff); 0x004474d9 test ebp, ebp | | if (ebp < 0) { 0x004474db js 0x447450 | goto label_0; | } 0x004474e1 mov byte [rsp + 0xe], 0xa | *((rsp + 0xe)) = 0xa; 0x004474e6 lea rsi, [rsp + 0xe] | | label_2: 0x004474eb mov edx, 1 | 0x004474f0 mov rdi, r14 | 0x004474f3 call 0x445120 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (r14, rsp + 0xe, 1); 0x004474f8 jmp 0x447450 | goto label_0; | }