Solved

BOOST_FUSION_ADAPT_STRUCT

Posted on 2013-06-02
1
576 Views
Last Modified: 2013-06-19
Given:

#include <boost/fusion/include/sequence.hpp>
#include <boost/fusion/include/algorithm.hpp>
#include <boost/fusion/include/vector.hpp>

#include <boost/fusion/include/adapt_struct.hpp>
#include <boost/fusion/mpl.hpp>
#include <boost/fusion/adapted.hpp> // BOOST_FUSION_ADAPT_STRUCT
#include <boost/array.hpp> 
// boost::fusion::result_of::value_at 
#include <boost/fusion/sequence/intrinsic/value_at.hpp>
#include <boost/fusion/include/value_at.hpp>

// boost::fusion::result_of::size 
#include <boost/fusion/sequence/intrinsic/size.hpp>
#include <boost/fusion/include/size.hpp>

// boost::fusion::at 
#include <boost/fusion/sequence/intrinsic/at.hpp>
#include <boost/fusion/include/at.hpp>

# include <boost/bind.hpp>

# include <iostream>
# include <vector>
# include <typeinfo>
# include <cstdio>

typedef std::vector < int > INT_VEC ;
typedef boost::array<int, 10> array_t;
// Your existing struct 
struct my_struct { 
  int          i; 
  bool         j; 
  array_t      arr1; 
  unsigned int arr2 [ 10 ];
  INT_VEC      arr3 ; 
  my_struct() 
  : i    ( 0x4000 ) 
  , j    ( false )
  , arr3 ( 10, 6 ) 
  {
    for ( unsigned int odx ( 0 ); odx < 10; ++odx ) {
      arr2 [ odx ] = odx + 15  ;
    }
  } 
}; 

// Generate an adapter allowing to view "Foo" as a Boost.Fusion sequence 
BOOST_FUSION_ADAPT_STRUCT( 
    my_struct, 
    (int, i) 
    (bool, j) 
    (array_t, arr1 ) 
    (unsigned int, arr2 [ 10 ] ) 
    (INT_VEC, arr3) 
) 

template <typename T2> struct parse {  
  static void decode(  T2   & f); 
};

struct work {
  template <typename T>
  void operator()(  T& t) const {
    parse<T>::decode(t);
  }
};

template <typename T2>
void parse<T2>::decode(  T2 & f) {
  boost::fusion::for_each(f, work());
};

template <> void parse< unsigned int >::decode(  unsigned int  & f) {  
  std::cout << f << std::endl; 
}

template <> void parse<int >::decode(  int  & f) {  
  std::cout << f << std::endl; 
}
template <> void parse<char>::decode(  char & f) {  
  std::cout << f << std::endl; 
}
template <> void parse<bool>::decode(  bool&  f) { 
  if ( f ) {
    std::cout << "true" << std::endl;
  } else {  
    std::cout << "false" << std::endl;
  }
}
template <> void parse<double>::decode(  double&  f) {  
  std::cout << "(double = " << f << std::endl;  
}

template <> void parse<array_t>::decode(   array_t&  f)  { 
  for(int i = 0; i < 10; ++i) 
    std::cout << f[i] << ";" ;
  std::cout << std::endl;
}

template <> void parse<INT_VEC>::decode(   INT_VEC&  f)  { 
  for(int i = 0; i < 10; ++i) 
    std::cout << f[i] << ";" ;
  std::cout << std::endl;
}

int main() {
  my_struct obj ;
  for ( unsigned int odx ( 0 ); odx < 10; ++odx ) {
    obj.arr1 [ odx ] = odx ;
  } 
  parse<my_struct>::decode( obj );
}

Open in new window


a)
How do I specialize the C style array (arr2) such that I could iterate over the array and display the contents?

b)

template <> void parse<INT_VEC>::decode(   INT_VEC&  f)  { 
  for(int i = 0; i < 10; ++i) 
    std::cout << f[i] << ";" ;
  std::cout << std::endl;
}

Open in new window


f.size() does not produce the correct number of elements (10).   Why?
0
Comment
Question by:forums_mp
1 Comment
 
LVL 32

Accepted Solution

by:
sarabande earned 200 total points
ID: 39218453
(unsigned int, arr2 [ 10 ] )

Open in new window


the current definition wasn't for an array but for a single unsigned int. and the address was out-of-boundary.

in my opinion you need an array type. you could try

typedef unsigned int UINTARR10[10];
....
BOOST_FUSION_ADAPT_STRUCT( 
    my_struct,
    ....
    (UINTARR10, arr2),
    ....

Open in new window



if that  doesn't compile, it is probably because of a missing operator. you then could define a structure that contains the array and provides the missing properties.

Sara
0

Featured Post

IT, Stop Being Called Into Every Meeting

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

This article shows you how to optimize memory allocations in C++ using placement new. Applicable especially to usecases dealing with creation of large number of objects. A brief on problem: Lets take example problem for simplicity: - I have a G…
Basic understanding on "OO- Object Orientation" is needed for designing a logical solution to solve a problem. Basic OOAD is a prerequisite for a coder to ensure that they follow the basic design of OO. This would help developers to understand the b…
The viewer will learn how to pass data into a function in C++. This is one step further in using functions. Instead of only printing text onto the console, the function will be able to perform calculations with argumentents given by the user.
The viewer will learn how to use the return statement in functions in C++. The video will also teach the user how to pass data to a function and have the function return data back for further processing.

708 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

15 Experts available now in Live!

Get 1:1 Help Now