Re: [Boost-users] [review][constrained_value] Review of Constrained Value Library begins today
data:image/s3,"s3://crabby-images/ed5b6/ed5b6a01603c10ddfe8dd06be51a7f45f05c689b" alt=""
One idea on the dynamically changing the global bounds for a type as I keep
mentioning, one concern people have is that it could invalidate instantiated
objects of the type.
As I said before, being able to dynamically change the bounds at runtime is
essential, but most of the time you would do it before you instantiate
anything. Hence, one solution is to make a check to see if it has been
instantiated yet. I don't know enough metaprogramming to know if this is
possible, but the idea is to flip some kind of a compile time flag in the
constructor of the type and if you try to change the bounds after that, it
fails a compile time assertion.
So, the following would work:
typedef bounded_type
data:image/s3,"s3://crabby-images/48064/48064d72b0cc2a7ace5789b3da09cb4b9f086523" alt=""
AMDG Jesse Perla wrote:
I don't know enough metaprogramming to know if this is possible, but the idea is to flip some kind of a compile time flag in the constructor of the type and if you try to change the bounds after that, it fails a compile time assertion.
It's possible to hack a compile-time boolean flag, but... a) The bounds could be set in a different translation unit from the one in which objects are constructed. b) The order in which statements are compiled is not necessarily the same as the order in which they are executed. In Christ, Steven Watanabe
participants (2)
-
Jesse Perla
-
Steven Watanabe