C++ Template Metaprogramming
data:image/s3,"s3://crabby-images/b4e66/b4e6618abd88571690777d58d3e735c7f53bb18c" alt=""
For the past year Aleksey Gurtovoy and I have been working on a new book, titled _C++ Template Metaprogramming: Concepts, Tools and Techniques from Boost and Beyond_. The book has recently entered copyediting. If you're interested you can peruse some sample chapters at http://boost-consulting.com/mplbook. Regards, Dave -- Dave Abrahams Boost Consulting http://www.boost-consulting.com
data:image/s3,"s3://crabby-images/4645e/4645e9c5dc66bba6084ab091cbbd6570d0cfb84e" alt=""
Ok this is bit off topic since it isn't directly related to boost, but I know there are a lot C++ guru's here, and I'm sure one of you has addressed this. I am using Andrei's ScopeGuard and not boosts. I have googled, but I haven't figured out how to turn off the "unused variable" warning in g++, with out disabling all warnings. My guess is that there is no solution, but I thought I would try here first. TIA, Christopher
data:image/s3,"s3://crabby-images/2c13e/2c13e1e9810bfe68bd1f2a18fbe3b0e3603168c1" alt=""
Christopher Baus wrote:
Ok this is bit off topic since it isn't directly related to boost, but I know there are a lot C++ guru's here, and I'm sure one of you has addressed this.
I am using Andrei's ScopeGuard and not boosts. I have googled, but I haven't figured out how to turn off the "unused variable" warning in g++, with out disabling all warnings. My guess is that there is no solution, but I thought I would try here first.
Unless I'm missing something, this should do the trick: g++ -c -O2 -Wall -Wno-unused-variable foo.cpp Hope this helps, Stephen Jackson
data:image/s3,"s3://crabby-images/4645e/4645e9c5dc66bba6084ab091cbbd6570d0cfb84e" alt=""
Unless I'm missing something, this should do the trick:
g++ -c -O2 -Wall -Wno-unused-variable foo.cpp
I was hoping there was some way to modify ON_BLOCK_EXIT, so I could leave the unused variable warning, but only disable it for ScopeGuard with a pragma.
data:image/s3,"s3://crabby-images/4645e/4645e9c5dc66bba6084ab091cbbd6570d0cfb84e" alt=""
Unless I'm missing something, this should do the trick:
g++ -c -O2 -Wall -Wno-unused-variable foo.cpp
Ok, I found the solution. I was looking for a pragma to do it, but the solution for gcc is the use the unused attribute.
Cheers, Christopher
data:image/s3,"s3://crabby-images/9f28a/9f28a86445be16ad8bbc5c629fb86cc41d1c01fc" alt=""
"Christopher Baus"
Unless I'm missing something, this should do the trick:
g++ -c -O2 -Wall -Wno-unused-variable foo.cpp
Ok, I found the solution. I was looking for a pragma to do it, but the solution for gcc is the use the unused attribute.
I think an idiomatic solution is : int unused ; unused ; --drkm, en recherche d'un stage : http://www.fgeorges.org/ipl/stage.html
data:image/s3,"s3://crabby-images/5eaf0/5eaf0f7b5ebab294e74424d04414e09c35d0c4e8" alt=""
"drkm"
Unless I'm missing something, this should do the trick:
g++ -c -O2 -Wall -Wno-unused-variable foo.cpp
Ok, I found the solution. I was looking for a pragma to do it, but the solution for gcc is the use the unused attribute.
I think an idiomatic solution is : int unused ; unused ; Rene Rivera proposed this: namespace boost { namespace detail { inline void no_unused_variable_warning(void*) { } } } #define BOOST_NO_UNUSED_VARIABLE_WARNING(v) \ ::boost::detail::no_unused_variable_warning(&(v)) See namespace boost { namespace detail { inline void no_unused_variable_warning(void*) { } } } http://lists.boost.org/MailArchives/boost/msg54904.phpJonathan
data:image/s3,"s3://crabby-images/5eaf0/5eaf0f7b5ebab294e74424d04414e09c35d0c4e8" alt=""
"Christopher Baus"
Ok this is bit off topic since it isn't directly related to boost, but I know there are a lot C++ guru's here, and I'm sure one of you has addressed this.
I am using Andrei's ScopeGuard and not boosts. I have googled, but I haven't figured out how to turn off the "unused variable" warning in g++, with out disabling all warnings. My guess is that there is no solution, but I thought I would try here first.
Joaquín M López Muñoz has a version of Anrei's scope guard in his recently accepted multi_index library. To prevent these warnings, he adds a no-op member void touch() cont { } to scope_guard_impl_base. Then, in his version of ON_BLOCK_EXIT (which is customized for his library, and so not generally useful) expands to something like this: const scope_guard_impl_base& guard = make_guard( ... ); guard.touch(); Jonathan
data:image/s3,"s3://crabby-images/4645e/4645e9c5dc66bba6084ab091cbbd6570d0cfb84e" alt=""
Then, in his version of ON_BLOCK_EXIT (which is customized for his library, and so not generally useful) expands to something like this:
const scope_guard_impl_base& guard = make_guard( ... ); guard.touch();
That's probably a better solution than using compiler dependant switches.
data:image/s3,"s3://crabby-images/5eaf0/5eaf0f7b5ebab294e74424d04414e09c35d0c4e8" alt=""
"Christopher Baus"
Then, in his version of ON_BLOCK_EXIT (which is customized for his library, and so not generally useful) expands to something like this:
const scope_guard_impl_base& guard = make_guard( ... ); guard.touch();
That's probably a better solution than using compiler dependant switches.
Yep. It should suppress warnings on other compilers too, and makes the code easier to understand. Jonathan
participants (5)
-
Christopher Baus
-
David Abrahams
-
drkm
-
Jonathan Turkanis
-
Stephen Jackson