ba06a404d1
53d0d913a v3.5.0 1648c30ec Look just for 'Catch2 X.Y.Z' in doc placeholder update d4e9fb8aa Highlight that SECTIONs rerun the entire test case from beginning (#2749) b606bc280 Remove obsolete section in limitations.md 4ab0af8ba Fix minor typos in documentation (#2769) b7d70ddcd Ensure we always read 32 bit seed from std::random_device a6f22c516 Remove static instance of std::random_device in Benchmark::analyse_samples 1887d42e3 Use our PCG32 RNG instead of mt19937 in Benchmark::analyse_samples 1774dbfd5 Make it clearer that the JSON reporter is WIP cb07ff9a7 Fix uniform_floating_point_distribution for unit ranges ae4fe16b8 Make the user-facing random Generators reproducible 28c66fdc5 Make uniform_floating_point_distribution reproducible ed9d672b5 Add uniform_integer_distribution 04a829b0e Add helpers for implementing uniform integer distribution ab1b079e4 Add uniform_floating_point_distribution d139b4ff7 Add implementation of helpers for uniform float distribution bfd9f0f5a Move nextafter polyfill to polyfills.hpp 9a1e73568 Add test showing literals and complex generators in one GENERATE 21d2da23b Fix typo in tostring.md d1d7414eb Always run apt-get update before apt-get install dacbf4fd6 Drop VS 2017 support 0520ff443 [DOC] Replaced broken link (fixes #2770) 4a7be16c8 Fix compilation on Xbox platforms 32d9ae24b JSONWriter deals in StringRefs instead of std::strings de7ba4e88 fn need to be in parenthesis 733b901dd Fix special character escaping in JsonWriter 7bf136b50 Add JSON reporter (#2706) 2c68a0d05 lifted suggested version 01cac90c6 Bump up actions/checkout version to v4 (#2760) b735dfce2 Increase build parallelism on macOS (#2759) caffe79a3 Fix missing include in catch_message.hpp a8cf3e671 Mark `CATCH_CONFIG_` options as advanced 79d39a195 Fix tests for C++23's multi-arg index operator 6ebc013b8 Fix UDL definitions for C++23 966d36155 Improve formatting of test specification docs 766541d12 why-catch.md: Add JetBrains survey link 7b793314e Catch.cmake: Support CMake multi-config with PRE_TEST discovery mode (#2739) 0fb817e41 fix some bugprone-macro-parentheses warnings f161110be Merge pull request #2747 from xandox/devel db495acdb correct argument references in CatchAddTests.cmake 9c541ca72 Add test for multiple streaming parts in UNSCOPED_INFO 92672591c Make jackknife TU-local to stats.cpp 56fcd584c Make directCompare TU-local to stats.cpp aafe09bc1 Update meson.build to fix #2722 (#2742) 47a2c9693 Reduce the number of templates in Benchmarking fb96279ae Remove superfluous stdlib includes from catch_benchmark.hpp e14a08d73 Remove unused typedef from Benchmark::Environment 9bba07cb8 Replace vector iterator args in benchmarks with ptr args b4ffba508 Update sample output in docs/benchmarks.md 3a5cde55b implement stringify for std::nullopt_t 2a19ae16b Rewrite commandline test spec docs f24d39e42 Support C arrays and ADL ranges in from_range generator 85eb4652b Add nice license headers to files in examples/ and fuzzing/ 5bba3e403 Edited amalgamated file generator, to block REUSE from getting confused e09de7222 Small cleanup in XML reporter a64ff326b Change 'estimated' to 'est run time' in console reporter output ad5646347 Flush stream after benchmarkStarting in ConsoleReporter 9538d1600 Mention missing catch_user_config.hpp in FAQ a94bee771 Add missing line for v3.4.0 to ToC in release-notes.md d7304f0c4 Constify section hints in static-analysis mode cd60a0301 Assert Info reset need to also reset result disposition to normal to handle uncaught exception correctly (#2723) b593be211 Always default empty destructors ed4acded3 Don't define tryTranslators function if exception are disabled 4acc51828 Introduce CATCH_CONFIG_PREFIX_MESSAGES to only prefix a few logging related macros. (#2544) 6e79e682b v3.4.0 683c85772 Clean up explanation in tests 1b049bdba 2 more TEST_CASEs to DiscoverTests/register-tests.cpp e4b16053a Escape Catch2 test names in catch_discover_tests tests 42ee66b5e Fix handling of semicolon and backslash characters in CMake test discovery (#2676) a0c6a2846 Fix possible FP in catch_discover_tests tests c8363143e Add test scaffolding for catch_discover_tests 7a52dfa77 Fix typo in cross-docs links 913173663 Bazel support: Update skylib 0631b607e Test & document SKIP in generator constructor dff7513b2 Static analysis cleanup in tests bf5aa7b38 Experimental static analysis support in TEST_CASE and SECTION dba9197ec Add new config option: STATIC_ANALYSIS_SUPPORT f60c15364 Add macro for suppressing Wshadow b3cf1bfb5 Avoid unused variable warning in GeneratorsImpl tests 73b93ce6b Include catch_user_config.hpp in all catch_config_* files 8008625d7 Merge pull request #2693 from Ali-Amir/u/ali/optional-meson-unit-tests ce7b15302 Add option to disable building unit tests in Meson build file. 535205e2a Suppress -Wunused-result warning in gcc 689fdcd7d Fix some tests never being run a153fce72 Improve error messages for TEST_CASE tag parsing errors 06c0e1cfa Merge pull request #2689 from ThePhD/fix/includes/header-exception 05d7eb5a0 🛠 Add <exception> header where strictly necessary f53bb3ae7 meson: require version >=0.54.1 ce8a7b339 Merge pull request #2687 from ChrisThrasher/sfml 6dce539fa Add SFML to the list of open source users 5a40b2275 Update CatchConfigOptions.cmake 598895d04 Fix Wredundant-decls 0dc82e08d Move CATCH_INTERNAL_STRINGIFY macro into its own header 8ca504cbc Move AssertionResult when passing it inside RunContext c57b5cdf4 Move-enable Catch::optional d84777c9c Fix assertionStarting events being sent after the expr is evaluated 51fdbedd1 Internal linkage for outlier_variance 10f0a5864 Some template instantiation reductions fe64c2892 Reduce compilation costs of benchmarks 7d07efc92 Clean up iterator usage in benchmarks f3c678c0a Constexprify constants in estimate_clock.hpp 46539b6d9 Fix spelling 10596b227 Fix unreachable-code-return warnings 897fe2a01 cmake: Improve unreachable-code warnings aad926baf Catch.cmake: Add new DISCOVERY_MODE option to catch_discover_tests 4e8399d83 CatchAddTests.cmake: Refactor into callable method 9a2a4eadc Bump xml-format-version in XML reporter fb806da76 Add lineinfo to XML reporter output for INFO/WARN 50bf00e26 Fix reporter detection in catch_discover_tests 9f08097f5 Cleanup internal includes by splitting out some event structs 1f881ab46 Split ITestInvoker into its own header c487b27d9 Reduce misc includes all around 3230760db Cleanup in translating exceptions to messages b3ebce715 Cleanup benchmarking includes d0f70fdfd Unify IReporterRegistry and ReporterRegistry 4f4ad8ada Sprinkle some constexpr around 5b665be64 Cut out catch_interfaces_capture.hpp include from the main include 2598116aa Mark various anonymous classes final 173aa3f1f Devirtualize Context 28437e121 Remove pointless member variable from RunContext 3c8fb6bbb Internal linkage for generator trackers 72f3ce4db Outline the actual registering of listener factories to cpp file 62167d756 Reduce internal includes 678341134 Fixed extras installation and shard impl location 7b4dd326c Remove obsolete comment in multireporter 1dfaa8abe Outline throwing of TestSkipException ba94278bd Inline trivial function in AssertionHandler 8e5a4b6f7 Remove superfluous pointer copy in AssertionStats constructor 9b884d810 Fix refactoring 8a1b3b81c Add wxWidgets as another Open Source project using Catch e5aabb671 Add xmlwrapp to the list of Open Source projects using Catch 3a1ef1409 Use hasMessage() instead of getMessage().empty() 13fae1e2f Move exception's translation into AssertionResultData message 3220ae6d4 Add support for the IAR compiler 0a0ebf500 Support elements without op!= in VectorEquals 69f35a5ac Bazel support: Update skylib version 3f0283de7 v3.3.2 6fbb3f072 Add IsNaN matcher 9ff3cde87 Simplify test name creation for list-templated test cases 4d802ca58 Use StringRef UDL in more preprocessor-generated strings 13711be7c Use StringRef UDL for generated generator names 27ba26f74 Merge pull request #2643 from kisielk/patch-1 a209bcfb5 Update build instructions in contributing.md 584973a48 Early evaluate line loc in NameAndLoc::operator== 4f7c8cb28 Avoid copying NameAndLocationRef when passed as argument e1dbad4c9 Inline StringRef::operator== 2befd98da Inline some non-virtual functions in ITracker and TrackerContext 00f259aeb Move captured output into TestCaseStats when sending testCaseEnded fed143624 Avoid allocating trimmed name for SectionTracker 0477326ad Directly construct empty string for invalid SectionInfo f04c93462 Small refactoring in AssertionResult 1af351cea Remove unused TrackerContext::endRun function dcc9fa3f3 Use StringRef UDL for more string literals when expanding macros bf6a15a69 Rewrite -# docs 6135a78c3 Don't insert the foo part of [.foo] tag twice when parsing test spec e8ba329b6 Add support for iterator+sentinel pairs in Contains matcher 4aa88299a Preconstruct error message in RunContext::handleIncomplete 4ff9be3bc cmake-integration.md: Use "tests" as test target name in all examples. 76cdaa3b5 Merge pull request #2637 from jbadwaik/nvhpc_unused_warning 644294df6 Suppress declared_but_not_referenced warning for NVHPC cefa8fcf3 Enable use of UnorderedRangeEquals with iterator+sentinel pairs 772fa3f79 Add Catch::Detail::is_permutation that supports sentinels f3c0a3cd0 Fix RangeEquals matcher to handle iterator + sentinel ranges 42d9d4533 Add test for empty result of filter generator 618d44c44 Update docs about thread safe assertions 388f7e173 Cleanup unneeded allocations from reporters 2ab20a0e0 v3.3.1 60264b880 Avoid copying strings in sonarqube when sorting tests by file 65ffee518 Don't take ownership of SECTION's name for inactive sections 43f02027e Avoid allocations when looking for trackers 906552f8c Clean up extraneous copies in Messages 356dfc143 Move name and sample analysis in benchmarks into BenchmarkStats e5d1eb757 Move AssertionResultData into AssertionResult in RunContext 2403f5620 Move SectionEndInfo into sectionEnded call in SECTION's destructor d58491c85 Move sectionInfo into sectionEndInfo when SECTION ends c837cb4a8 v3.3.0 8359a6b24 Stop exceptions in generator constructors from aborting the binary adf43494e Add missing version information to matchers.md efca9a0f1 Added ElementsAre and UnorderedElementsAre (#2377) dd36f83b8 Merge pull request #2630 from ChrisThrasher/export_all_symbols baab9e8d2 Export symbols for all compilers on Windows 2d3c9713a Remove VS2015 workaround from Detail::generate 956f915e3 Document template macros are in spearate header aa8da505e Fix compatibility with previous CUDA versions e27bb7198 Fix macro-redefinition issue with MSVC+CUDA 3486f8ed9 Update generator docs b5be64204 catch_debugger.hpp: restore PPC support (#2619) d59572f46 Reword the SKIP docs a bit 16f48f8c7 Add SUCCEED and FAIL docs next to SKIP docs 367c2cb24 Update doc about what counts as unique test case d548be26e Add new SKIP macro for skipping tests at runtime (#2360) 52066dbc2 Fix build with GCC 13 (add missing <cstdint> include) cdf604f30 Update command-line.md 04382af4c Slightly better clang-format ac93f1943 Improved path normalization in approvalTests.py 72b60dfd2 Cleanup the Windows GHA builds 0c62167fe Merge pull request #2604 from ChrisThrasher/generated_includes_directory 1be954ff7 Keep generated headers within project binary directory 78bb4fda0 Mention that the benchmarks are not run by default next to example e6ec1c238 Fix benchmarking example in the main readme 477c1f515 Fixed typo in code example in top level README.md f8b9f7725 Prune Appveyor builds 77fbacb03 Add VS 2019-2022 C+14/17 jobs to GHA e3fc97dff fix compiler warning in parseUint and catch only relevant exceptions (#2572) 9c0533a90 Add MessageMatches matcher for exception (#2570) ed02710b8 Make AutoReg in test registration macros const 8b84438be Avoid usage of master when possible git-subtree-dir: externals/catch git-subtree-split: 53d0d913a422d356b23dd927547febdf69ee9081
343 lines
13 KiB
Markdown
343 lines
13 KiB
Markdown
<a id="top"></a>
|
|
# Contributing to Catch2
|
|
|
|
**Contents**<br>
|
|
[Using Git(Hub)](#using-github)<br>
|
|
[Testing your changes](#testing-your-changes)<br>
|
|
[Writing documentation](#writing-documentation)<br>
|
|
[Writing code](#writing-code)<br>
|
|
[CoC](#coc)<br>
|
|
|
|
So you want to contribute something to Catch2? That's great! Whether it's
|
|
a bug fix, a new feature, support for additional compilers - or just
|
|
a fix to the documentation - all contributions are very welcome and very
|
|
much appreciated. Of course so are bug reports, other comments, and
|
|
questions, but generally it is a better idea to ask questions in our
|
|
[Discord](https://discord.gg/4CWS9zD), than in the issue tracker.
|
|
|
|
|
|
This page covers some guidelines and helpful tips for contributing
|
|
to the codebase itself.
|
|
|
|
## Using Git(Hub)
|
|
|
|
Ongoing development happens in the `devel` branch for Catch2 v3, and in
|
|
`v2.x` for maintenance updates to the v2 versions.
|
|
|
|
Commits should be small and atomic. A commit is atomic when, after it is
|
|
applied, the codebase, tests and all, still works as expected. Small
|
|
commits are also preferred, as they make later operations with git history,
|
|
whether it is bisecting, reverting, or something else, easier.
|
|
|
|
_When submitting a pull request please do not include changes to the
|
|
amalgamated distribution files. This means do not include them in your
|
|
git commits!_
|
|
|
|
When addressing review comments in a MR, please do not rebase/squash the
|
|
commits immediately. Doing so makes it harder to review the new changes,
|
|
slowing down the process of merging a MR. Instead, when addressing review
|
|
comments, you should append new commits to the branch and only squash
|
|
them into other commits when the MR is ready to be merged. We recommend
|
|
creating new commits with `git commit --fixup` (or `--squash`) and then
|
|
later squashing them with `git rebase --autosquash` to make things easier.
|
|
|
|
|
|
|
|
## Testing your changes
|
|
|
|
_Note: Running Catch2's tests requires Python3_
|
|
|
|
|
|
Catch2 has multiple layers of tests that are then run as part of our CI.
|
|
The most obvious one are the unit tests compiled into the `SelfTest`
|
|
binary. These are then used in "Approval tests", which run (almost) all
|
|
tests from `SelfTest` through a specific reporter and then compare the
|
|
generated output with a known good output ("Baseline"). By default, new
|
|
tests should be placed here.
|
|
|
|
To configure a Catch2 build with just the basic tests, use the `basic-tests`
|
|
preset, like so:
|
|
|
|
```
|
|
# Assuming you are in Catch2's root folder
|
|
|
|
cmake -B basic-test-build -S . -DCMAKE_BUILD_TYPE=Debug --preset basic-tests
|
|
```
|
|
|
|
However, not all tests can be written as plain unit tests. For example,
|
|
checking that Catch2 orders tests randomly when asked to, and that this
|
|
random ordering is subset-invariant, is better done as an integration
|
|
test using an external check script. Catch2 integration tests are written
|
|
using CTest, either as a direct command invocation + pass/fail regex,
|
|
or by delegating the check to a Python script.
|
|
|
|
Catch2 is slowly gaining more and more types of tests, currently Catch2
|
|
project also has buildable examples, "ExtraTests", and CMake config tests.
|
|
Examples present a small and self-contained snippets of code that
|
|
use Catch2's facilities for specific purpose. Currently they are assumed
|
|
passing if they compile.
|
|
|
|
ExtraTests then are expensive tests, that we do not want to run all the
|
|
time. This can be either because they take a long time to run, or because
|
|
they take a long time to compile, e.g. because they test compile time
|
|
configuration and require separate compilation.
|
|
|
|
Finally, CMake config tests test that you set Catch2's compile-time
|
|
configuration options through CMake, using CMake options of the same name.
|
|
|
|
These test categories can be enabled one by one, by passing
|
|
`-DCATCH_BUILD_EXAMPLES=ON`, `-DCATCH_BUILD_EXTRA_TESTS=ON`, and
|
|
`-DCATCH_ENABLE_CONFIGURE_TESTS=ON` when configuring the build.
|
|
|
|
Catch2 also provides a preset that promises to enable _all_ test types,
|
|
`all-tests`.
|
|
|
|
The snippet below will build & run all tests, in `Debug` compilation mode.
|
|
|
|
<!-- snippet: catch2-build-and-test -->
|
|
<a id='snippet-catch2-build-and-test'></a>
|
|
```sh
|
|
# 1. Regenerate the amalgamated distribution (some tests are built against it)
|
|
./tools/scripts/generateAmalgamatedFiles.py
|
|
|
|
# 2. Configure the full test build
|
|
cmake -B debug-build -S . -DCMAKE_BUILD_TYPE=Debug --preset all-tests
|
|
|
|
# 3. Run the actual build
|
|
cmake --build debug-build
|
|
|
|
# 4. Run the tests using CTest
|
|
cd debug-build
|
|
ctest -j 4 --output-on-failure -C Debug
|
|
```
|
|
<sup><a href='/tools/scripts/buildAndTest.sh#L6-L19' title='File snippet `catch2-build-and-test` was extracted from'>snippet source</a> | <a href='#snippet-catch2-build-and-test' title='Navigate to start of snippet `catch2-build-and-test`'>anchor</a></sup>
|
|
<!-- endSnippet -->
|
|
|
|
For convenience, the above commands are in the script `tools/scripts/buildAndTest.sh`, and can be run like this:
|
|
|
|
```bash
|
|
cd Catch2
|
|
./tools/scripts/buildAndTest.sh
|
|
```
|
|
|
|
A Windows version of the script is available at `tools\scripts\buildAndTest.cmd`.
|
|
|
|
If you added new tests, you will likely see `ApprovalTests` failure.
|
|
After you check that the output difference is expected, you should
|
|
run `tools/scripts/approve.py` to confirm them, and include these changes
|
|
in your commit.
|
|
|
|
|
|
## Writing documentation
|
|
|
|
If you have added new feature to Catch2, it needs documentation, so that
|
|
other people can use it as well. This section collects some technical
|
|
information that you will need for updating Catch2's documentation, and
|
|
possibly some generic advise as well.
|
|
|
|
|
|
### Technicalities
|
|
|
|
First, the technicalities:
|
|
|
|
* If you have introduced a new document, there is a simple template you
|
|
should use. It provides you with the top anchor mentioned to link to
|
|
(more below), and also with a backlink to the top of the documentation:
|
|
```markdown
|
|
<a id="top"></a>
|
|
# Cool feature
|
|
|
|
> [Introduced](https://github.com/catchorg/Catch2/pull/123456) in Catch2 X.Y.Z
|
|
|
|
Text that explains how to use the cool feature.
|
|
|
|
|
|
---
|
|
|
|
[Home](Readme.md#top)
|
|
```
|
|
|
|
* Crosslinks to different pages should target the `top` anchor, like this
|
|
`[link to contributing](contributing.md#top)`.
|
|
|
|
* We introduced version tags to the documentation, which show users in
|
|
which version a specific feature was introduced. This means that newly
|
|
written documentation should be tagged with a placeholder, that will
|
|
be replaced with the actual version upon release. There are 2 styles
|
|
of placeholders used through the documentation, you should pick one that
|
|
fits your text better (if in doubt, take a look at the existing version
|
|
tags for other features).
|
|
* `> [Introduced](link-to-issue-or-PR) in Catch2 X.Y.Z` - this
|
|
placeholder is usually used after a section heading
|
|
* `> X (Y and Z) was [introduced](link-to-issue-or-PR) in Catch2 X.Y.Z`
|
|
- this placeholder is used when you need to tag a subpart of something,
|
|
e.g. a list
|
|
|
|
* For pages with more than 4 subheadings, we provide a table of contents
|
|
(ToC) at the top of the page. Because GitHub markdown does not support
|
|
automatic generation of ToC, it has to be handled semi-manually. Thus,
|
|
if you've added a new subheading to some page, you should add it to the
|
|
ToC. This can be done either manually, or by running the
|
|
`updateDocumentToC.py` script in the `scripts/` folder.
|
|
|
|
### Contents
|
|
|
|
Now, for some content tips:
|
|
|
|
* Usage examples are good. However, having large code snippets inline
|
|
can make the documentation less readable, and so the inline snippets
|
|
should be kept reasonably short. To provide more complex compilable
|
|
examples, consider adding new .cpp file to `examples/`.
|
|
|
|
* Don't be afraid to introduce new pages. The current documentation
|
|
tends towards long pages, but a lot of that is caused by legacy, and
|
|
we know that some of the pages are overly big and unfocused.
|
|
|
|
* When adding information to an existing page, please try to keep your
|
|
formatting, style and changes consistent with the rest of the page.
|
|
|
|
* Any documentation has multiple different audiences, that desire
|
|
different information from the text. The 3 basic user-types to try and
|
|
cover are:
|
|
* A beginner to Catch2, who requires closer guidance for the usage of Catch2.
|
|
* Advanced user of Catch2, who want to customize their usage.
|
|
* Experts, looking for full reference of Catch2's capabilities.
|
|
|
|
|
|
## Writing code
|
|
|
|
If want to contribute code, this section contains some simple rules
|
|
and tips on things like code formatting, code constructions to avoid,
|
|
and so on.
|
|
|
|
### C++ standard version
|
|
|
|
Catch2 currently targets C++14 as the minimum supported C++ version.
|
|
Features from higher language versions should be used only sparingly,
|
|
when the benefits from using them outweigh the maintenance overhead.
|
|
|
|
Example of good use of polyfilling features is our use of `conjunction`,
|
|
where if available we use `std::conjunction` and otherwise provide our
|
|
own implementation. The reason it is good is that the surface area for
|
|
maintenance is quite small, and `std::conjunction` can directly use
|
|
compiler built-ins, thus providing significant compilation benefits.
|
|
|
|
Example of bad use of polyfilling features would be to keep around two
|
|
sets of metaprogramming in the stringification implementation, once
|
|
using C++14 compliant TMP and once using C++17's `if constexpr`. While
|
|
the C++17 would provide significant compilation speedups, the maintenance
|
|
cost would be too high.
|
|
|
|
|
|
### Formatting
|
|
|
|
To make code formatting simpler for the contributors, Catch2 provides
|
|
its own config for `clang-format`. However, because it is currently
|
|
impossible to replicate existing Catch2's formatting in clang-format,
|
|
using it to reformat a whole file would cause massive diffs. To keep
|
|
the size of your diffs reasonable, you should only use clang-format
|
|
on the newly changed code.
|
|
|
|
|
|
### Code constructs to watch out for
|
|
|
|
This section is a (sadly incomplete) listing of various constructs that
|
|
are problematic and are not always caught by our CI infrastructure.
|
|
|
|
|
|
#### Naked exceptions and exceptions-related function
|
|
|
|
If you are throwing an exception, it should be done via `CATCH_ERROR`
|
|
or `CATCH_RUNTIME_ERROR` in `internal/catch_enforce.hpp`. These macros will handle
|
|
the differences between compilation with or without exceptions for you.
|
|
However, some platforms (IAR) also have problems with exceptions-related
|
|
functions, such as `std::current_exceptions`. We do not have IAR in our
|
|
CI, but luckily there should not be too many reasons to use these.
|
|
However, if you do, they should be kept behind a
|
|
`CATCH_CONFIG_DISABLE_EXCEPTIONS` macro.
|
|
|
|
|
|
#### Avoid `std::move` and `std::forward`
|
|
|
|
`std::move` and `std::forward` provide nice semantic name for a specific
|
|
`static_cast`. However, being function templates they have surprisingly
|
|
high cost during compilation, and can also have a negative performance
|
|
impact for low-optimization builds.
|
|
|
|
You should be using `CATCH_MOVE` and `CATCH_FORWARD` macros from
|
|
`internal/catch_move_and_forward.hpp` instead. They expand into the proper
|
|
`static_cast`, and avoid the overhead of `std::move` and `std::forward`.
|
|
|
|
|
|
#### Unqualified usage of functions from C's stdlib
|
|
|
|
If you are using a function from C's stdlib, please include the header
|
|
as `<cfoo>` and call the function qualified. The common knowledge that
|
|
there is no difference is wrong, QNX and VxWorks won't compile if you
|
|
include the header as `<cfoo>` and call the function unqualified.
|
|
|
|
|
|
#### User-Defined Literals (UDL) for Catch2' types
|
|
|
|
Due to messy standardese and ... not great ... implementation of
|
|
`-Wreserved-identifier` in Clang, avoid declaring UDLs as
|
|
```cpp
|
|
Approx operator "" _a(long double);
|
|
```
|
|
and instead declare them as
|
|
```cpp
|
|
Approx operator ""_a(long double);
|
|
```
|
|
|
|
Notice that the second version does not have a space between the `""` and
|
|
the literal suffix.
|
|
|
|
|
|
|
|
### New source file template
|
|
|
|
If you are adding new source file, there is a template you should use.
|
|
Specifically, every source file should start with the licence header:
|
|
```cpp
|
|
|
|
// Copyright Catch2 Authors
|
|
// Distributed under the Boost Software License, Version 1.0.
|
|
// (See accompanying file LICENSE.txt or copy at
|
|
// https://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
```
|
|
|
|
The include guards for header files should follow the pattern `{FILENAME}_INCLUDED`.
|
|
This means that for file `catch_matchers_foo.hpp`, the include guard should
|
|
be `CATCH_MATCHERS_FOO_HPP_INCLUDED`, for `catch_generators_bar.hpp`, the include
|
|
guard should be `CATCH_GENERATORS_BAR_HPP_INCLUDED`, and so on.
|
|
|
|
|
|
### Adding new `CATCH_CONFIG` option
|
|
|
|
When adding new `CATCH_CONFIG` option, there are multiple places to edit:
|
|
* `CMake/CatchConfigOptions.cmake` - this is used to generate the
|
|
configuration options in CMake, so that CMake frontends know about them.
|
|
* `docs/configuration.md` - this is where the options are documented
|
|
* `src/catch2/catch_user_config.hpp.in` - this is template for generating
|
|
`catch_user_config.hpp` which contains the materialized configuration
|
|
* `BUILD.bazel` - Bazel does not have configuration support like CMake,
|
|
and all expansions need to be done manually
|
|
* other files as needed, e.g. `catch2/internal/catch_config_foo.hpp`
|
|
for the logic that guards the configuration
|
|
|
|
|
|
## CoC
|
|
|
|
This project has a [CoC](../CODE_OF_CONDUCT.md). Please adhere to it
|
|
while contributing to Catch2.
|
|
|
|
-----------
|
|
|
|
_This documentation will always be in-progress as new information comes
|
|
up, but we are trying to keep it as up to date as possible._
|
|
|
|
---
|
|
|
|
[Home](Readme.md#top)
|