; assembly | /* r2dec pseudo code output */ | /* balber_berdecoder.t/none @ 0x447360 */ | #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 () | int64_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 */ 0x00447360 push rbp | 0x00447361 push r14 | 0x00447363 push rbx | 0x00447364 sub rsp, 0x10 | 0x00447368 mov r14, rdi | r14 = rdi; 0x0044736b cmp edx, 2 | | if (edx != 2) { 0x0044736e je 0x4473c0 | 0x00447370 cmp edx, 1 | | if (edx != 1) { 0x00447373 jne 0x44740e | goto label_0; | } 0x00447379 mov rbx, qword [rsi] | rbx = *(rsi); 0x0044737c mov rax, qword [rbx] | rax = *(rbx); 0x0044737f mov rax, qword [rax - 0x18] | rax = *((rax - 0x18)); 0x00447383 test byte [rbx + rax + 0x20], 1 | | if ((*((rbx + rax + 0x20)) & 1) != 0) { 0x00447388 jne 0x44740e | goto label_0; | } 0x0044738e mov ebp, dword [rsi + 0xc] | ebp = *((rsi + 0xc)); 0x00447391 mov esi, dword [rsi + 8] | 0x00447394 mov rdi, rbx | 0x00447397 mov edx, ebp | edx = ebp; 0x00447399 call 0x460f00 | BloombergLP::bdlb::Print::indent(std::_1::basic_ostream>&,int,int) (rbx, *((rsi + 8))); 0x0044739e mov rdi, r14 | 0x004473a1 mov rsi, rbx | 0x004473a4 xor edx, edx | 0x004473a6 mov ecx, 0xffffffff | 0x004473ab call 0x46c420 | BloombergLP::bdlt::Time::print(std::_1::basic_ostream>&,int,int)const (r14, rbx, 0, 0xffffffff); 0x004473b0 test ebp, ebp | | if (ebp < 0) { 0x004473b2 js 0x44740e | goto label_0; | } 0x004473b4 mov byte [rsp + 0xe], 0xa | *((rsp + 0xe)) = 0xa; 0x004473b9 lea rsi, [rsp + 0xe] | rsi = rsp + 0xe; 0x004473be jmp 0x447401 | | } else { 0x004473c0 mov rbx, qword [rsi] | rbx = *(rsi); 0x004473c3 mov rax, qword [rbx] | rax = *(rbx); 0x004473c6 mov rax, qword [rax - 0x18] | rax = *((rax - 0x18)); 0x004473ca test byte [rbx + rax + 0x20], 1 | | if ((*((rbx + rax + 0x20)) & 1) != 0) { 0x004473cf jne 0x44740e | goto label_0; | } 0x004473d1 mov ebp, dword [rsi + 0xc] | ebp = *((rsi + 0xc)); 0x004473d4 mov esi, dword [rsi + 8] | 0x004473d7 mov rdi, rbx | 0x004473da mov edx, ebp | edx = ebp; 0x004473dc call 0x460f00 | BloombergLP::bdlb::Print::indent(std::_1::basic_ostream>&,int,int) (rbx, *((rsi + 8))); 0x004473e1 mov rdi, r14 | 0x004473e4 mov rsi, rbx | 0x004473e7 xor edx, edx | 0x004473e9 mov ecx, 0xffffffff | 0x004473ee call 0x46c5d0 | BloombergLP::bdlt::TimeTz::print(std::_1::basic_ostream>&,int,int)const (r14, rbx, 0, 0xffffffff); 0x004473f3 test ebp, ebp | | if (ebp < 0) { 0x004473f5 js 0x44740e | goto label_0; | } 0x004473f7 mov byte [rsp + 0xf], 0xa | *((rsp + 0xf)) = 0xa; 0x004473fc lea rsi, [rsp + 0xf] | | } 0x00447401 mov edx, 1 | 0x00447406 mov rdi, rbx | 0x00447409 call 0x445090 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (rbx, rsp + 0xf, 1); | label_0: 0x0044740e add rsp, 0x10 | 0x00447412 pop rbx | 0x00447413 pop r14 | 0x00447415 pop rbp | 0x00447416 ret | return rax; | }