C++ style guide: Difference between revisions
(fix link to m-file style guide) |
Carandraug (talk | contribs) (→Other C++ features: C++11 is now allowed and C++14 is the new not allowed) |
||
Line 43: | Line 43: | ||
=== C++11 === | === C++11 === | ||
Do not use C++ | C++11 features are generally allowed. Check if the feature you want to | ||
use has been already used. If not, ask on the mailing list. | |||
=== C++14 === | |||
Do not use C++14 features. Octave is widely used in very old systems and we | |||
want them to be able to use up to date versions of Octave. Building a recent | want them to be able to use up to date versions of Octave. Building a recent | ||
compiler in such systems is not a trivial task so the limitation must happen | compiler in such systems is not a trivial task so the limitation must happen | ||
in Octave | in Octave. | ||
An exception: code that requires C++ | An exception: code that requires C++14 feature must also implement an | ||
alternative code in the absence of said feature. In such case, use a | alternative code in the absence of said feature. In such case, use a | ||
configure check. This increases maintenance a lot, must be used sparsely, | configure check. This increases maintenance a lot, must be used sparsely, | ||
and requires approval from other maintainers. | and requires approval from other maintainers. | ||
#if | #if HAVE_THIS_C14_FEATURE | ||
// code that really needs it | // code that really needs it | ||
#else | #else | ||
// alternative code in its absence | // alternative code in its absence | ||
#endif | #endif | ||
Revision as of 12:23, 20 June 2016
A lot of GNU Octave is written in C++. This document details the C++ style used by the GNU Octave project.
Being part of the GNU project, Octave inherits the GNU coding standards.
See also the GNU Octave Octave style guide for how to write m-files.
Formatting
Indentation
Use only spaces, and indent 2 spaces at a time.
We use spaces for indentation. Absolutely do not use tabs in your code. You should probably set your editor to emit spaces when you hit the tab key.
Line Length
Keep the length of source lines to 79 characters or less, for maximum readability in the widest range of environments. This is inherited from the GNU Coding Standards.
Header Files
Order of Includes
Use the following order with an empty line between each section:
- config.h
- The C++ wrappers for C headers (cstdlib, cassert, etc.)
- C++ standard library headers (iostream, list, map, etc.)
- Other POSIX headers (sys/types.h, unistd.h, etc., no need to use
#if defined (HAVE_FOO_H)
if existence is guaranteed because of gnulib) - Other library header files (glpk.h, curl.h, etc., should be protected by
#if defined (HAVE_FOO_H)
since they may be missing on the build system) - Octave's liboctave headers
- Octave's libinterp headers
Each grouping of header files should be alphabetized unless there is some specific reason to not do that. The only case where that is true is in oct-parse.in.yy and there is a comment in the file for that one.
Other C++ features
C++11
C++11 features are generally allowed. Check if the feature you want to use has been already used. If not, ask on the mailing list.
C++14
Do not use C++14 features. Octave is widely used in very old systems and we want them to be able to use up to date versions of Octave. Building a recent compiler in such systems is not a trivial task so the limitation must happen in Octave.
An exception: code that requires C++14 feature must also implement an alternative code in the absence of said feature. In such case, use a configure check. This increases maintenance a lot, must be used sparsely, and requires approval from other maintainers.
#if HAVE_THIS_C14_FEATURE // code that really needs it #else // alternative code in its absence #endif