Keeping types safe
Apr 13, 2013 at 4:15pm UTC  
I have a function which is passed an unsigned integer.  The value of the integer must be zero or ( 1 << 31 ).  In order to ensure this happens, I've done this:
1enum  free_edge { USED = 0, FREE = 1 << 31 };
void  myFunc(free_edge);
Another function, also taking an unsigned integer, has a less strict range.  Namely, it has to be less than 1 << 30.
I can of course check to make sure it's valid every time, but I've thought perhaps better to do this:
1struct  size_in_bytes{
  uint32_t size;
  size_in_bytes(uint32_t s){
    if  ( s >= ( 1 << 30)) size = (1 << 30) - 1;  // maybe I should throw? 
    else                   size = s;
I guess the question is, should I make a Ranged_Int class?
Last edited on Apr 13, 2013 at 4:19pm UTC  
 
Topic archived. No new replies allowed.