/* Menes - C++ High-Level Utility Library * Copyright (C) 2002-2005 Jay Freeman (saurik) */ /* * Redistribution and use in source and binary * forms, with or without modification, are permitted * provided that the following conditions are met: * * 1. Redistributions of source code must retain the * above copyright notice, this list of conditions * and the following disclaimer. * 2. Redistributions in binary form must reproduce the * above copyright notice, this list of conditions * and the following disclaimer in the documentation * and/or other materials provided with the * distribution. * 3. The name of the author may not be used to endorse * or promote products derived from this software * without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef MENES_ETL_TYPELIST_HPP #define MENES_ETL_TYPELIST_HPP #include "cxx/platform.hpp" #ifdef MENES_PRAGMA_ONCE #pragma once #endif #include "etl/integral.hpp" #include "etl/template.hpp" namespace etl { struct Null { private: Null(); public: typedef Null Head; typedef Null Tail; }; template struct Cons { typedef Head_ Head; typedef Tail_ Tail; }; namespace be { struct ListNull_; } template < typename Arg0_ = be::ListNull_, typename Arg1_ = be::ListNull_, typename Arg2_ = be::ListNull_, typename Arg3_ = be::ListNull_, typename Arg4_ = be::ListNull_, typename Arg5_ = be::ListNull_, typename Arg6_ = be::ListNull_, typename Arg7_ = be::ListNull_ > struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons::Result> Result; }; template struct List { typedef Cons Result; }; template <> struct List { typedef Null Result; }; template struct Append { typedef Cons::Result> Result; }; template struct Append { typedef Right_ Result; }; template struct MaxSize { private: static const unsigned head_ = sizeof(typename Cell_::Head); static const unsigned tail_ = MaxSize::value; public: static const unsigned value = IfElse< (head_ > tail_), Integer, Integer >::Result::value; }; template <> struct MaxSize { static const unsigned value = 0; }; template struct Length { static const unsigned value = Length::value + 1; }; template <> struct Length { static const unsigned value = 0; }; template union Union { typename Cell_::Head head; Union tail; }; template union Union< Cons > { Type_ head; }; template <> union Union { }; template struct Struct { typename Cell_::Head head; Struct tail; }; template struct Struct< Cons > { Type_ head; }; template <> struct Struct { }; template class Operation_> struct ForEach { typedef Cons::Result, typename ForEach::Result> Result; }; template