Opened 11 years ago
Closed 11 years ago
#5507 closed Bugs (fixed)
const char vs. const signed char in boost/archive/iterators/binary_from_base64.hpp
Reported by: | Owned by: | Robert Ramey | |
---|---|---|---|
Milestone: | To Be Determined | Component: | serialization |
Version: | Boost 1.46.1 | Severity: | Problem |
Keywords: | Cc: |
Description
There seems to be a small bug in binary_from_base64.hpp:
CharType operator()(CharType t) const{ const char lookup_table[] = { -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, [...]
However, it's not guaranteed that a "const char" accepts signed values, see e.g. http://www.network-theory.co.uk/docs/gccintro/gccintro_71.html. See also /usr/include/limits.h - depending whether __CHAR_UNSIGNED__
is set or not, the platform may not or may accept negative values for a const char.
Especially when enabling C++0x support, this leads to a compilation failure e.g. on PowerPC:
"powerpc-linux-gnu-g++" -ftemplate-depth-128 -O3 -finline-functions -Wno-inline -Wall -pthread -fPIC -std=c++0x -DBOOST_ALL_NO_LIB=1 -DBOOST_SERIALIZATION_DYN_LINK=1 -DNDEBUG -I"." -c -o "bin.v2/libs/serialization/build/gcc-powerpc/release/threading-multi/basic_text_iprimitive.o" "libs/serialization/src/basic_text_iprimitive.cpp" [...] In file included from ./boost/archive/impl/basic_text_iprimitive.ipp:30:0, from libs/serialization/src/basic_text_iprimitive.cpp:19: [...] ./boost/archive/iterators/binary_from_base64.hpp:51:9: error: narrowing conversion of '-0x00000000000000001' from 'int' to 'const char' inside { }
The following patch fixed the problem for us:
Index: boost_1_46_1/boost/archive/iterators/binary_from_base64.hpp =================================================================== --- boost_1_46_1.orig/boost/archive/iterators/binary_from_base64.hpp +++ boost_1_46_1/boost/archive/iterators/binary_from_base64.hpp @@ -39,7 +39,7 @@ template<class CharType> struct to_6_bit { typedef CharType result_type; CharType operator()(CharType t) const{ - const char lookup_table[] = { + const signed char lookup_table[] = { -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1, -1,-1,-1,-1,-1,-1,-1,-1,-1,-1,-1,62,-1,-1,-1,63,
Note:
See TracTickets
for help on using tickets.
looks good to me, I'm rolling in your change. It will likely show up in 1.48