2
1
mirror of https://github.com/qpdf/qpdf.git synced 2025-01-05 08:02:11 +00:00

Remove all calls to sprintf

This commit is contained in:
Jay Berkenbilt 2013-02-28 16:20:45 -05:00
parent 66c3c8fdf7
commit a51ae10b8d
6 changed files with 43 additions and 22 deletions

View File

@ -1,3 +1,10 @@
2013-02-28 Jay Berkenbilt <ejb@ql.org>
* Remove all calls to sprintf
* New method QUtil::int_to_string_base to convert to octal or
hexademical (or decimal) strings without using sprintf
2013-02-26 Jay Berkenbilt <ejb@ql.org> 2013-02-26 Jay Berkenbilt <ejb@ql.org>
* Rewrite QUtil::int_to_string and QUtil::double_to_string to * Rewrite QUtil::int_to_string and QUtil::double_to_string to

View File

@ -22,6 +22,8 @@ namespace QUtil
QPDF_DLL QPDF_DLL
std::string int_to_string(long long, int length = 0); std::string int_to_string(long long, int length = 0);
QPDF_DLL QPDF_DLL
std::string int_to_string_base(long long, int base, int length = 0);
QPDF_DLL
std::string double_to_string(double, int decimal_places = 0); std::string double_to_string(double, int decimal_places = 0);
QPDF_DLL QPDF_DLL

View File

@ -95,7 +95,6 @@ QPDF_String::unparse(bool force_binary)
else else
{ {
result += "("; result += "(";
char num[5];
for (unsigned int i = 0; i < this->val.length(); ++i) for (unsigned int i = 0; i < this->val.length(); ++i)
{ {
char ch = this->val[i]; char ch = this->val[i];
@ -140,8 +139,9 @@ QPDF_String::unparse(bool force_binary)
} }
else else
{ {
sprintf(num, "\\%03o", static_cast<unsigned char>(ch)); // XXXX result += "\\" + QUtil::int_to_string_base(
result += num; static_cast<int>(static_cast<unsigned char>(ch)),
8, 3);
} }
break; break;
} }

View File

@ -24,11 +24,23 @@
std::string std::string
QUtil::int_to_string(long long num, int length) QUtil::int_to_string(long long num, int length)
{ {
// Backward compatibility -- this function used to use sprintf return int_to_string_base(num, 10, length);
// with %0*d, so we interpret length such that a negative value }
// appends spaces and a positive value prepends zeroes.
std::string
QUtil::int_to_string_base(long long num, int base, int length)
{
// Backward compatibility -- int_to_string, which calls this
// function, used to use sprintf with %0*d, so we interpret length
// such that a negative value appends spaces and a positive value
// prepends zeroes.
if (! ((base == 8) || (base == 10) || (base == 16)))
{
throw std::logic_error(
"int_to_string_base called with unsupported base");
}
std::ostringstream buf; std::ostringstream buf;
buf << num; buf << std::setbase(base) << std::nouppercase << num;
std::string result; std::string result;
if ((length > 0) && if ((length > 0) &&
(buf.str().length() < static_cast<size_t>(length))) (buf.str().length() < static_cast<size_t>(length)))
@ -152,16 +164,13 @@ QUtil::copy_string(std::string const& str)
std::string std::string
QUtil::hex_encode(std::string const& input) QUtil::hex_encode(std::string const& input)
{ {
size_t input_size = input.length(); std::string result;
size_t hex_size = 1 + (2 * input_size); for (unsigned int i = 0; i < input.length(); ++i)
PointerHolder<char> bufp(true, new char[hex_size]);
char* buf = bufp.getPointer();
buf[hex_size - 1] = '\0';
for (unsigned int i = 0; i < input_size; ++i)
{ {
sprintf(buf + i * 2, "%02x", static_cast<unsigned char>(input[i])); // XXXX result += QUtil::int_to_string_base(
static_cast<int>(static_cast<unsigned char>(input[i])), 16, 2);
} }
return buf; return result;
} }
void void

View File

@ -8,6 +8,9 @@
0.00012 0.00012
0.12346 0.12346
0.00012 0.00012
16059
37273
3ebb
one one
7 7
compare okay compare okay

View File

@ -23,7 +23,10 @@ void string_conversion_test()
<< QUtil::double_to_string(.1234, 5) << std::endl << QUtil::double_to_string(.1234, 5) << std::endl
<< QUtil::double_to_string(.0001234, 5) << std::endl << QUtil::double_to_string(.0001234, 5) << std::endl
<< QUtil::double_to_string(.123456, 5) << std::endl << QUtil::double_to_string(.123456, 5) << std::endl
<< QUtil::double_to_string(.000123456, 5) << std::endl; << QUtil::double_to_string(.000123456, 5) << std::endl
<< QUtil::int_to_string_base(16059, 10) << std::endl
<< QUtil::int_to_string_base(16059, 8) << std::endl
<< QUtil::int_to_string_base(16059, 16) << std::endl;
std::string embedded_null = "one"; std::string embedded_null = "one";
embedded_null += '\0'; embedded_null += '\0';
@ -86,10 +89,8 @@ void getenv_test()
static void print_utf8(unsigned long val) static void print_utf8(unsigned long val)
{ {
char t[20];
sprintf(t, "%lx", val); // XXXX
std::string result = QUtil::toUTF8(val); std::string result = QUtil::toUTF8(val);
std::cout << "0x" << t << " ->"; std::cout << "0x" << QUtil::int_to_string_base(val, 16) << " ->";
if (val < 0xfffe) if (val < 0xfffe)
{ {
std::cout << " " << result; std::cout << " " << result;
@ -102,9 +103,8 @@ static void print_utf8(unsigned long val)
for (std::string::iterator iter = result.begin(); for (std::string::iterator iter = result.begin();
iter != result.end(); ++iter) iter != result.end(); ++iter)
{ {
char t[3]; std::cout << " " << QUtil::int_to_string_base(
sprintf(t, "%02x", static_cast<unsigned char>(*iter)); // XXXX static_cast<int>(static_cast<unsigned char>(*iter)), 16, 2);
std::cout << " " << t;
} }
} }
std::cout << std::endl; std::cout << std::endl;