Rizin
unix-like reverse engineering framework and cli tools
cxx.c
Go to the documentation of this file.
1 // SPDX-FileCopyrightText: 2013-2019 pancake <pancake@nopcode.org>
2 // SPDX-License-Identifier: LGPL-3.0-only
3 #include "demangler_util.h"
4 #include "cxx/demangle.h"
5 #include <rz_libdemangle.h>
6 
7 #if WITH_GPL
8 #define SL(x) \
9  { x, strlen(x) }
10 
11 typedef struct cxx_prefix_t {
12  const char *name;
13  uint32_t size;
14 } CxxPrefix;
15 
16 char *libdemangle_handler_cxx(const char *str) {
17  // DMGL_TYPES | DMGL_PARAMS | DMGL_ANSI | DMGL_VERBOSE | DMGL_RET_POSTFIX | DMGL_TYPES;
18  uint32_t i;
19 
21  CxxPrefix prefixes[] = {
22  SL("__symbol_stub1_"),
23  SL("reloc."),
24  SL("sym.imp."),
25  SL("imp."),
26  { NULL, 0 }
27  };
28  char *tmpstr = strdup(str);
29  char *p = tmpstr;
30 
31  if (p[0] == p[1] && *p == '_') {
32  p++;
33  }
34  for (i = 0; prefixes[i].name; i++) {
35  if (!strncmp(p, prefixes[i].name, prefixes[i].size)) {
36  p += prefixes[i].size;
37  break;
38  }
39  }
40  // remove CXXABI suffix
41  char *cxxabi = strstr(p, "@@CXXABI");
42  char *glibcxx = strstr(p, "@GLIBCXX");
43  if (cxxabi) {
44  *cxxabi = '\0';
45  } else if (glibcxx) {
46  if (p < glibcxx && glibcxx[-1] == '@') {
47  glibcxx[-1] = '\0';
48  } else {
49  *glibcxx = '\0';
50  }
51  }
52 
53  uint32_t len = strlen(p);
54  uint32_t _ptrlen = strlen("_ptr");
55  if (len > _ptrlen && !strncmp(p + len - _ptrlen, "_ptr", _ptrlen)) {
56  // remove _ptr from the end
57  *(p + len - _ptrlen) = '\0';
58  } else if (len > 1 && IS_DIGIT(*(p + len - 1))) {
59  // removes version sequences like _5_2 or _18_4 etc... from the end
60  bool expect_digit = true;
61  bool expect_underscore = false;
62  for (i = len - 1; i > 0; i--) {
63  if (expect_digit && IS_DIGIT(p[i])) {
64  if (i == 0) {
65  break;
66  } else if (p[i - 1] == '_') {
67  expect_underscore = true;
68  expect_digit = false;
69  } else if (!IS_DIGIT(p[i - 1])) {
70  break;
71  }
72  } else if (expect_underscore && p[i] == '_') {
73  p[i] = '\0';
74  if (!IS_DIGIT(p[i - 1])) {
75  break;
76  } else {
77  expect_underscore = false;
78  expect_digit = true;
79  }
80  }
81  }
82  }
83 
84  char *out = cplus_demangle_v3(p, flags);
85  free(tmpstr);
86  return out;
87 }
88 #endif
size_t len
Definition: 6502dis.c:15
lzma_index ** i
Definition: index.h:629
const lzma_allocator const uint8_t size_t uint8_t * out
Definition: block.h:528
char * cplus_demangle_v3(const char *mangled, int options)
Definition: cp-demangle.c:5942
#define NULL
Definition: cris-opc.c:27
#define DMGL_PARAMS
Definition: demangle.h:43
#define DMGL_NO_OPTS
Definition: demangle.h:42
RZ_API void Ht_() free(HtName_(Ht) *ht)
Definition: ht_inc.c:130
voidpf void uLong size
Definition: ioapi.h:138
void * p
Definition: libc.cpp:67
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")
const char * name
Definition: op.c:541
#define IS_DIGIT(x)
Definition: rz_str_util.h:11
static struct sockaddr static addrlen static backlog const void static flags void flags
Definition: sfsocketcall.h:123
unsigned int uint32_t
Definition: sftypes.h:29
Definition: z80asm.h:102