QxOrm  1.2.8
C++ Object Relational Mapping library
QxFunction_9.h
Go to the documentation of this file.
00001 /****************************************************************************
00002 **
00003 ** http://www.qxorm.com/
00004 ** Copyright (C) 2013 Lionel Marty (contact@qxorm.com)
00005 **
00006 ** This file is part of the QxOrm library
00007 **
00008 ** This software is provided 'as-is', without any express or implied
00009 ** warranty. In no event will the authors be held liable for any
00010 ** damages arising from the use of this software
00011 **
00012 ** Commercial Usage
00013 ** Licensees holding valid commercial QxOrm licenses may use this file in
00014 ** accordance with the commercial license agreement provided with the
00015 ** Software or, alternatively, in accordance with the terms contained in
00016 ** a written agreement between you and Lionel Marty
00017 **
00018 ** GNU General Public License Usage
00019 ** Alternatively, this file may be used under the terms of the GNU
00020 ** General Public License version 3.0 as published by the Free Software
00021 ** Foundation and appearing in the file 'license.gpl3.txt' included in the
00022 ** packaging of this file. Please review the following information to
00023 ** ensure the GNU General Public License version 3.0 requirements will be
00024 ** met : http://www.gnu.org/copyleft/gpl.html
00025 **
00026 ** If you are unsure which license is appropriate for your use, or
00027 ** if you have questions regarding the use of this file, please contact :
00028 ** contact@qxorm.com
00029 **
00030 ****************************************************************************/
00031 
00032 #ifndef _QX_FUNCTION_9_H_
00033 #define _QX_FUNCTION_9_H_
00034 
00035 #ifdef _MSC_VER
00036 #pragma once
00037 #endif
00038 
00046 #include <QxFunction/IxFunction.h>
00047 #include <QxFunction/QxParameters.h>
00048 
00049 namespace qx {
00050 
00055 template <class Owner, typename R, typename P1, typename P2, typename P3, typename P4, typename P5, typename P6, typename P7, typename P8, typename P9>
00056 class QxFunction_9 : public IxFunction
00057 {
00058 
00059 public:
00060 
00061    typedef boost::function<R (Owner *, P1, P2, P3, P4, P5, P6, P7, P8, P9)> type_fct;
00062    typedef typename qx::trait::remove_attr<P1, false>::type type_P1;
00063    typedef typename qx::trait::remove_attr<P2, false>::type type_P2;
00064    typedef typename qx::trait::remove_attr<P3, false>::type type_P3;
00065    typedef typename qx::trait::remove_attr<P4, false>::type type_P4;
00066    typedef typename qx::trait::remove_attr<P5, false>::type type_P5;
00067    typedef typename qx::trait::remove_attr<P6, false>::type type_P6;
00068    typedef typename qx::trait::remove_attr<P7, false>::type type_P7;
00069    typedef typename qx::trait::remove_attr<P8, false>::type type_P8;
00070    typedef typename qx::trait::remove_attr<P9, false>::type type_P9;
00071    QX_FUNCTION_CLASS_MEMBER_FCT(QxFunction_9);
00072 
00073    virtual qx_bool isValidParams(const QString & params) const          { Q_UNUSED(params); return true; }
00074    virtual qx_bool isValidParams(const type_any_params & params) const  { Q_UNUSED(params); return true; }
00075 
00076 private:
00077 
00078    template <class T, bool bReturnValue /* = false */>
00079    struct QxInvokerFct
00080    {
00081       static inline qx_bool invoke(void * pOwner, const T & params, boost::any * ret, const QxFunction_9 * pThis)
00082       {
00083          QX_FUNCTION_INVOKE_START_WITH_OWNER();
00084          QX_FUNCTION_FETCH_PARAM(type_P1, p1, get_param_1);
00085          QX_FUNCTION_FETCH_PARAM(type_P2, p2, get_param_2);
00086          QX_FUNCTION_FETCH_PARAM(type_P3, p3, get_param_3);
00087          QX_FUNCTION_FETCH_PARAM(type_P4, p4, get_param_4);
00088          QX_FUNCTION_FETCH_PARAM(type_P5, p5, get_param_5);
00089          QX_FUNCTION_FETCH_PARAM(type_P6, p6, get_param_6);
00090          QX_FUNCTION_FETCH_PARAM(type_P7, p7, get_param_7);
00091          QX_FUNCTION_FETCH_PARAM(type_P8, p8, get_param_8);
00092          QX_FUNCTION_FETCH_PARAM(type_P9, p9, get_param_9);
00093          try { pThis->m_fct(static_cast<Owner *>(pOwner), p1, p2, p3, p4, p5, p6, p7, p8, p9); }
00094          QX_FUNCTION_CATCH_AND_RETURN_INVOKE();
00095       }
00096    };
00097 
00098    template <class T>
00099    struct QxInvokerFct<T, true>
00100    {
00101       static inline qx_bool invoke(void * pOwner, const T & params, boost::any * ret, const QxFunction_9 * pThis)
00102       {
00103          QX_FUNCTION_INVOKE_START_WITH_OWNER();
00104          QX_FUNCTION_FETCH_PARAM(type_P1, p1, get_param_1);
00105          QX_FUNCTION_FETCH_PARAM(type_P2, p2, get_param_2);
00106          QX_FUNCTION_FETCH_PARAM(type_P3, p3, get_param_3);
00107          QX_FUNCTION_FETCH_PARAM(type_P4, p4, get_param_4);
00108          QX_FUNCTION_FETCH_PARAM(type_P5, p5, get_param_5);
00109          QX_FUNCTION_FETCH_PARAM(type_P6, p6, get_param_6);
00110          QX_FUNCTION_FETCH_PARAM(type_P7, p7, get_param_7);
00111          QX_FUNCTION_FETCH_PARAM(type_P8, p8, get_param_8);
00112          QX_FUNCTION_FETCH_PARAM(type_P9, p9, get_param_9);
00113          try { R retTmp = pThis->m_fct(static_cast<Owner *>(pOwner), p1, p2, p3, p4, p5, p6, p7, p8, p9); if (ret) { (* ret) = boost::any(retTmp); } }
00114          QX_FUNCTION_CATCH_AND_RETURN_INVOKE();
00115       }
00116    };
00117 
00118 };
00119 
00120 template <typename R, typename P1, typename P2, typename P3, typename P4, typename P5, typename P6, typename P7, typename P8, typename P9>
00121 class QxFunction_9<void, R, P1, P2, P3, P4, P5, P6, P7, P8, P9> : public IxFunction
00122 {
00123 
00124 public:
00125 
00126    typedef boost::function<R (P1, P2, P3, P4, P5, P6, P7, P8, P9)> type_fct;
00127    typedef typename qx::trait::remove_attr<P1, false>::type type_P1;
00128    typedef typename qx::trait::remove_attr<P2, false>::type type_P2;
00129    typedef typename qx::trait::remove_attr<P3, false>::type type_P3;
00130    typedef typename qx::trait::remove_attr<P4, false>::type type_P4;
00131    typedef typename qx::trait::remove_attr<P5, false>::type type_P5;
00132    typedef typename qx::trait::remove_attr<P6, false>::type type_P6;
00133    typedef typename qx::trait::remove_attr<P7, false>::type type_P7;
00134    typedef typename qx::trait::remove_attr<P8, false>::type type_P8;
00135    typedef typename qx::trait::remove_attr<P9, false>::type type_P9;
00136    QX_FUNCTION_CLASS_FCT(QxFunction_9);
00137 
00138    virtual qx_bool isValidParams(const QString & params) const          { Q_UNUSED(params); return true; }
00139    virtual qx_bool isValidParams(const type_any_params & params) const  { Q_UNUSED(params); return true; }
00140 
00141 private:
00142 
00143    template <class T, bool bReturnValue /* = false */>
00144    struct QxInvokerFct
00145    {
00146       static inline qx_bool invoke(const T & params, boost::any * ret, const QxFunction_9 * pThis)
00147       {
00148          QX_FUNCTION_INVOKE_START_WITHOUT_OWNER();
00149          QX_FUNCTION_FETCH_PARAM(type_P1, p1, get_param_1);
00150          QX_FUNCTION_FETCH_PARAM(type_P2, p2, get_param_2);
00151          QX_FUNCTION_FETCH_PARAM(type_P3, p3, get_param_3);
00152          QX_FUNCTION_FETCH_PARAM(type_P4, p4, get_param_4);
00153          QX_FUNCTION_FETCH_PARAM(type_P5, p5, get_param_5);
00154          QX_FUNCTION_FETCH_PARAM(type_P6, p6, get_param_6);
00155          QX_FUNCTION_FETCH_PARAM(type_P7, p7, get_param_7);
00156          QX_FUNCTION_FETCH_PARAM(type_P8, p8, get_param_8);
00157          QX_FUNCTION_FETCH_PARAM(type_P9, p9, get_param_9);
00158          try { pThis->m_fct(p1, p2, p3, p4, p5, p6, p7, p8, p9); }
00159          QX_FUNCTION_CATCH_AND_RETURN_INVOKE();
00160       }
00161    };
00162 
00163    template <class T>
00164    struct QxInvokerFct<T, true>
00165    {
00166       static inline qx_bool invoke(const T & params, boost::any * ret, const QxFunction_9 * pThis)
00167       {
00168          QX_FUNCTION_INVOKE_START_WITHOUT_OWNER();
00169          QX_FUNCTION_FETCH_PARAM(type_P1, p1, get_param_1);
00170          QX_FUNCTION_FETCH_PARAM(type_P2, p2, get_param_2);
00171          QX_FUNCTION_FETCH_PARAM(type_P3, p3, get_param_3);
00172          QX_FUNCTION_FETCH_PARAM(type_P4, p4, get_param_4);
00173          QX_FUNCTION_FETCH_PARAM(type_P5, p5, get_param_5);
00174          QX_FUNCTION_FETCH_PARAM(type_P6, p6, get_param_6);
00175          QX_FUNCTION_FETCH_PARAM(type_P7, p7, get_param_7);
00176          QX_FUNCTION_FETCH_PARAM(type_P8, p8, get_param_8);
00177          QX_FUNCTION_FETCH_PARAM(type_P9, p9, get_param_9);
00178          try { R retTmp = pThis->m_fct(p1, p2, p3, p4, p5, p6, p7, p8, p9); if (ret) { (* ret) = boost::any(retTmp); } }
00179          QX_FUNCTION_CATCH_AND_RETURN_INVOKE();
00180       }
00181    };
00182 
00183 };
00184 
00185 namespace function {
00186 
00187 template <class Owner, typename R, typename P1, typename P2, typename P3, typename P4, typename P5, typename P6, typename P7, typename P8, typename P9>
00188 IxFunction_ptr bind_fct_9(const typename QxFunction_9<Owner, R, P1, P2, P3, P4, P5, P6, P7, P8, P9>::type_fct & fct)
00189 {
00190    typedef boost::is_same<Owner, void> qx_verify_owner_tmp;
00191    BOOST_STATIC_ASSERT(qx_verify_owner_tmp::value);
00192    IxFunction_ptr ptr; ptr.reset(new QxFunction_9<void, R, P1, P2, P3, P4, P5, P6, P7, P8, P9>(fct));
00193    return ptr;
00194 }
00195 
00196 template <class Owner, typename R, typename P1, typename P2, typename P3, typename P4, typename P5, typename P6, typename P7, typename P8, typename P9>
00197 IxFunction_ptr bind_member_fct_9(const typename QxFunction_9<Owner, R, P1, P2, P3, P4, P5, P6, P7, P8, P9>::type_fct & fct)
00198 {
00199    typedef boost::is_same<Owner, void> qx_verify_owner_tmp;
00200    BOOST_STATIC_ASSERT(! qx_verify_owner_tmp::value);
00201    IxFunction_ptr ptr; ptr.reset(new QxFunction_9<Owner, R, P1, P2, P3, P4, P5, P6, P7, P8, P9>(fct));
00202    return ptr;
00203 }
00204 
00205 } // namespace function
00206 } // namespace qx
00207 
00208 #endif // _QX_FUNCTION_9_H_