Validating syntax with plumedcheck

Here is a list of coding rules that are enforced by the plumedcheck script. These rules are necessary to be sure that the codebase is consistent. Code not satisfying these rules will make the automatic test on travis-ci fail. In the following we provide a list of errors that are detected automatically, together with a short explanation of the reason we consider these as errors. The names used are the same ones reported by plumedcheck. The plumedcheck script can be used as is, but the simplest way to obtain a report is to go to the buildroot/src directory and type make plumedcheck. In case you think you have a valid reason for a code not passing the check to be merged, please contact the developers.

wrong_module_type

Module type as indicated in the module.type file located in the module directory is not valid. The admitted types are: default-on, which means the module is on by default, default-off, which means that they should be explicitly enabled, and always, which means they are always required.

used_wrapper_module

Wrapper module should not be used in other modules (via USE=wrapper in Makefile). The reason is that this makes libplumedKernel dependent on the PLUMED wrappers. An exception is the main module, which needs to use the wrapper module. Notice that within the PLUMED library there is no need to use the external cmd interface since one can directly declare a PlumedMain object.

astyle

In order to keep the code readable, we use the astyle program to format all source files. This error indicates that the reported file has not been formatted correctly. It is important that the version of astyle and the options exactly match the ones we use for testing. To this aim, you should use a command such as make astyle from the plumed root directory.

autoconf

In our git repository we distribute both ./configure and ./configure.ac files. When you modify the latter, the former should be regenerated using autoconf and committed to git. This error indicates that the ./configure.ac and ./configure files in the repository are not consistent. Notice that this test should be performed using exactly the same autoconf version that was used to generate the ./configure file.

include_dots

It is considered an error to include a file using a path starting with ../dir, where dir is not the name of a module explicitly declared as used in the Makefile. This might result in undetected dependences between the modules, which means that by enabling some set of modules one would result in a non-linkable library. As an exception, one can include files such as ../dir where dir is the current module since this would obviously create no problem. This would simplify life when moving files from a directory to another.

deprecated_headers

There is a list of headers that have been deprecated in C++ and should not be included. These headers should be replaced with their equivalent from the stdlib. E.g., use #include <cstdlib> instead of #include <stdlib.h>. Notice that using the modern header all the functions are declared inside the std namespace. Also notice that we have a special exception to allow them in Plumed.h.

external_header (style)

Header files should possibly not include other header files from external libraries. Indeed, once PLUMED is installed, if paths are not set correctly the include files of the other libraries might not be reachable anymore. This is only a stylistic warning now. Notice that with the current implementation of class Communicator it is necessary to include mpi.h in a header file.

non_h_header

Files with .inc extension are generated by PLUMED while it is compiled and are not installed. They should not be directly included in header files, otherwise those header files could be not usable once PLUMED is installed.

include_non_used_module

When including a file in the form "dir/file.h", dir should be an used module. This makes sure that we do not include system files that by chance are named as PLUMED modules. Indeed, when including "file" if the file is not found in the current path it is searched in system directories.

multi_registered_action

Each action should be registered (with PLUMED_REGISTER_ACTION) once and only once.

multi_registered_cltool

Each cltool should be registered (with PLUMED_REGISTER_CLTOOL) once and only once.

multi_registered_vessel

Each vessel should be registered (with PLUMED_REGISTER_VESSEL) once and only once.

multi_registered_metric

Each metric should be registered (with PLUMED_REGISTER_METRIC) once and only once.

multi_doc

An action or cltool should be documented once and only once. Notice that because of the way the manual is generated, a cltool cannot have the same name of an action.

using_namespace_in_header

A statement using namespace in header files is considered bad practice. Indeed, this would imply that any other file including that header file would be using the same namespace. This is true also for std namespace, and that's why you typically find full specifications such as std::string in header files.

using_namespace_std_in_source

A statement using namespace std in a source files is considered bad practice. Indeed, it makes it difficult to distinguish classes and functions that are taken from the standard library (such as std::vector) from similar names declared locally. This is currently a style issue, but will become an error in the future.

using_namespace_std_in_default_source

A statement using namespace std in a source files is considered bad practice. Indeed, it makes it difficult to distinguish classes and functions that are taken from the standard library (such as std::vector) from similar names declared locally. This is currently an error for default modules.

used_has_in_header (style)

Using __PLUMED_HAS_SOMETHING macros in headers should be avoided since it could make it difficult to make sure the same macros are correctly defined when using PLUMED as a library. This is only a stylistic warning now. Notice that with the current implementation of class Communicator it is necessary to include mpi.h in a header file and thus to use __PLUMED_HAS_MPI.

missing_namespace_plmd

Every source file should contain a PLMD namespace. Notice that files in the "outer modules" wrapper and main, that is those that are not included in the kernel library, are exempted from this rule.

missing_namespace_module

Every source file should contain a sub namespace with the same name of the module itself. Notice that there are important exceptions to this rule:

  • "outer modules" wrapper and main, that are not included in the kernel library.
  • "core modules" that are part of the core of PLUMED. Since the classes implemented here are widely used within PLUMED, they are directly defined in the PLMD namespace.

missing_guard

Every header file should contain a proper guard to avoid double inclusion. The format of the guard is fixed and should be __PLUMED_modulename_filename_h, where modulename is the name of the module and filename is the name of the file, without suffix. This choice makes guards unique within the whole codebase.

non_existing_cpp

For every header file there should exist a corresponding source file with the same name. Notice that dummy headers that only include another header or which only define preprocessor macros are exempted from this rule.

non_included_h

The source file corresponding to a header file (that is: with the same name) should include it as the first included file. This is to make sure that all the header files that we install can be individually included and compiled.

undocumented_action

Every action that is registered with PLUMED_REGISTER_ACTION should also be documented in a PLUMEDOC page.

action_without_examples

Every action that is registered should contain an Example section in its documentation. Notice that if the Example section is not added the manual will not show the registered keywords.

action_without_verbatim

Every action that is registered should contain an example in the form of a plumedfile section. This is currently a stylistic warning since there are many actions not satisfying this requirement.

unregistered_action

Every action that is documented should be also registered using PLUMED_REGISTER_ACTION.

undocumented_cltool

Every cltool that is registered with PLUMED_REGISTER_CLTOOL should also be documented in a PLUMEDOC page.

cltool_without_examples

Every cltool that is registered should contain an Example section in its documentation. Notice that if the Example section is not added the manual will not show the registered options.

cltool_without_verbatim

Every cltool that is registered should contain an example in the form of a verbatim section.

unregistered_cltool

Every cltool that is documented should be also registered using PLUMED_REGISTER_CLTOOL.

undefined_has

Every macro in the form __PLUMED_HAS_SOMETHING that is used in the code should be defined in configure.ac. This check is made to avoid errors with mis-typed macros.

unused_has

Every macro in the form __PLUMED_HAS_SOMETHING that is defined in configure.ac should be used at least once in the code. This check is made to avoid errors with mis-typed macros.