-
Notifications
You must be signed in to change notification settings - Fork 82
File structure and naming
Enrico Seiler edited this page Apr 30, 2021
·
11 revisions
- header-only: SeqAn is a header-only library and all functionality is implemented in header files.
-
extension: Header files have the extension
.hpp
. -
file-names:
- all-lower snake_case
- only lower case standard characters
[a-z]
and underscore! - generalised singular (
concept.hpp
instead ofconcepts.hpp
) - if all the content of a file is inside the
namespace seqan3::detail
, the filename shall end_detail.hpp
or the file be placed in adetail
sub-directory
- utf8: All files are expected to be UTF-8 encoded. Special characters are allowed in documentation and string literals, but not in regular code (function names etc) and file names.
- self-contained: every header shall include every other header that it needs.
-
seqan3/core/platform.hpp
: every header that doesn't include another SeqAn3 header shall includeseqan3/core/platform.hpp
. -
visibility: every header that is not in a
detail
subfolder or contains_detail
in it's name is considered part of the API and may be directly included by users of the library.
-
Copyright notice:
- Copy from the license file or another header.
- Update the year if necessary.
- Don't add an Author line, instead add it to doc (see below).
-
File-Documentation:
-
\file
This says doxygen that the documentation block belongs to this file -
\brief
+ one-line description starting with upper case and ending in.
\author your name <your AT mail.com>
-
(files don't get this!)\ingroup MODULENAME
- optionally a longer description
-
-
Single-inclusion:
#pragma once
(more information); we don't use header guards. -
Names and order of includes: (an empty line between each block, sorted alphabetically within)
- C system library (rarely!)
- C++ Standard Library, e.g.
-
#include <vector>
and -
#include <seqan3/std/ranges>
, this header is in the future the same as#include <ranges>
, so it will be ordered as if the prefixseqan3/std
is not there.
-
- SDSL
- Ranges-V3 (Always
#include <seqan3/std/ranges>
before including any Ranges-V3 header) - SeqAn3
- Cereal
- Lemon
- All headers are always included with
<header>
not with"header"
, even SeqAn3! - The reasoning for this order is System β required Dependencies β SeqAn β optional Dependencies (because the inclusion of optional dependencies might depend on values/macros from other headers, especially
platform.hpp
) - Of course there are exceptions to this rule, but they should be very well argued!
-
rest of file (likely starts with a namespace opening)
// -----------------------------------------------------------------------------------------------------
// Copyright (c) 2006-2020, Knut Reinert & Freie UniversitΓ€t Berlin
// Copyright (c) 2016-2020, Knut Reinert & MPI fΓΌr molekulare Genetik
// This file may be used, modified and/or redistributed under the terms of the 3-clause BSD-License
// shipped with this file and also available at: https://github.com/seqan/seqan3/blob/master/LICENSE.md
// -----------------------------------------------------------------------------------------------------
/*!\file
* \brief Contains many nice things.
* \author Hannes Hauswedell <hannes.hauswedell AT fu-berlin.de>
* \ingroup alphabet
*/
#pragma once
#include <any>
#include <type_traits>
#include <vector>
#include <range/v3/view/drop.hpp>
#include <range/v3/view/take.hpp>
#include <seqan3/range/container/concept.hpp>
// here comes the code
In some cases you need headers only in DEBUG mode, e.g. when static_assert
ing a concept. In these cases you may include the header inside the DEBUG block, but only if this actually improves readability of the file.
10 different DEBUG block which each include different headers do not improve readability, in this case please move everything to an extra _detail.hpp
.