[Boost-bugs] [Boost C++ Libraries] #7374: Boost ASIO has a wrong swprintf interface definition for MinGW 4.7.0

Subject: [Boost-bugs] [Boost C++ Libraries] #7374: Boost ASIO has a wrong swprintf interface definition for MinGW 4.7.0
From: Boost C++ Libraries (noreply_at_[hidden])
Date: 2012-09-13 19:25:02


#7374: Boost ASIO has a wrong swprintf interface definition for MinGW 4.7.0
-----------------------------------------------------------+----------------
 Reporter: Lukas Dürrenberger <eXpl0it3r@…> | Owner: chris_kohlhoff
     Type: Bugs | Status: new
Milestone: To Be Determined | Component: asio
  Version: Boost Development Trunk | Severity: Showstopper
 Keywords: asio, mingw, gcc 4.7.0, swprintf, decleration |
-----------------------------------------------------------+----------------
 In the file
 [http://svn.boost.org/svn/boost/trunk/boost/asio/detail/impl/win_static_mutex.ipp
 win_static_mutex.ipp] on the lines 45-51 one can read:

 {{{
 #!c++
 #if BOOST_WORKAROUND(BOOST_MSVC, >= 1400) && !defined(UNDER_CE)
   swprintf_s(mutex_name, 128,
 #else // BOOST_WORKAROUND(BOOST_MSVC, >= 1400) && !defined(UNDER_CE)
   swprintf(mutex_name,
 #endif // BOOST_WORKAROUND(BOOST_MSVC, >= 1400) && !defined(UNDER_CE)
       L"asio-58CCDC44-6264-4842-90C2-F3C545CB8AA7-%u-%p",
       static_cast<unsigned int>(::GetCurrentProcessId()), this);
 }}}

 As one can see there are two different signatures. The first one is for
 Visual Studio's swprintf_s function and the second one should be for the
 rest, but this function is declared differently in MinGW and also takes an
 integer as second argument.
 The correct interface is declared in MinGW's libintl.h header on line 419
 as following:
 {{{
 #!c++
 extern int swprintf (wchar_t *, size_t, const wchar_t *, ...);
 }}}

 That deceleration is also what the C99 standard declares:
 [http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1124.pdf §7.24.2.3 (p.
 362)]

 A fix would either involve to change the #else statement completely to add
 a second parameter as with swprintf_s or another check for MinGW.
 Probably the better solution would be to completely eliminate the swprintf
 function and make use of streams.

 If tested the version 1.49, 1.50 and 1.51 and for all, my application
 fails to build with GCC 4.7.0, simply by including the ASIO header. Thus a
 minimal example would be:

 {{{
 #!c++
 #include <boost/asio.hpp>
 int main()
 {
 }
 }}}

-- 
Ticket URL: <https://svn.boost.org/trac/boost/ticket/7374>
Boost C++ Libraries <http://www.boost.org/>
Boost provides free peer-reviewed portable C++ source libraries.

This archive was generated by hypermail 2.1.7 : 2017-02-16 18:50:10 UTC