18 if (!strncmp(sym,
"_OBJC_Class_", 12)) {
19 const char *className = sym + 12;
22 }
else if (!strncmp(sym,
"_OBJC_CLASS_$_", 14)) {
23 const char *className = sym + 14;
27 if (!strncmp(sym,
"_OBJC_IVAR_$_", 13)) {
30 char *
p = strchr(clas,
'.');
38 }
else if (sym[0] && sym[1] ==
'[') {
42 }
else if (sym[0] ==
'-') {
48 name = strchr(clas,
' ');
68 if (sym[0] ==
'_' && sym[1] && sym[2] ==
'_') {
71 args = strstr(clas,
"__");
95 }
else if (sym[1] ==
'c') {
100 if (!strcmp(
type,
"field")) {
104 const char *
arg =
"int";
char * dem_str_newf(const char *fmt,...)
RZ_API void Ht_() free(HtName_(Ht) *ht)
void * malloc(size_t size)
return strdup("=SP r13\n" "=LR r14\n" "=PC r15\n" "=A0 r0\n" "=A1 r1\n" "=A2 r2\n" "=A3 r3\n" "=ZF zf\n" "=SF nf\n" "=OF vf\n" "=CF cf\n" "=SN or0\n" "gpr lr .32 56 0\n" "gpr pc .32 60 0\n" "gpr cpsr .32 64 0 ____tfiae_________________qvczn\n" "gpr or0 .32 68 0\n" "gpr tf .1 64.5 0 thumb\n" "gpr ef .1 64.9 0 endian\n" "gpr jf .1 64.24 0 java\n" "gpr qf .1 64.27 0 sticky_overflow\n" "gpr vf .1 64.28 0 overflow\n" "gpr cf .1 64.29 0 carry\n" "gpr zf .1 64.30 0 zero\n" "gpr nf .1 64.31 0 negative\n" "gpr itc .4 64.10 0 if_then_count\n" "gpr gef .4 64.16 0 great_or_equal\n" "gpr r0 .32 0 0\n" "gpr r1 .32 4 0\n" "gpr r2 .32 8 0\n" "gpr r3 .32 12 0\n" "gpr r4 .32 16 0\n" "gpr r5 .32 20 0\n" "gpr r6 .32 24 0\n" "gpr r7 .32 28 0\n" "gpr r8 .32 32 0\n" "gpr r9 .32 36 0\n" "gpr r10 .32 40 0\n" "gpr r11 .32 44 0\n" "gpr r12 .32 48 0\n" "gpr r13 .32 52 0\n" "gpr r14 .32 56 0\n" "gpr r15 .32 60 0\n" "gpr r16 .32 64 0\n" "gpr r17 .32 68 0\n")
char * libdemangle_handler_objc(const char *sym)