topical media & game development

talk show tell print

lib-of-vs-libs-Poco-include-Poco-NamedTuple.h / h



  //
  // NamedTuple.h
  //
  // Id: //poco/1.3/Foundation/include/Poco/NamedTuple.h#3 
  //
  // Library: Foundation
  // Package: Core
  // Module:  NamedTuple
  //
  // Definition of the NamedTuple class.
  //
  // Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
  // and Contributors.
  //
  // Permission is hereby granted, free of charge, to any person or organization
  // obtaining a copy of the software and accompanying documentation covered by
  // this license (the "Software") to use, reproduce, display, distribute,
  // execute, and transmit the Software, and to prepare derivative works of the
  // Software, and to permit third-parties to whom the Software is furnished to
  // do so, all subject to the following:
  // 
  // The copyright notices in the Software and this entire statement, including
  // the above license grant, this restriction and the following disclaimer,
  // must be included in all copies of the Software, in whole or in part, and
  // all derivative works of the Software, unless such copies or derivative
  // works are solely in the form of machine-executable object code generated by
  // a source language processor.
  // 
  // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  // DEALINGS IN THE SOFTWARE.
  //
  
  ifndef Foundation_NamedTuple_INCLUDED
  define Foundation_NamedTuple_INCLUDED
  
  include "Poco/Foundation.h"
  include "Poco/Tuple.h"
  include "Poco/TypeList.h"
  include "Poco/DynamicAny.h"
  include "Poco/SharedPtr.h"
  include "Poco/Format.h"
  
  namespace Poco {
  
  template<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames)
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17), 
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18), 
          typename TypeWrapper<T19>::CONSTTYPE& t19 = POCO_TYPEWRAPPER_DEFAULTVALUE(T19)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18,t19), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17), 
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18), 
          typename TypeWrapper<T19>::CONSTTYPE& t19 = POCO_TYPEWRAPPER_DEFAULTVALUE(T19)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18,t19)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14),
          const std::string& n15 = "P",
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15),
          const std::string& n16 = "Q",
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16),
          const std::string& n17 = "R",
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17),
          const std::string& n18 = "S",
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18),
                  const std::string& n19 = "T",
          typename TypeWrapper<T19>::CONSTTYPE& t19 = POCO_TYPEWRAPPER_DEFAULTVALUE(T19)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18,t19), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14,n15,n16,n17,n18,n19);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                                          case 15: return TupleType::template get<15>();
                                          case 16: return TupleType::template get<16>();
                                          case 17: return TupleType::template get<17>();
                                          case 18: return TupleType::template get<18>();
                                          case 19: return TupleType::template get<19>();
                      default: throw RangeException();
                  }
              }
          } 
  
          throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
          void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O",
          const std::string& n15 = "P",
          const std::string& n16 = "Q",
          const std::string& n17 = "R",
          const std::string& n18 = "S",
          const std::string& n19 = "T")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
                          _pNames->push_back(n15); 
                          _pNames->push_back(n16); 
                          _pNames->push_back(n17); 
                          _pNames->push_back(n18); 
                          _pNames->push_back(n19); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,T18,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,T18>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,T18> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,T18>::Type Type;
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17), 
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17), 
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14),
          const std::string& n15 = "P",
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15),
          const std::string& n16 = "Q",
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16),
          const std::string& n17 = "R",
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17),
          const std::string& n18 = "S",
          typename TypeWrapper<T18>::CONSTTYPE& t18 = POCO_TYPEWRAPPER_DEFAULTVALUE(T18)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17,t18), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14,n15,n16,n17,n18);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                                          case 15: return TupleType::template get<15>();
                                          case 16: return TupleType::template get<16>();
                                          case 17: return TupleType::template get<17>();
                                          case 18: return TupleType::template get<18>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O",
          const std::string& n15 = "P",
          const std::string& n16 = "Q",
          const std::string& n17 = "R",
          const std::string& n18 = "S")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
                          _pNames->push_back(n15); 
                          _pNames->push_back(n16); 
                          _pNames->push_back(n17); 
                          _pNames->push_back(n18); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,T17>::Type Type;
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames)
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16), 
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14),
          const std::string& n15 = "P",
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15),
          const std::string& n16 = "Q",
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16),
          const std::string& n17 = "R",
          typename TypeWrapper<T17>::CONSTTYPE& t17 = POCO_TYPEWRAPPER_DEFAULTVALUE(T17)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16,t17), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14,n15,n16,n17);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                                          case 15: return TupleType::template get<15>();
                                          case 16: return TupleType::template get<16>();
                                          case 17: return TupleType::template get<17>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O",
          const std::string& n15 = "P",
          const std::string& n16 = "Q",
          const std::string& n17 = "R")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
                          _pNames->push_back(n15); 
                          _pNames->push_back(n16); 
                          _pNames->push_back(n17); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,T16>::Type Type;
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15), 
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14),
          const std::string& n15 = "P",
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15),
          const std::string& n16 = "Q",
          typename TypeWrapper<T16>::CONSTTYPE& t16 = POCO_TYPEWRAPPER_DEFAULTVALUE(T16)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15,t16), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14,n15,n16);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                                          case 15: return TupleType::template get<15>();
                                          case 16: return TupleType::template get<16>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O",
          const std::string& n15 = "P",
          const std::string& n16 = "Q")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
                          _pNames->push_back(n15); 
                          _pNames->push_back(n16); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,T15>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14), 
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14),
          const std::string& n15 = "P",
          typename TypeWrapper<T15>::CONSTTYPE& t15 = POCO_TYPEWRAPPER_DEFAULTVALUE(T15)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14,n15);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                                          case 15: return TupleType::template get<15>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O",
          const std::string& n15 = "P")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
                          _pNames->push_back(n15); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,T14>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13), 
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13),
          const std::string& n14 = "O",
          typename TypeWrapper<T14>::CONSTTYPE& t14 = POCO_TYPEWRAPPER_DEFAULTVALUE(T14)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13,n14);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                                          case 14: return TupleType::template get<14>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N",
          const std::string& n14 = "O")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
                          _pNames->push_back(n14); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,T13>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12), 
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12),
          const std::string& n13 = "N",
          typename TypeWrapper<T13>::CONSTTYPE& t13 = POCO_TYPEWRAPPER_DEFAULTVALUE(T13)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12,n13);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                                          case 13: return TupleType::template get<13>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M",
          const std::string& n13 = "N")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
                          _pNames->push_back(n13); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,T12>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11), 
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11),
          const std::string& n12 = "M",
          typename TypeWrapper<T12>::CONSTTYPE& t12 = POCO_TYPEWRAPPER_DEFAULTVALUE(T12)): 
      TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12), _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11,n12);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                                          case 12: return TupleType::template get<12>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L",
          const std::string& n12 = "M")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
                          _pNames->push_back(n12); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,T11>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10), 
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10),
          const std::string& n11 = "L",
          typename TypeWrapper<T11>::CONSTTYPE& t11 = POCO_TYPEWRAPPER_DEFAULTVALUE(T11)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10,n11);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                                          case 11: return TupleType::template get<11>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K",
          const std::string& n11 = "L")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
                          _pNames->push_back(n11); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,T10>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9), 
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9),
          const std::string& n10 = "K",
          typename TypeWrapper<T10>::CONSTTYPE& t10 = POCO_TYPEWRAPPER_DEFAULTVALUE(T10)): 
      TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9,t10), _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9,n10);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                                          case 10: return TupleType::template get<10>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J",
          const std::string& n10 = "K")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
                          _pNames->push_back(n10); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,T9>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8), 
          const std::string& n9 = "J",
          typename TypeWrapper<T9>::CONSTTYPE& t9 = POCO_TYPEWRAPPER_DEFAULTVALUE(T9)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8,t9), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8,n9);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      case 9: return TupleType::template get<9>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I",
          const std::string& n9 = "J")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
              _pNames->push_back(n9); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,T8,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7,T8>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7),
          const std::string& n8 = "I",
          typename TypeWrapper<T8>::CONSTTYPE& t8 = POCO_TYPEWRAPPER_DEFAULTVALUE(T8)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7,t8), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7,n8);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      case 8: return TupleType::template get<8>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H",
          const std::string& n8 = "I")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
              _pNames->push_back(n8);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,T7,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6,T7>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6,T7> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6,T7>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6),
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6), 
          const std::string& n7 = "H",
          typename TypeWrapper<T7>::CONSTTYPE& t7 = POCO_TYPEWRAPPER_DEFAULTVALUE(T7)): 
                  TupleType(t0,t1,t2,t3,t4,t5,t6,t7), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6,n7);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      case 7: return TupleType::template get<7>(); 
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G",
          const std::string& n7 = "H")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
              _pNames->push_back(n7);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,T6,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5,T6>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5,T6> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5,T6>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6)): 
      TupleType(t0,t1,t2,t3,t4,t5,t6), _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5), 
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6)): 
      TupleType(t0,t1,t2,t3,t4,t5,t6)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5),
          const std::string& n6 = "G",
          typename TypeWrapper<T6>::CONSTTYPE& t6 = POCO_TYPEWRAPPER_DEFAULTVALUE(T6)): 
      TupleType(t0,t1,t2,t3,t4,t5,t6), _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5,n6);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      case 6: return TupleType::template get<6>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F", 
          const std::string& n6 = "G")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
              _pNames->push_back(n6);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,T5,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4,T5>
  {
          typedef Tuple<T0,T1,T2,T3,T4,T5> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4,T5>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5)): 
      TupleType(t0,t1,t2,t3,t4,t5), _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4),
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5)): 
      TupleType(t0,t1,t2,t3,t4,t5)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4), 
          const std::string& n5 = "F",
          typename TypeWrapper<T5>::CONSTTYPE& t5 = POCO_TYPEWRAPPER_DEFAULTVALUE(T5)): 
      TupleType(t0,t1,t2,t3,t4,t5), _pNames(0) 
      {
          init(n0,n1,n2,n3,n4,n5);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      case 5: return TupleType::template get<5>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E",
          const std::string& n5 = "F")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
              _pNames->push_back(n5);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,T4,NullTypeList>:
          public Tuple<T0,T1,T2,T3,T4>
  {
          typedef Tuple<T0,T1,T2,T3,T4> TupleType;
          typedef typename Tuple<T0,T1,T2,T3,T4>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4)): 
                  TupleType(t0,t1,t2,t3,t4), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4)): 
                  TupleType(t0,t1,t2,t3,t4)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3),
          const std::string& n4 = "E",
          typename TypeWrapper<T4>::CONSTTYPE& t4 = POCO_TYPEWRAPPER_DEFAULTVALUE(T4)): 
                  TupleType(t0,t1,t2,t3,t4), 
                  _pNames(0) 
      {
          init(n0,n1,n2,n3,n4);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      case 4: return TupleType::template get<4>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D",
          const std::string& n4 = "E")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
              _pNames->push_back(n4);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,T3,NullTypeList>:
          public Tuple<T0,T1,T2,T3>
  {
          typedef Tuple<T0,T1,T2,T3> TupleType;
          typedef typename Tuple<T0,T1,T2,T3>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3)): 
                  TupleType(t0,t1,t2,t3), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3)): 
                  TupleType(t0,t1,t2,t3)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2), 
          const std::string& n3 = "D",
          typename TypeWrapper<T3>::CONSTTYPE& t3 = POCO_TYPEWRAPPER_DEFAULTVALUE(T3)): 
      TupleType(t0,t1,t2,t3), _pNames(0) 
      {
          init(n0,n1,n2,n3);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      case 3: return TupleType::template get<3>(); 
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C",
          const std::string& n3 = "D")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
              _pNames->push_back(n3); 
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,T2,NullTypeList>:
          public Tuple<T0,T1,T2>
  {
          typedef Tuple<T0,T1,T2> TupleType;
          typedef typename Tuple<T0,T1,T2>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1), 
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2)): 
                  TupleType(t0,t1,t2), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2)): 
                  TupleType(t0,t1,t2)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1),
          const std::string& n2 = "C",
          typename TypeWrapper<T2>::CONSTTYPE& t2 = POCO_TYPEWRAPPER_DEFAULTVALUE(T2)): 
                  TupleType(t0,t1,t2), 
                  _pNames(0) 
      {
          init(n0,n1,n2);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      case 2: return TupleType::template get<2>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B",
          const std::string& n2 = "C")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
              _pNames->push_back(n2);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template
  struct NamedTuple<T0,T1,NullTypeList>:
          public Tuple<T0,T1>
  {
          typedef Tuple<T0,T1> TupleType;
          typedef typename Tuple<T0,T1>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1)): 
                  TupleType(t0,t1), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0,
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1)): 
                  TupleType(t0,t1)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0,
          typename TypeWrapper<T0>::CONSTTYPE& t0, 
          const std::string& n1 = "B",
          typename TypeWrapper<T1>::CONSTTYPE& t1 = POCO_TYPEWRAPPER_DEFAULTVALUE(T1)): 
                  TupleType(t0,t1), 
                  _pNames(0) 
      {
          init(n0,n1);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      case 1: return TupleType::template get<1>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A",
          const std::string& n1 = "B")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
              _pNames->push_back(n1);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  template<class T0>
  struct NamedTuple<T0,NullTypeList>:
          public Tuple<T0>
  {
          typedef Tuple<T0> TupleType;
          typedef typename Tuple<T0>::Type Type;
  
      typedef std::vector<std::string> NameVec; 
      typedef SharedPtr<NameVec> NameVecPtr; 
  
      NamedTuple(): _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames) 
      {
          if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(typename TypeWrapper<T0>::CONSTTYPE& t0): 
                  TupleType(t0), 
                  _pNames(0)
      {
          init();
      }
  
      NamedTuple(const NameVecPtr& rNames, 
          typename TypeWrapper<T0>::CONSTTYPE& t0): 
                  TupleType(t0)
      {
                  if (rNames->size() != TupleType::length)
              throw InvalidArgumentException("Wrong names vector length."); 
  
          _pNames = rNames;
      }
  
      NamedTuple(const std::string& n0, typename TypeWrapper<T0>::CONSTTYPE& t0): 
                  TupleType(t0), 
                  _pNames(0) 
      {
          init(n0);
      }
  
      const DynamicAny get(const std::string& name) const
      {
          NameVec::const_iterator it = _pNames->begin(); 
          NameVec::const_iterator itEnd = _pNames->end();
  
          for(std::size_t counter = 0; it != itEnd; ++it, ++counter)
          {
              if (name == *it)
              {
                  switch (counter)
                  { 
                      case 0: return TupleType::template get<0>();
                      default: throw RangeException();
                  }
              }
          } 
  
                  throw NotFoundException("Name not found: " + name);
      }
  
      const DynamicAny operator [] (const std::string& name) const
      {
          return get(name);
      }
  
      template<int N>
      typename TypeGetter<N, Type>::ConstHeadType& get() const 
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      typename TypeGetter<N, Type>::HeadType& get()
      {
          return TupleType::template get<N>();
      }
  
      template<int N>
      void set(typename TypeGetter<N, Type>::ConstHeadType& val)
      {
          return TupleType::template set<N>(val);
      }
  
      const NameVecPtr& names()
      {
          return _pNames; 
      }
  
      void setName(std::size_t index, const std::string& name)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  (*_pNames)[index] = name;
          }
  
          const std::string& getName(std::size_t index)
          {
                  if (index >= _pNames->size())
                          throw InvalidArgumentException(format("Invalid index: \%z", index));
  
                  return (*_pNames)[index];
          }
  
      bool operator == (const NamedTuple& other) const
      {
          return TupleType(*this) == TupleType(other) && _pNames == other._pNames;
      }
  
      bool operator != (const NamedTuple& other) const 
      {
          return !(*this == other);
      }
  
      bool operator < (const NamedTuple& other) const
      {
          TupleType th(*this);
          TupleType oth(other); 
  
          return (th < oth && _pNames == other._pNames) || 
              (th == oth && _pNames < other._pNames) ||
              (th < oth && _pNames < other._pNames);
      }
  
  private:
      void init(const std::string& n0 = "A")
      { 
          if (!_pNames)
          {
              _pNames = new NameVec;
              _pNames->push_back(n0);
          }
      }
  
      NameVecPtr _pNames;
  };
  
  } // namespace Poco
  
  endif // Foundation_Tuple_INCLUDED
  


(C) Æliens 04/09/2009

You may not copy or print any of this material without explicit permission of the author or the publisher. In case of other copyright issues, contact the author.