source: src/Actions/SelectionAction/Atoms/NotAtomByElementAction.def@ 97dff0

Last change on this file since 97dff0 was 6ba9ba, checked in by Frederik Heber <heber@…>, 13 years ago

Default values are properly set by the Action into their (Action)Parameters.

  • we changed the boost::preprocessor magic to accomplish this.
  • NODEFAULT -> NOPARAM_DEFAULT to be safe.
  • it has been a hell of a lot of work to make it possible to add a construct such as ", default" to the call of a function, either the comma or the default is easy but both could only be accomplished via a list contained in the sequence of default values. Because the list has an explicit NIL element which is taken as NOPARAM_DEFAULT.
  • PARAM_DEFAULT is a macro to wrap the default value into a list.
  • Property mode set to 100644
File size: 1.1 KB
Line 
1/*
2 * NotAtomByElementAction.def
3 *
4 * Created on: Aug 26, 2010
5 * Author: heber
6 */
7
8// all includes and forward declarations necessary for non-integral types below
9class element;
10
11#include "Parameters/Validators/Specific/ElementValidator.hpp"
12
13// i.e. there is an integer with variable name Z that can be found in
14// ValueStorage by the token "Z" -> first column: int, Z, "Z"
15// "undefine" if no parameters are required, use (NOPARAM_DEFAULT) for each (undefined) default value
16#define paramtypes (const element*)
17#define paramtokens ("unselect-atom-by-element")
18#define paramdescriptions ("element")
19#undef paramdefaults
20#define paramreferences (elemental)
21#define paramvalids \
22(ElementValidator())
23
24#define statetypes (std::vector<atom*>)
25#define statereferences (unselectedAtoms)
26
27// some defines for all the names, you may use ACTION, STATE and PARAMS
28#define CATEGORY Selection
29#define MENUNAME "selection"
30#define MENUPOSITION 15
31#define ACTIONNAME NotAtomByElement
32#define TOKEN "unselect-atom-by-element"
33
34
35// finally the information stored in the ActionTrait specialization
36#define DESCRIPTION "unselect an atom by element"
37#undef SHORTFORM
Note: See TracBrowser for help on using the repository browser.