Fix a bug in hex_to_ascii().

This commit is contained in:
garenchan 2018-11-28 19:18:39 +08:00
parent 7aff64740e
commit b53590fe3a
2 changed files with 4 additions and 12 deletions

View File

@ -25,18 +25,14 @@ void hex_to_ascii(int n, char str[]) {
s32 tmp; s32 tmp;
int i; int i;
for (i = 28; i > 0; i -= 4) { for (i = 28; i >= 0; i -= 4) {
tmp = (n >> i) & 0xF; tmp = (n >> i) & 0xF;
if (tmp == 0 && zeros == 0) continue; if (tmp == 0 && zeros == 0) continue;
zeros = 1; zeros = 1;
if (tmp > 0xA) append(str, tmp - 0xA + 'a');
else append(str, tmp + '0');
}
tmp = n & 0xF;
if (tmp >= 0xA) append(str, tmp - 0xA + 'a'); if (tmp >= 0xA) append(str, tmp - 0xA + 'a');
else append(str, tmp + '0'); else append(str, tmp + '0');
} }
}
/* K&R */ /* K&R */
void reverse(char s[]) { void reverse(char s[]) {

View File

@ -25,18 +25,14 @@ void hex_to_ascii(int n, char str[]) {
int32_t tmp; int32_t tmp;
int i; int i;
for (i = 28; i > 0; i -= 4) { for (i = 28; i >= 0; i -= 4) {
tmp = (n >> i) & 0xF; tmp = (n >> i) & 0xF;
if (tmp == 0 && zeros == 0) continue; if (tmp == 0 && zeros == 0) continue;
zeros = 1; zeros = 1;
if (tmp > 0xA) append(str, tmp - 0xA + 'a');
else append(str, tmp + '0');
}
tmp = n & 0xF;
if (tmp >= 0xA) append(str, tmp - 0xA + 'a'); if (tmp >= 0xA) append(str, tmp - 0xA + 'a');
else append(str, tmp + '0'); else append(str, tmp + '0');
} }
}
/* K&R */ /* K&R */
void reverse(char s[]) { void reverse(char s[]) {