Menu

AttributeSetImpl.h

Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2008-2010 Michael Schulze <mschulze@ivs.cs.uni-magdeburg.de>
00004  *                    2010 Marcus Foerster <MarcusFoerster1@gmx.de>
00005  * All rights reserved.
00006  *
00007  *    Redistribution and use in source and binary forms, with or without
00008  *    modification, are permitted provided that the following conditions
00009  *    are met:
00010  *
00011  *    * Redistributions of source code must retain the above copyright
00012  *      notice, this list of conditions and the following disclaimer.
00013  *
00014  *    * Redistributions in binary form must reproduce the above copyright
00015  *      notice, this list of conditions and the following disclaimer in
00016  *      the documentation and/or other materials provided with the
00017  *      distribution.
00018  *
00019  *    * Neither the name of the copyright holders nor the names of
00020  *      contributors may be used to endorse or promote products derived
00021  *      from this software without specific prior written permission.
00022  *
00023  *
00024  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00025  *    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00026  *    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00027  *    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00028  *    OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00029  *    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00030  *    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00031  *    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00032  *    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00033  *    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00034  *    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00035  *
00036  *
00037  * $Id$
00038  *
00039  ******************************************************************************/
00040 
00041 #ifndef _Attribute_Set_Impl_
00042 #define _Attribute_Set_Impl_
00043 
00044 #include <stdint.h>
00045 
00046 #include "boost/mpl/begin.hpp"
00047 #include "boost/mpl/end.hpp"
00048 #include "boost/mpl/size.hpp"
00049 #include "boost/mpl/deref.hpp"
00050 #include "boost/mpl/next.hpp"
00051 
00052 #include "mw/attributes/detail/AttributeSize.h"
00053 
00054 #include "object/PlacementNew.h"
00055 
00056 namespace famouso {
00057     namespace mw {
00058         namespace attributes {
00059             namespace detail {
00060 
00061                 template <typename AttrSeq,
00062                           typename Iter = typename boost::mpl::begin<AttrSeq>::type>
00063                 struct AttributeSetImpl {
00064                     private:
00065                         // The current attribute type (determined by the given iterator type)
00066                         typedef typename boost::mpl::deref<Iter>::type curAttr;
00067 
00068                         // The next sequence element type
00069                         typedef typename boost::mpl::next<Iter>::type iterNext;
00070 
00071                     public:
00072                         // This type
00073                         typedef AttributeSetImpl type;
00074 
00075                         // The size in bytes of this attribute set
00076                         static const uint16_t size = AttributeSize<curAttr>::value +
00077                                                      AttributeSetImpl<AttrSeq, iterNext>::size;
00078 
00079                         // The number of attributes contained in this set
00080                         static const uint16_t count = boost::mpl::size<AttrSeq>::value;
00081 
00082                         static void construct(uint8_t *pos){
00083                             // Construct the attribute currently pointed to by the
00084                             //  given iterator
00085                             new (pos) curAttr;
00086                             // Then construct the rest of the set recursively
00087                             AttributeSetImpl<AttrSeq, iterNext>::construct(pos+AttributeSize<curAttr>::value);
00088                         }
00089 
00090                     private:
00091                         AttributeSetImpl();
00092                         AttributeSetImpl(const AttributeSetImpl&);
00093                         const AttributeSetImpl& operator=(const AttributeSetImpl&);
00094                 };
00095 
00096                 template <typename AttrSeq>
00097                 struct AttributeSetImpl<AttrSeq, typename boost::mpl::end<AttrSeq>::type> {
00098                         // This type
00099                         typedef AttributeSetImpl type;
00100 
00101                         static const uint16_t size = 0;
00102 
00103                         static const uint16_t count = 0;
00104 
00105                         static void construct(uint8_t *){}
00106 
00107                     private:
00108                         AttributeSetImpl();
00109                         AttributeSetImpl(const AttributeSetImpl&);
00110                         const AttributeSetImpl& operator=(const AttributeSetImpl&);
00111                 };
00112 
00113             } // end namespace detail
00114         } // end namespace attributes
00115     } // end namespace mw
00116 } // end namespace famouso
00117 
00118 #endif // _Attribute_Set_Header_