[statechart] Template States, Compile Error
data:image/s3,"s3://crabby-images/429af/429aff7ed9a2ef1aa6dbd93f1f3dbdeabdbfb2a6" alt=""
The attached testcase doesn't compile with g++ 4.0.2 or g++ 3.2.3.
The compiler generates a series of error messages like this:
boost/statechart/simple_state.hpp:189: error: no type named
'inner_context_type' in 'struct Test::NormalMode<int>'
I hastily sketched this out based on a larger code. If there
are typos or other mistakes, let me know but the main problem I'm
trying to solve is the "no type named" problem. I typedef it
right in the template definition for NormalMode!
This is using the current CVS for statechart, 1.33.1 for mpl.
Is it possibly a compiler bug?
Thanks!
-Dave
----------------
Testcase
#include
data:image/s3,"s3://crabby-images/7e3eb/7e3eb43d5aaef1e2f42c13e57f17f7f33e8d30f1" alt=""
Hi Dave
The attached testcase doesn't compile with g++ 4.0.2 or g++ 3.2.3. The compiler generates a series of error messages like this:
boost/statechart/simple_state.hpp:189: error: no type named 'inner_context_type' in 'struct Test::NormalMode<int>'
MSVC7.1 gives a similar diagnostic.
I hastily sketched this out based on a larger code. If there are typos or other mistakes, let me know but the main problem I'm trying to solve is the "no type named" problem. I typedef it right in the template definition for NormalMode!
Strange indeed. As you might have noticed, I'm using templated states and machines quite extensively in examples & tests. This should work in principle. I'll look into it.
This is using the current CVS for statechart, 1.33.1 for mpl.
Is it possibly a compiler bug?
I don't think so, see above. Later, -- Andreas Huber When replying by private email, please remove the words spam and trap from the address shown in the header.
data:image/s3,"s3://crabby-images/429af/429aff7ed9a2ef1aa6dbd93f1f3dbdeabdbfb2a6" alt=""
Andreas Huber wrote:
Strange indeed. As you might have noticed, I'm using templated states and machines quite extensively in examples & tests. This should work in principle. I'll look into it.
Thanks. Could you keep me posted on what you find? Boost.Statechart is perfect for the project I'm working on right now and it would be a shame to have to drop it due to this issue. -Dave
data:image/s3,"s3://crabby-images/7e3eb/7e3eb43d5aaef1e2f42c13e57f17f7f33e8d30f1" alt=""
David Greene wrote:
Andreas Huber wrote:
Strange indeed. As you might have noticed, I'm using templated states and machines quite extensively in examples & tests. This should work in principle. I'll look into it.
Thanks. Could you keep me posted on what you find?
Will do, I'm working on it right now. Later, -- Andreas Huber When replying by private email, please remove the words spam and trap from the address shown in the header.
data:image/s3,"s3://crabby-images/7e3eb/7e3eb43d5aaef1e2f42c13e57f17f7f33e8d30f1" alt=""
It is getting late here in Switzerland. I've tried several things,
nothing worked and I don't have much of a clue at the moment. The fact
that two independent compilers choke on this pretty much rules out a
compiler bug. I think a library bug isn't likely either as everything
works when you make the innermost state non-templated. Moreover, the
newest version of TransitionTest.cpp (checked in yesterday) seems to
work perfectly on a number of platforms. That test does something very
similar to what you try to do. I can't currently see any other
explanation than that we must both be missing something. The attached
program is what I got after throwing out all the unnecessary stuff. It
compiles on MSVC, but as soon as you uncomment the commented parts it
complains with "'inner_context_type' : is not a member of
'NormalMode<Type>'". Tomorrow I'll try to reduce it to something that
hasn't anything to do with Boost.Statechart...
#include
data:image/s3,"s3://crabby-images/429af/429aff7ed9a2ef1aa6dbd93f1f3dbdeabdbfb2a6" alt=""
Andreas Huber wrote:
It is getting late here in Switzerland. I've tried several things, nothing worked and I don't have much of a clue at the moment. The fact that two independent compilers choke on this pretty much rules out a compiler bug. I think a library bug isn't likely either as everything works when you make the innermost state non-templated. Moreover, the newest version of TransitionTest.cpp (checked in yesterday) seems to work perfectly on a number of platforms. That test does something very similar to what you try to do. I can't currently see any other explanation than that we must both be missing something. The attached program is what I got after throwing out all the unnecessary stuff. It compiles on MSVC, but as soon as you uncomment the commented parts it complains with "'inner_context_type' : is not a member of 'NormalMode<Type>'". Tomorrow I'll try to reduce it to something that hasn't anything to do with Boost.Statechart...
Believe me, I share your pain, bewilderment and frustration. I wonder if anyone else on the Boost developers list or someone on comp.lang.c++.moderated would have any insight. -Dave
data:image/s3,"s3://crabby-images/7e3eb/7e3eb43d5aaef1e2f42c13e57f17f7f33e8d30f1" alt=""
Hi Dave
The problem you stumbled upon is (or was :-() well known. It was
discussed during review and I even tried to find a workaround for it not
too long ago. The solution is very simple and is even described in the
reference manual under the requirements for the InnerInitial parameter:
<quote>
An mpl::list<> containing models of the SimpleState or State concepts or
instantiations of the shallow_history or deep_history class templates.
If there is only a single inner initial state
_that_is_not_a_template_instantiation_ then it can also be passed
directly, without wrapping it into an mpl::list<>. [...]
</quote>
(_Note_the_underlined_part_). So, the only thing you need to do is to
wrap every templated InnerInitial parameter into an mpl::list and
everything will work as expected (see attached example). The reason why
compilers rightly choke on the code lies in the fact that simple_state
internally checks whether the InnerInitial parameter already is an
mpl::list. This check works perfectly even on forward-declared classes.
However, as soon as InnerInitial is a class template instantiation, for
some reason that template needs to be fully instantiated. The problem is
described in more detail here:
http://article.gmane.org/gmane.comp.lib.boost.devel/128741
I guess it was simply a little too late yesterday, sorry...
#include
data:image/s3,"s3://crabby-images/429af/429aff7ed9a2ef1aa6dbd93f1f3dbdeabdbfb2a6" alt=""
Andreas Huber wrote:
(_Note_the_underlined_part_). So, the only thing you need to do is to wrap every templated InnerInitial parameter into an mpl::list and everything will work as expected (see attached example). The reason why
Aha, I see. Yes, that makes sense. Thanks for doing the digging. Perhaps this should be part of a Statechart FAQ? I certainly glossed right over the part of the manual that noted this. It's easy to miss a single phrase like that. -Dave
data:image/s3,"s3://crabby-images/7e3eb/7e3eb43d5aaef1e2f42c13e57f17f7f33e8d30f1" alt=""
David Greene wrote:
Aha, I see. Yes, that makes sense. Thanks for doing the digging.
Perhaps this should be part of a Statechart FAQ?
Already on my to-do list :-)... Regards, -- Andreas Huber When replying by private email, please remove the words spam and trap from the address shown in the header.
participants (3)
-
Andreas Huber
-
David A. Greene
-
David Greene