data:image/s3,"s3://crabby-images/57880/57880876522cfdcb105af2f74212010edbb1f793" alt=""
Hi,
we are using boost to develp cross-platform stuff. I am the Mac developer. The Mac is a 64 bit Intel machine, development environment is Xcode, of course, using gcc as compiler.
To create code as robust as possible I always turn on as many warning levels as possible. Usually I am using this:
-Wall -Wextra -Wconversion -Wshorten-64-to-32
This worked great with all basic boost stuff that we've used previously.
Now I tried just to include thread.hpp and I get many many compiler warnings!
I just do:
#include "boost/thread.hpp"
The warnings are just two kinds of warnings:
1.) warning: implicit conversion shortens 64-bit value into a 32-bit value
2.) warning: missing initializer for member '...'
An example for the first warning can be found in gregorian_calender.ipp (just showing relevant parts):
template
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Manfred Schwind wrote:
The second warning is caused by the following line in conversion.hpp:
std::tm datetm = {}; // zero initialization is needed for extension members, like tm_zone
In this line I get the "missing initializer" warning for every member of the struct, e.g. tm::tm_sec, tm::tm_min, tm::tm_hour etc. What's the intension by initializing with empty braces? IMO this is not a standard initialization method.
Yes it is. In Christ, Steven Watanabe
data:image/s3,"s3://crabby-images/4ff2b/4ff2b591c548b8d541192a957ebd1476d1bb98c5" alt=""
I was wondering the same thing, whether or not this was going to be fixed or
if there was a fix without having to change the code in that boost file.
Why was religion brought into this coding thread? I don't understand what
Steven Watanabe is talking about...
--
-Jaime
http://www.jaimerios.com
On Thu, Apr 22, 2010 at 10:55 AM, Steven Watanabe
AMDG
Manfred Schwind wrote:
The second warning is caused by the following line in conversion.hpp:
std::tm datetm = {}; // zero initialization is needed for extension members, like tm_zone
In this line I get the "missing initializer" warning for every member of the struct, e.g. tm::tm_sec, tm::tm_min, tm::tm_hour etc. What's the intension by initializing with empty braces? IMO this is not a standard initialization method.
Yes it is.
In Christ, Steven Watanabe
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/60deb/60deb4d6c10efe00852105496c6edad7a74d2fec" alt=""
On Tue, May 11, 2010 at 7:56 AM, Jaime Rios
I was wondering the same thing, whether or not this was going to be fixed or if there was a fix without having to change the code in that boost file. Why was religion brought into this coding thread? I don't understand what Steven Watanabe is talking about...
He just informs you that { } is a standard form of initialization. In Buddha, Emil Dotchevski Reverge Studios, Inc. http://www.revergestudios.com/reblog/index.php?n=ReCode
data:image/s3,"s3://crabby-images/2d876/2d8761f822017f8aa245a528aea60188ebc194c6" alt=""
Manfred Schwind
This worked great with all basic boost stuff that we've used previously. Now I tried just to include thread.hpp and I get many many compiler warnings! I just do:
#include "boost/thread.hpp"
The warnings are just two kinds of warnings: 1.) warning: implicit conversion shortens 64-bit value into a 32-bit value 2.) warning: missing initializer for member '...'
An example for the first warning can be found in gregorian_calender.ipp (just showing relevant parts):
Most of these warnings are from the Boost.DateTime library, which is used by Boost.Thread. I believe they are all harmless, if annoying. Anthony -- Author of C++ Concurrency in Action http://www.stdthread.co.uk/book/ just::thread C++0x thread library http://www.stdthread.co.uk Just Software Solutions Ltd http://www.justsoftwaresolutions.co.uk 15 Carrallack Mews, St Just, Cornwall, TR19 7UL, UK. Company No. 5478976
data:image/s3,"s3://crabby-images/4cc5c/4cc5cdc63f00c2516ceaf822b1b698b798ee56c1" alt=""
Anthony Williams
Manfred Schwind
writes: #include "boost/thread.hpp"
The warnings are just two kinds of warnings: 1.) warning: implicit conversion shortens 64-bit value into a 32-bit value 2.) warning: missing initializer for member '...'
An example for the first warning can be found in gregorian_calender.ipp
(just showing relevant parts):
Most of these warnings are from the Boost.DateTime library, which is used by Boost.Thread. I believe they are all harmless, if annoying.
Our development group's process specifically disallows any warnings in code before it is released. Some exceptions have been made in intransigent situations, but the warnings mentioned above do not fall into that category. Therefore, we have been forced to wrap thread.hpp's inclusion as follows: #if defined(_MSC_VER) #pragma warning(push,3) #endif // defined(_MSC_VER) #include "boost/thread.hpp" #if defined(_MSC_VER) #pragma warning(pop) #endif // defined(_MSC_VER) Compilation using gcc 4.1.2, even with -Wall, does not elicit the warnings. It's ugly, I know. We could have chosen to compile the entire translation unit, or even project, using warning level 3, but the advantage of compiling at the highest warning level wherever and whenever possible dictated the more focused approach above. Hopefully the code producing these warnings will be fixed in a near release... Geoff Shapiro FLIR Systems, Inc.
participants (6)
-
Anthony Williams
-
Emil Dotchevski
-
Geoff Shapiro
-
Jaime Rios
-
Manfred Schwind
-
Steven Watanabe