; assembly | /* r2dec pseudo code output */ | /* baljsn_simpleformatter.t/none @ 0x42a820 */ | #include | ; (fcn) method.int_BloombergLP::baljsn::SimpleFormatter::addValue_BloombergLP::bdlt.DateTz__BloombergLP::bdlt::DateTz_const_ () | uint64_t method_int_BloombergLP::baljsn::SimpleFormatter::addValue_BloombergLP::bdlt_DateTz_BloombergLP::bdlt::DateTz_const_ (int64_t arg2, uint32_t arg1) { | int64_t var_8h; | int64_t var_10h; | int64_t var_40h; | size_t var_48h; | rsi = arg2; | rdi = arg1; | /* int BloombergLP::baljsn::SimpleFormatter::addValue(BloombergLP::bdlt::DateTz const&) */ 0x0042a820 push rbp | 0x0042a821 push r15 | 0x0042a823 push r14 | 0x0042a825 push r12 | 0x0042a827 push rbx | 0x0042a828 sub rsp, 0x50 | 0x0042a82c mov r14, rsi | r14 = rsi; 0x0042a82f mov rbx, rdi | rbx = rdi; 0x0042a832 cmp dword [rdi + 0x4c], 1 | | if (*((rdi + 0x4c)) == 1) { 0x0042a836 jne 0x42a897 | 0x0042a838 mov bpl, byte [rbx + 0xa] | bpl = *((rbx + 0xa)); 0x0042a83c mov byte [rbx + 9], 1 | *((rbx + 9)) = 1; 0x0042a840 cmp byte [rbx + 8], 0 | | if (*((rbx + 8)) != 0) { 0x0042a844 je 0x42a87a | 0x0042a846 mov rdi, qword [rbx] | 0x0042a849 mov byte [rsp + 0x10], 0x2c | *((rsp + 0x10)) = 0x2c; 0x0042a84e lea rsi, [rsp + 0x10] | 0x0042a853 mov edx, 1 | 0x0042a858 call 0x429230 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (*(rbx), rsp + 0x10, 1); 0x0042a85d cmp dword [rbx + 0x4c], 1 | | if (*((rbx + 0x4c)) != 1) { 0x0042a861 jne 0x42a87a | goto label_0; | } 0x0042a863 mov rdi, qword [rbx] | 0x0042a866 mov byte [rsp + 0x10], 0xa | *((rsp + 0x10)) = 0xa; 0x0042a86b lea rsi, [rsp + 0x10] | 0x0042a870 mov edx, 1 | 0x0042a875 call 0x429230 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (*(rbx), rsp + 0x10, 1); | } | label_0: 0x0042a87a mov byte [rbx + 0xa], 0 | *((rbx + 0xa)) = 0; 0x0042a87e mov byte [rbx + 8], 1 | *((rbx + 8)) = 1; 0x0042a882 test bpl, bpl | | if (bpl != 0) { 0x0042a885 jne 0x42a8dd | goto label_1; | } 0x0042a887 mov rdi, qword [rbx] | 0x0042a88a mov esi, dword [rbx + 0x54] | 0x0042a88d mov edx, dword [rbx + 0x3c] | edx = *((rbx + 0x3c)); 0x0042a890 call 0x431290 | BloombergLP::bdlb::Print::indent(std::_1::basic_ostream>&,int,int) (*(rbx), *((rbx + 0x54))); 0x0042a895 jmp 0x42a8dd | | } else { 0x0042a897 mov byte [rbx + 9], 1 | *((rbx + 9)) = 1; 0x0042a89b cmp byte [rbx + 8], 0 | | if (*((rbx + 8)) != 0) { 0x0042a89f je 0x42a8d5 | 0x0042a8a1 mov rdi, qword [rbx] | 0x0042a8a4 mov byte [rsp + 0x10], 0x2c | *((rsp + 0x10)) = 0x2c; 0x0042a8a9 lea rsi, [rsp + 0x10] | 0x0042a8ae mov edx, 1 | 0x0042a8b3 call 0x429230 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (*(rbx), rsp + 0x10, 1); 0x0042a8b8 cmp dword [rbx + 0x4c], 1 | | if (*((rbx + 0x4c)) != 1) { 0x0042a8bc jne 0x42a8d5 | goto label_2; | } 0x0042a8be mov rdi, qword [rbx] | 0x0042a8c1 mov byte [rsp + 0x10], 0xa | *((rsp + 0x10)) = 0xa; 0x0042a8c6 lea rsi, [rsp + 0x10] | 0x0042a8cb mov edx, 1 | 0x0042a8d0 call 0x429230 | std::_1::basic_ostream>&std::_1::_put_character_sequence>(std::_1::basic_ostream>&,char const*,unsigned long) (*(rbx), rsp + 0x10, 1); | } | label_2: 0x0042a8d5 mov byte [rbx + 0xa], 0 | *((rbx + 0xa)) = 0; 0x0042a8d9 mov byte [rbx + 8], 1 | *((rbx + 8)) = 1; | } | label_1: 0x0042a8dd mov r15, qword [rbx] | r15 = *(rbx); 0x0042a8e0 mov dword [rsp + 8], 3 | *((rsp + 8)) = 3; 0x0042a8e8 mov esi, dword [rbx + 0x40] | 0x0042a8eb lea r12, [rsp + 8] | r12 = rsp + 8; 0x0042a8f0 mov rdi, r12 | 0x0042a8f3 call 0x442440 | BloombergLP::bdlt::Iso8601UtilConfiguration::setFractionalSecondPrecision(int) (r12, *((rbx + 0x40))); 0x0042a8f8 lea rbx, [rsp + 0x10] | rbx = rsp + 0x10; 0x0042a8fd mov rdi, rbx | 0x0042a900 mov esi, 0x27 | 0x0042a905 mov rdx, r14 | 0x0042a908 mov rcx, r12 | 0x0042a90b call 0x43ffa0 | BloombergLP::bdlt::Iso8601Util::generate(char*,int,BloombergLP::bdlt::DateTzconst&,BloombergLP::bdlt::Iso8601UtilConfigurationconst&) (rbx, 0x27, r14, r12); 0x0042a910 mov qword [rsp + 0x40], rbx | *((rsp + 0x40)) = rbx; 0x0042a915 mov rdi, rbx | 0x0042a918 call 0x404440 | rax = strlen (rbx); 0x0042a91d mov qword [rsp + 0x48], rax | *((rsp + 0x48)) = rax; 0x0042a922 lea rsi, [rsp + 0x40] | 0x0042a927 mov rdi, r15 | 0x0042a92a call 0x42b280 | BloombergLP::baljsn::PrintUtil::printString(std::_1::basic_ostream>&,std::_1::basic_string_view>const&) (r15, rsp + 0x40); 0x0042a92f add rsp, 0x50 | 0x0042a933 pop rbx | 0x0042a934 pop r12 | 0x0042a936 pop r14 | 0x0042a938 pop r15 | 0x0042a93a pop rbp | 0x0042a93b ret | return rax; | }