mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-24 22:58:21 +00:00
Fix printf problems with high ascii characters after r413586 (1.8).
In r413586 (1.8) various casts were added to silence gcc 4.10 warnings. Those fixes included things like: -out += sprintf(out, "%%%02X", (unsigned char) *ptr); +out += sprintf(out, "%%%02X", (unsigned) *ptr); That works for low ascii characters, but for the high range that yields e.g. FFFFFFC3 when C3 is expected. This changeset: - fixes those casts to use the 'hh' unsigned char modifier instead - consistently uses %02x instead of %2.2x (or other non-standard usage) - adds a few 'h' modifiers in various places - fixes a 'replcaes' typo - dev/urandon typo (in 13+ patch) Review: https://reviewboard.asterisk.org/r/4263/ ASTERISK-24619 #close Reported by: Stefan27 (on IRC) ........ Merged revisions 429673 from http://svn.asterisk.org/svn/asterisk/branches/11 ........ Merged revisions 429674 from http://svn.asterisk.org/svn/asterisk/branches/12 ........ Merged revisions 429675 from http://svn.asterisk.org/svn/asterisk/branches/13 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@429683 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
10
main/utils.c
10
main/utils.c
@@ -251,7 +251,7 @@ void ast_md5_hash(char *output, const char *input)
|
||||
MD5Final(digest, &md5);
|
||||
ptr = output;
|
||||
for (x = 0; x < 16; x++)
|
||||
ptr += sprintf(ptr, "%2.2x", (unsigned)digest[x]);
|
||||
ptr += sprintf(ptr, "%02hhx", digest[x]);
|
||||
}
|
||||
|
||||
/*! \brief Produce 40 char SHA1 hash of value. */
|
||||
@@ -269,7 +269,7 @@ void ast_sha1_hash(char *output, const char *input)
|
||||
SHA1Result(&sha, Message_Digest);
|
||||
ptr = output;
|
||||
for (x = 0; x < 20; x++)
|
||||
ptr += sprintf(ptr, "%2.2x", (unsigned)Message_Digest[x]);
|
||||
ptr += sprintf(ptr, "%02hhx", Message_Digest[x]);
|
||||
}
|
||||
|
||||
/*! \brief Produce a 20 byte SHA1 hash of value. */
|
||||
@@ -420,7 +420,7 @@ char *ast_uri_encode(const char *string, char *outbuf, int buflen, struct ast_fl
|
||||
if (out - outbuf >= buflen - 3) {
|
||||
break;
|
||||
}
|
||||
out += sprintf(out, "%%%02X", (unsigned) *ptr);
|
||||
out += sprintf(out, "%%%02hhX", (unsigned char) *ptr);
|
||||
} else {
|
||||
*out = *ptr; /* Continue copying the string */
|
||||
out++;
|
||||
@@ -2701,10 +2701,10 @@ char *ast_eid_to_str(char *s, int maxlen, struct ast_eid *eid)
|
||||
}
|
||||
} else {
|
||||
for (x = 0; x < 5; x++) {
|
||||
sprintf(s, "%02x:", (unsigned)eid->eid[x]);
|
||||
sprintf(s, "%02hhx:", eid->eid[x]);
|
||||
s += 3;
|
||||
}
|
||||
sprintf(s, "%02x", (unsigned)eid->eid[5]);
|
||||
sprintf(s, "%02hhx", eid->eid[5]);
|
||||
}
|
||||
return os;
|
||||
}
|
||||
|
Reference in New Issue
Block a user