[Filesystem] path refuses "foo\bar" on win32/mingw
data:image/s3,"s3://crabby-images/47d60/47d606555ffe98581e5c99e015b2d81dda75df17" alt=""
When passing "foo\bar" to boost::filesystem::path constructor, it is
accepted when compiled with MSVC, but is refused when compiled with
mingw-gcc (v3.4.2). "foo/bar" argument is accepted with both
compilers.
Test-case:
#include
data:image/s3,"s3://crabby-images/47d60/47d606555ffe98581e5c99e015b2d81dda75df17" alt=""
On 7/18/05, Alo Sarv
Compiled with: g++ -I c:\boostcvs\include\boost-1_33 -L c:\boostcvs\lib test-path.cpp -o test-path -lboost_filesystem-mgw-d Tested against: Boost 1.32 release, CVS HEAD
After some more searching, I found that it's actually dll builds that break on mingw - static builds work fine - all dll tests on file_system library seem to be skipped on mingw as well ... why? Alo
data:image/s3,"s3://crabby-images/38195/38195f274c7e0d93b6d5b1b3b55febfd81458447" alt=""
"Alo Sarv"
On 7/18/05, Alo Sarv
wrote: Compiled with: g++ -I c:\boostcvs\include\boost-1_33 -L c:\boostcvs\lib test-path.cpp -o test-path -lboost_filesystem-mgw-d Tested against: Boost 1.32 release, CVS HEAD
After some more searching, I found that it's actually dll builds that break on mingw - static builds work fine - all dll tests on file_system library seem to be skipped on mingw as well ... why?
It looks as if mingw ::GetLastError() is returning 0 rather than the correct error code under some conditions. Furthermore, some versions of gcc fail to deal with function address comparisons correctly across dll boundaries. I'm not sure which bug has bitten you. At least that is the appearance. I haven't had time to verify the bug or determine the exact conditions and versions involved, so if you want to track the problem down and file a bug report, that would be helpful. Thanks, --Beman
participants (2)
-
Alo Sarv
-
Beman Dawes