/src/capstonev5/SStream.c
Line | Count | Source (jump to first uncovered line) |
1 | | /* Capstone Disassembly Engine */ |
2 | | /* By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2019 */ |
3 | | |
4 | | #include <stdarg.h> |
5 | | #if defined(CAPSTONE_HAS_OSXKERNEL) |
6 | | #include <Availability.h> |
7 | | #include <libkern/libkern.h> |
8 | | #include <i386/limits.h> |
9 | | #else |
10 | | #include <stdio.h> |
11 | | #include <limits.h> |
12 | | #endif |
13 | | #include <string.h> |
14 | | |
15 | | #include <capstone/platform.h> |
16 | | |
17 | | #include "SStream.h" |
18 | | #include "cs_priv.h" |
19 | | #include "utils.h" |
20 | | |
21 | | #ifdef _MSC_VER |
22 | | #pragma warning(disable: 4996) // disable MSVC's warning on strcpy() |
23 | | #endif |
24 | | |
25 | | void SStream_Init(SStream *ss) |
26 | 3.06M | { |
27 | 3.06M | ss->index = 0; |
28 | 3.06M | ss->buffer[0] = '\0'; |
29 | 3.06M | } |
30 | | |
31 | | void SStream_concat0(SStream *ss, const char *s) |
32 | 14.2M | { |
33 | 14.2M | #ifndef CAPSTONE_DIET |
34 | 14.2M | unsigned int len = (unsigned int) strlen(s); |
35 | | |
36 | 14.2M | memcpy(ss->buffer + ss->index, s, len); |
37 | 14.2M | ss->index += len; |
38 | 14.2M | ss->buffer[ss->index] = '\0'; |
39 | 14.2M | #endif |
40 | 14.2M | } |
41 | | |
42 | | void SStream_concat1(SStream *ss, const char c) |
43 | 415k | { |
44 | 415k | #ifndef CAPSTONE_DIET |
45 | 415k | ss->buffer[ss->index] = c; |
46 | 415k | ss->index++; |
47 | 415k | ss->buffer[ss->index] = '\0'; |
48 | 415k | #endif |
49 | 415k | } |
50 | | |
51 | | void SStream_concat(SStream *ss, const char *fmt, ...) |
52 | 4.12M | { |
53 | 4.12M | #ifndef CAPSTONE_DIET |
54 | 4.12M | va_list ap; |
55 | 4.12M | int ret; |
56 | | |
57 | 4.12M | va_start(ap, fmt); |
58 | 4.12M | ret = cs_vsnprintf(ss->buffer + ss->index, sizeof(ss->buffer) - (ss->index + 1), fmt, ap); |
59 | 4.12M | va_end(ap); |
60 | 4.12M | ss->index += ret; |
61 | 4.12M | #endif |
62 | 4.12M | } |
63 | | |
64 | | // print number with prefix # |
65 | | void printInt64Bang(SStream *O, int64_t val) |
66 | 58.2k | { |
67 | 58.2k | if (val >= 0) { |
68 | 33.0k | if (val > HEX_THRESHOLD) |
69 | 28.6k | SStream_concat(O, "#0x%"PRIx64, val); |
70 | 4.45k | else |
71 | 4.45k | SStream_concat(O, "#%"PRIu64, val); |
72 | 33.0k | } else { |
73 | 25.1k | if (val <- HEX_THRESHOLD) { |
74 | 22.7k | if (val == LONG_MIN) |
75 | 105 | SStream_concat(O, "#-0x%"PRIx64, (uint64_t)val); |
76 | 22.6k | else |
77 | 22.6k | SStream_concat(O, "#-0x%"PRIx64, (uint64_t)-val); |
78 | 22.7k | } else |
79 | 2.44k | SStream_concat(O, "#-%"PRIu64, -val); |
80 | 25.1k | } |
81 | 58.2k | } |
82 | | |
83 | | void printUInt64Bang(SStream *O, uint64_t val) |
84 | 79.7k | { |
85 | 79.7k | if (val > HEX_THRESHOLD) |
86 | 50.4k | SStream_concat(O, "#0x%"PRIx64, val); |
87 | 29.2k | else |
88 | 29.2k | SStream_concat(O, "#%"PRIu64, val); |
89 | 79.7k | } |
90 | | |
91 | | // print number |
92 | | void printInt64(SStream *O, int64_t val) |
93 | 230k | { |
94 | 230k | if (val >= 0) { |
95 | 172k | if (val > HEX_THRESHOLD) |
96 | 139k | SStream_concat(O, "0x%"PRIx64, val); |
97 | 32.8k | else |
98 | 32.8k | SStream_concat(O, "%"PRIu64, val); |
99 | 172k | } else { |
100 | 58.1k | if (val <- HEX_THRESHOLD) { |
101 | 54.2k | if (val == LONG_MIN) |
102 | 0 | SStream_concat(O, "-0x%"PRIx64, (uint64_t)val); |
103 | 54.2k | else |
104 | 54.2k | SStream_concat(O, "-0x%"PRIx64, (uint64_t)-val); |
105 | 54.2k | } else |
106 | 3.82k | SStream_concat(O, "-%"PRIu64, -val); |
107 | 58.1k | } |
108 | 230k | } |
109 | | |
110 | | void printUInt64(SStream *O, uint64_t val) |
111 | 9.17k | { |
112 | 9.17k | if (val > HEX_THRESHOLD) |
113 | 9.03k | SStream_concat(O, "0x%"PRIx64, val); |
114 | 139 | else |
115 | 139 | SStream_concat(O, "%"PRIu64, val); |
116 | 9.17k | } |
117 | | |
118 | | // print number in decimal mode |
119 | | void printInt32BangDec(SStream *O, int32_t val) |
120 | 13.7k | { |
121 | 13.7k | if (val >= 0) |
122 | 13.7k | SStream_concat(O, "#%u", val); |
123 | 0 | else { |
124 | 0 | if (val == INT_MIN) |
125 | 0 | SStream_concat(O, "#-%u", val); |
126 | 0 | else |
127 | 0 | SStream_concat(O, "#-%u", (uint32_t)-val); |
128 | 0 | } |
129 | 13.7k | } |
130 | | |
131 | | void printInt32Bang(SStream *O, int32_t val) |
132 | 194k | { |
133 | 194k | if (val >= 0) { |
134 | 192k | if (val > HEX_THRESHOLD) |
135 | 112k | SStream_concat(O, "#0x%x", val); |
136 | 80.0k | else |
137 | 80.0k | SStream_concat(O, "#%u", val); |
138 | 192k | } else { |
139 | 1.63k | if (val <- HEX_THRESHOLD) { |
140 | 1.25k | if (val == INT_MIN) |
141 | 69 | SStream_concat(O, "#-0x%x", (uint32_t)val); |
142 | 1.18k | else |
143 | 1.18k | SStream_concat(O, "#-0x%x", (uint32_t)-val); |
144 | 1.25k | } else |
145 | 380 | SStream_concat(O, "#-%u", -val); |
146 | 1.63k | } |
147 | 194k | } |
148 | | |
149 | | void printInt32(SStream *O, int32_t val) |
150 | 106k | { |
151 | 106k | if (val >= 0) { |
152 | 91.3k | if (val > HEX_THRESHOLD) |
153 | 31.6k | SStream_concat(O, "0x%x", val); |
154 | 59.7k | else |
155 | 59.7k | SStream_concat(O, "%u", val); |
156 | 91.3k | } else { |
157 | 14.9k | if (val <- HEX_THRESHOLD) { |
158 | 14.6k | if (val == INT_MIN) |
159 | 80 | SStream_concat(O, "-0x%x", (uint32_t)val); |
160 | 14.5k | else |
161 | 14.5k | SStream_concat(O, "-0x%x", (uint32_t)-val); |
162 | 14.6k | } else |
163 | 305 | SStream_concat(O, "-%u", -val); |
164 | 14.9k | } |
165 | 106k | } |
166 | | |
167 | | void printUInt32Bang(SStream *O, uint32_t val) |
168 | 223k | { |
169 | 223k | if (val > HEX_THRESHOLD) |
170 | 186k | SStream_concat(O, "#0x%x", val); |
171 | 36.9k | else |
172 | 36.9k | SStream_concat(O, "#%u", val); |
173 | 223k | } |
174 | | |
175 | | void printUInt32(SStream *O, uint32_t val) |
176 | 78.0k | { |
177 | 78.0k | if (val > HEX_THRESHOLD) |
178 | 24.7k | SStream_concat(O, "0x%x", val); |
179 | 53.3k | else |
180 | 53.3k | SStream_concat(O, "%u", val); |
181 | 78.0k | } |