| [949953] | 1 | /* | 
|---|
|  | 2 | * Action_impl_python.hpp | 
|---|
|  | 3 | * | 
|---|
|  | 4 | *  Created on: Sep 25, 2011 | 
|---|
|  | 5 | *      Author: heber | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | // include config.h | 
|---|
|  | 9 | #ifdef HAVE_CONFIG_H | 
|---|
|  | 10 | #include <config.h> | 
|---|
|  | 11 | #endif | 
|---|
|  | 12 |  | 
|---|
|  | 13 | #include <boost/preprocessor/cat.hpp> | 
|---|
|  | 14 | #include <boost/preprocessor/comparison/equal.hpp> | 
|---|
|  | 15 | #include <boost/preprocessor/control/if.hpp> | 
|---|
|  | 16 | #include <boost/preprocessor/control/expr_if.hpp> | 
|---|
|  | 17 | #include <boost/preprocessor/debug/assert.hpp> | 
|---|
|  | 18 | #include <boost/preprocessor/facilities/expand.hpp> | 
|---|
|  | 19 | #include <boost/preprocessor/iteration/local.hpp> | 
|---|
| [6ba9ba] | 20 | #include <boost/preprocessor/list/adt.hpp> | 
|---|
| [949953] | 21 | #include <boost/preprocessor/punctuation/comma_if.hpp> | 
|---|
| [6ba9ba] | 22 | #include <boost/preprocessor/punctuation/paren.hpp> | 
|---|
| [0c74aa] | 23 | #include <boost/preprocessor/seq/elem.hpp> | 
|---|
|  | 24 | #include <boost/preprocessor/seq/size.hpp> | 
|---|
|  | 25 | #include <boost/preprocessor/seq/transform.hpp> | 
|---|
| [949953] | 26 |  | 
|---|
|  | 27 | // some derived names: if CATEGORY is not given, we don't prefix with it | 
|---|
|  | 28 | #ifdef CATEGORY | 
|---|
|  | 29 | #define ACTION BOOST_PP_CAT(CATEGORY, BOOST_PP_CAT(ACTIONNAME, Action)) | 
|---|
|  | 30 | #define COMMAND BOOST_PP_CAT(CATEGORY, ACTIONNAME) | 
|---|
|  | 31 | #define PARAMS BOOST_PP_CAT(CATEGORY, BOOST_PP_CAT(ACTIONNAME, Parameters)) | 
|---|
|  | 32 | #else | 
|---|
|  | 33 | #define ACTION BOOST_PP_CAT(ACTIONNAME, Action) | 
|---|
|  | 34 | #define COMMAND ACTIONNAME | 
|---|
|  | 35 | #define PARAMS BOOST_PP_CAT(ACTIONNAME, Parameters) | 
|---|
|  | 36 | #endif | 
|---|
|  | 37 |  | 
|---|
| [6ba9ba] | 38 | // for paramdefaults entries | 
|---|
|  | 39 | #define PARAM_DEFAULT(x) \ | 
|---|
|  | 40 | (x, BOOST_PP_NIL) | 
|---|
|  | 41 |  | 
|---|
| [949953] | 42 | // check if no lists given | 
|---|
|  | 43 | #ifndef paramtokens | 
|---|
|  | 44 | #define MAXPARAMTYPES 0 | 
|---|
|  | 45 | #else | 
|---|
|  | 46 | #define MAXPARAMTYPES BOOST_PP_SEQ_SIZE(paramtokens) | 
|---|
|  | 47 | #endif | 
|---|
|  | 48 |  | 
|---|
|  | 49 | // calculate numbers and check whether all have same size | 
|---|
|  | 50 | #ifdef paramtokens | 
|---|
|  | 51 | BOOST_PP_ASSERT_MSG(BOOST_PP_EQUAL(MAXPARAMTYPES, BOOST_PP_SEQ_SIZE(paramdescriptions)),\ | 
|---|
|  | 52 | ERROR: There are not the same number of "paramtokens" and "paramdescriptions" in: __FILE__ \ | 
|---|
|  | 53 | ) | 
|---|
|  | 54 | #endif | 
|---|
| [0c74aa] | 55 | #ifdef paramreferences | 
|---|
|  | 56 | BOOST_PP_ASSERT_MSG(BOOST_PP_EQUAL(MAXPARAMTYPES, BOOST_PP_SEQ_SIZE(paramreferences)),\ | 
|---|
|  | 57 | ERROR: There are not the same number of "paramtokens" and "paramreferences" in: __FILE__ \ | 
|---|
|  | 58 | ) | 
|---|
|  | 59 | #endif | 
|---|
|  | 60 |  | 
|---|
|  | 61 | #ifdef paramtypes | 
|---|
|  | 62 | BOOST_PP_ASSERT_MSG(BOOST_PP_EQUAL(MAXPARAMTYPES, BOOST_PP_SEQ_SIZE(paramtypes)),\ | 
|---|
|  | 63 | ERROR: There are not the same number of "paramtokens" and "paramtypes" in: __FILE__ \ | 
|---|
|  | 64 | ) | 
|---|
|  | 65 | #endif | 
|---|
| [949953] | 66 |  | 
|---|
|  | 67 | // print a list of "action separator description linenend, i.e. "Action - descrption\n" | 
|---|
|  | 68 | #define help_print(z,n,TYPELIST, VARLIST, separator, lineend) \ | 
|---|
|  | 69 | BOOST_PP_IF(n, +, BOOST_PP_EMPTY()) \ | 
|---|
|  | 70 | "\t" + std::string( BOOST_PP_SEQ_ELEM(n, TYPELIST) ) + \ | 
|---|
|  | 71 | std::string( separator ) + \ | 
|---|
|  | 72 | std::string( BOOST_PP_SEQ_ELEM(n, VARLIST) ) + \ | 
|---|
|  | 73 | std::string( lineend ) | 
|---|
|  | 74 |  | 
|---|
|  | 75 | // print a list of comma-separated list, i.e. (,)arg("Action")=default | 
|---|
|  | 76 | #define stringdefault_print(z,n,STRINGLIST, DEFAULTLIST) \ | 
|---|
|  | 77 | BOOST_PP_COMMA_IF(n) \ | 
|---|
|  | 78 | boost::python::arg( \ | 
|---|
| [e7ad08] | 79 | MoleCuilder::normalizeToken( BOOST_PP_SEQ_ELEM(n, STRINGLIST) ).c_str() \ | 
|---|
| [949953] | 80 | ) \ | 
|---|
| [6ba9ba] | 81 | = \ | 
|---|
|  | 82 | BOOST_PP_IF( \ | 
|---|
|  | 83 | BOOST_PP_NOT( BOOST_PP_LIST_IS_NIL( BOOST_PP_SEQ_ELEM(n, paramdefaults) ) ), \ | 
|---|
|  | 84 | toString BOOST_PP_LPAREN() \ | 
|---|
|  | 85 | BOOST_PP_LIST_FIRST( BOOST_PP_SEQ_ELEM(n, DEFAULTLIST) ) \ | 
|---|
|  | 86 | BOOST_PP_RPAREN(), \ | 
|---|
|  | 87 | std::string("") \ | 
|---|
|  | 88 | ) | 
|---|
| [949953] | 89 |  | 
|---|
|  | 90 | // print a list of comma-separated list, i.e. (,)arg("Action") | 
|---|
|  | 91 | #define string_print(z,n,STRINGLIST) \ | 
|---|
|  | 92 | BOOST_PP_COMMA_IF(n) \ | 
|---|
|  | 93 | boost::python::arg( \ | 
|---|
| [e7ad08] | 94 | MoleCuilder::normalizeToken( BOOST_PP_SEQ_ELEM(n, STRINGLIST) ).c_str() \ | 
|---|
| [949953] | 95 | ) | 
|---|
|  | 96 |  | 
|---|
|  | 97 | // print a list of type ref followed, i.e. "int i, double position" | 
|---|
|  | 98 | #define type_list(z,n,TYPELIST, VARLIST) \ | 
|---|
| [0c74aa] | 99 | BOOST_PP_COMMA_IF(n) \ | 
|---|
| [949953] | 100 | BOOST_PP_SEQ_ELEM(n, TYPELIST) \ | 
|---|
|  | 101 | BOOST_PP_SEQ_ELEM(n, VARLIST) | 
|---|
|  | 102 |  | 
|---|
|  | 103 | // prints set/queryCurrentValue (command) for paramreferences and paramtokens | 
|---|
| [5ca6b5] | 104 | #define value_print(z, n, container, prefix) \ | 
|---|
|  | 105 | prefix \ | 
|---|
| [0c74aa] | 106 | BOOST_PP_SEQ_ELEM(n, container) \ | 
|---|
|  | 107 | .set( \ | 
|---|
|  | 108 | BOOST_PP_SEQ_ELEM(n, container) \ | 
|---|
| [949953] | 109 | ); | 
|---|
|  | 110 |  | 
|---|
|  | 111 | #define stringtype std::string | 
|---|
|  | 112 |  | 
|---|
|  | 113 | #define type2string(s, data, elem) \ | 
|---|
|  | 114 | stringtype | 
|---|
|  | 115 |  | 
|---|
|  | 116 | #include "Actions/Action.hpp" | 
|---|
|  | 117 |  | 
|---|
|  | 118 | namespace MoleCuilder { | 
|---|
| [6aa485] | 119 | #ifdef returntype | 
|---|
|  | 120 | returntype | 
|---|
|  | 121 | #else | 
|---|
|  | 122 | void | 
|---|
|  | 123 | #endif | 
|---|
|  | 124 | BOOST_PP_CAT( COMMAND, _stringargs)( | 
|---|
| [949953] | 125 | #if defined paramtypes | 
|---|
| [0c74aa] | 126 | #define BOOST_PP_LOCAL_MACRO(n) type_list(~, n, BOOST_PP_SEQ_TRANSFORM( type2string, ~, paramtypes), paramreferences) | 
|---|
| [949953] | 127 | #define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1) | 
|---|
|  | 128 | #include BOOST_PP_LOCAL_ITERATE() | 
|---|
|  | 129 | #endif | 
|---|
|  | 130 | ); | 
|---|
|  | 131 | } | 
|---|
|  | 132 |  | 
|---|
|  | 133 | void BOOST_PP_CAT(export_, COMMAND)() | 
|---|
|  | 134 | { | 
|---|
|  | 135 | std::string docstring = | 
|---|
|  | 136 | std::string( DESCRIPTION ) + "\n\n" | 
|---|
|  | 137 | #if defined paramtokens && defined paramdescriptions | 
|---|
|  | 138 | #define BOOST_PP_LOCAL_MACRO(n) help_print(~, n, paramtokens, paramdescriptions, " - ", "\n") | 
|---|
|  | 139 | #define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1) | 
|---|
|  | 140 | #include BOOST_PP_LOCAL_ITERATE() | 
|---|
|  | 141 | #endif | 
|---|
|  | 142 | ; | 
|---|
|  | 143 | boost::python::def( | 
|---|
|  | 144 | BOOST_PP_STRINGIZE(COMMAND), | 
|---|
|  | 145 | MoleCuilder:: BOOST_PP_CAT( COMMAND, _stringargs) | 
|---|
|  | 146 | #if defined paramtokens // do we have parameters at all? | 
|---|
|  | 147 | ,( | 
|---|
|  | 148 | #if defined paramdefaults | 
|---|
|  | 149 | #define BOOST_PP_LOCAL_MACRO(n) stringdefault_print(~, n, paramtokens, paramdefaults) | 
|---|
|  | 150 | #else | 
|---|
|  | 151 | #define BOOST_PP_LOCAL_MACRO(n) string_print(~, n, paramtokens) | 
|---|
|  | 152 | #endif | 
|---|
|  | 153 | #define BOOST_PP_LOCAL_LIMITS  (0, MAXPARAMTYPES-1) | 
|---|
|  | 154 | #include BOOST_PP_LOCAL_ITERATE() | 
|---|
|  | 155 | ), docstring.c_str() | 
|---|
| [d628da] | 156 | #else | 
|---|
|  | 157 | , DESCRIPTION | 
|---|
| [949953] | 158 | #endif | 
|---|
|  | 159 | ); | 
|---|
|  | 160 | } | 
|---|
|  | 161 |  | 
|---|
|  | 162 | #undef COMMAND | 
|---|
|  | 163 | #undef ACTION | 
|---|
|  | 164 | #undef PARAMS | 
|---|
|  | 165 | #undef MAXPARAMTYPES | 
|---|
| [6ba9ba] | 166 | #undef PARAM_DEFAULT | 
|---|
| [949953] | 167 |  | 
|---|
| [874597] | 168 | #undef help_print | 
|---|
| [949953] | 169 | #undef string_print | 
|---|
|  | 170 | #undef stringdefault_print | 
|---|
| [874597] | 171 | #undef type_list | 
|---|
|  | 172 | #undef value_print | 
|---|
|  | 173 |  | 
|---|
|  | 174 | #undef type2string | 
|---|
|  | 175 | #undef stringtype | 
|---|