; assembly | /* r2dec pseudo code output */ | /* ball_recordjsonformatter.t/assume @ 0x41b350 */ | #include | ; (fcn) method.BloombergLP::ball._anonymous_namespace_::AttributeFormatter::parse_BloombergLP::bdld::DatumMapRef_ () | uint64_t method_BloombergLP::ball_anonymous_namespace_::AttributeFormatter::parse_BloombergLP::bdld::DatumMapRef_ (int64_t arg_40h, int64_t arg_48h, int64_t arg1) { | rdi = arg1; | /* BloombergLP::ball::(anonymous namespace)::AttributeFormatter::parse(BloombergLP::bdld::DatumMapRef) */ 0x0041b350 push rbp | 0x0041b351 push r15 | 0x0041b353 push r14 | 0x0041b355 push r13 | 0x0041b357 push r12 | 0x0041b359 push rbx | 0x0041b35a push rax | 0x0041b35b mov r12, qword [rsp + 0x48] | r12 = *((rsp + 0x48)); 0x0041b360 test r12, r12 | | if (r12 == 0) { 0x0041b363 je 0x41b40e | goto label_0; | } 0x0041b369 lea rax, [rsp + 0x40] | rax = rsp + 0x40; 0x0041b36e mov rbx, qword [rax] | rbx = *(rax); 0x0041b371 movzx ecx, word [rbx + 0x1e] | ecx = *((rbx + 0x1e)); 0x0041b375 mov eax, 0xffffffff | eax = 0xffffffff; 0x0041b37a mov r13d, 0x4030 | r13d = 0x4030; 0x0041b380 bt r13, rcx | | if (((r13 >> rcx) & 1) >= 0) { 0x0041b384 jae 0x41b410 | goto label_1; | } 0x0041b38a mov r15, rdi | r15 = rdi; 0x0041b38d lea rax, [rdi + 8] | rax = rdi + 8; 0x0041b391 mov qword [rsp], rax | *(rsp) = rax; 0x0041b395 mov eax, 1 | eax = 1; 0x0041b39a nop word [rax + rax] | | do { 0x0041b3a0 mov rbp, rax | 0x0041b3a3 cmp qword [rbx + 8], 4 | | if (*((rbx + 8)) == 4) { 0x0041b3a8 jne 0x41b3f0 | 0x0041b3aa mov rax, qword [rbx] | rax = *(rbx); 0x0041b3ad cmp dword [rax], 0x656d616e | | if (*(rax) != 0x656d616e) { 0x0041b3b3 jne 0x41b3f0 | goto label_2; | } 0x0041b3b5 movsx eax, cx | eax = (int32_t) cx; 0x0041b3b8 cmp eax, 0xe | | if (eax != 0xe) { 0x0041b3bb je 0x41b3c2 | 0x0041b3bd cmp eax, 5 | | if (eax != 5) { 0x0041b3c0 jne 0x41b3cc | goto label_3; | } | } 0x0041b3c2 mov rsi, qword [rbx + 0x10] | rsi = *((rbx + 0x10)); 0x0041b3c6 movsxd rdx, dword [rbx + 0x18] | rdx = *((rbx + 0x18)); 0x0041b3ca jmp 0x41b3d5 | goto label_4; | label_3: 0x0041b3cc lea rsi, [rbx + 0x11] | 0x0041b3d0 movsx rdx, byte [rbx + 0x10] | rdx = *((rbx + 0x10)); | label_4: 0x0041b3d5 mov r14, qword [r15 + 0x20] | r14 = *((r15 + 0x20)); 0x0041b3d9 mov qword [r15 + 0x20], 0 | *((r15 + 0x20)) = 0; 0x0041b3e1 mov ecx, 0x49a434 | 0x0041b3e6 mov rdi, qword [rsp] | 0x0041b3ea call 0x4753c0 | bsl::basic_string,bsl::allocator>::privateAppend(char const*,unsigned long,char const*) (*(rsp), rbx + 0x11, rdx, "string<>::operator=(basic_string_view&): string too long"); 0x0041b3ef nop | | } | label_2: 0x0041b3f0 cmp r12, rbp | | if (r12 == rbp) { 0x0041b3f3 je 0x41b407 | goto label_5; | } 0x0041b3f5 movzx ecx, word [rbx + 0x3e] | ecx = *((rbx + 0x3e)); 0x0041b3f9 add rbx, 0x20 | rbx += 0x20; 0x0041b3fd lea rax, [rbp + 1] | rax = rbp + 1; 0x0041b401 bt r13, rcx | 0x0041b405 jb 0x41b3a0 | | } while (((r13 >> rcx) & 1) < 0); | label_5: 0x0041b407 cmp rbp, r12 | 0x0041b40a sbb eax, eax | eax -= eax; 0x0041b40c jmp 0x41b410 | goto label_1; | label_0: 0x0041b40e xor eax, eax | eax = 0; | label_1: 0x0041b410 add rsp, 8 | 0x0041b414 pop rbx | 0x0041b415 pop r12 | 0x0041b417 pop r13 | 0x0041b419 pop r14 | 0x0041b41b pop r15 | 0x0041b41d pop rbp | 0x0041b41e ret | return rax; | }