Skip to content

Commit

Permalink
Add some wording to the coding standards to say how to indent namespaces
Browse files Browse the repository at this point in the history
(and to mention namespace ending comments). This is based on a quick
discussion on the developer mailing list where there was essentially no
objections to a simple and consistent rule. This should avoid future
debates about whether or not a namespace is "big enough" to indent. It
also matches clang-format's current behavior with LLVM source code which
hasn't really seen any opposition in code reviews that I spot checked.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@199620 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
chandlerc committed Jan 20, 2014
1 parent ee804f4 commit 5d696a9
Showing 1 changed file with 45 additions and 1 deletion.
46 changes: 45 additions & 1 deletion docs/CodingStandards.rst
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,24 @@ an algorithm is being implemented or something tricky is going on, a reference
to the paper where it is published should be included, as well as any notes or
*gotchas* in the code to watch out for.

Namespace Markers
"""""""""""""""""

We don't indent namespaces (see below) and so feel free to add markers to the
end of a namespace where it helps readabilitily:

.. code-block:: c++

namespace foo {

// Lots of code here...

} // End foo namespace

This isn't required, and in many cases (such as the namespace used for an
entire file like the 'llvm' namespace in header files) it isn't really useful.
Use your judgment and add it where it helps.

Class overviews
"""""""""""""""

Expand Down Expand Up @@ -336,7 +354,33 @@ Indent Code Consistently

Okay, in your first year of programming you were told that indentation is
important. If you didn't believe and internalize this then, now is the time.
Just do it.
Just do it. A few cases are called out here that have common alternatives. The
intent in saying which way to format things is to increase consistency across
the LLVM codebase.

Namespaces
""""""""""

A simple rule: don't indent them. Here are examples of well formatted and
indented namespaces:

.. code-block:: c++
namespace llvm {

namespace foo {
class A;
class B;
}

namespace {
/// \brief Some local class definition.
/// ...
class Widget {
// ... lots of code here ...
};
} // End anonymous namespace

} // End llvm namespace

Compiler Issues
---------------
Expand Down

0 comments on commit 5d696a9

Please sign in to comment.