Subversion Repositories Games.Descent

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 pmbaty 1
DXX-Rebirth requires a compiler that implements the C++17 standard.  A fully conforming compiler is recommended, but some omissions can be handled by SConf tests that enable a fallback to emulate the feature.
2
 
3
# Required C++11 features
4
DXX-Rebirth code uses C++11 and C++14 features present in >=clang-9.0 and >=gcc-7.5.  Some of these features are probed in the SConf tests so that an error can be reported if the feature is missing.  However, since these are considered the minimum supported compiler versions, and existing SConf tests reject older compilers, some C++14 features that are new in gcc-7.5 may be used without a corresponding test in SConf.
5
 
6
These C++11 features are required to build DXX-Rebirth:
7
 
8
* [Rvalue references][cppr:cpp/language/reference]
9
(`void a(A &&);`)
10
* [Variadic templates][cppr:cpp/language/parameter_pack]
11
(`template <typename... T> class A{};`)
12
* [`auto`-typed variables][cppr:cpp/language/auto]
13
(`auto a = f();`)
14
    * Trailing function return type (`auto f() -> int;`)
15
* [Lambdas][cppr:cpp/language/lambda]
16
(`f([]{ return 1; });`)
17
* [`decltype()`][cppr:cpp/language/decltype]
18
(`typedef decltype(a()) b;`)
19
* [Alias templates][cppr:cpp/language/type_alias]
20
(`using A = B;
21
template <typename T> using C = D<T, T>;`)
22
* [Null pointer constant `nullptr`][cppr:cpp/language/nullptr]
23
(`int *i = nullptr;`)
24
* [Strongly-typed enums][scppr:enum class]
25
(`enum class E { ... };`)
26
* [Forward declaration for enums][scppr:enum fwd]
27
(`enum E;
28
...;
29
enum E { ... };`)
30
* [Generalized constant expressions][cppr:cpp/language/constexpr]
31
(`constexpr int a = 0;`)
32
* [Explicit conversion operators][cppr:cpp/language/cast_operator]
33
(`explicit operator bool();`)
34
* [Defaulted and deleted functions][cppr:cpp/language/function#Function_definition]
35
(`void a(int b) = delete;`)
36
* [Unique pointer template std::unique\_ptr<T\>][cppr:cpp/memory/unique_ptr]
37
(`std::unique_ptr<int> i;
38
std::unique_ptr<int[]> j;`)
39
* [Static assertions][cppr:cpp/language/static_assert]
40
* `std::addressof`
41
 
42
# Required C++14 features
43
* [`std::index_sequence`][cppr:cpp/utility/integer_sequence] is a compile-time sequence of integers.
44
* [`std::exchange`][cppr:cpp/utility/exchange] is a utility to update a variable, and yield the value it had before the update
45
* [`std::make_unique`][cppr:cpp/memory/unique_ptr/make_unique] is a convenience utility function for constructing `std::unique_ptr` with a managed value.
46
 
47
# Optional C++11/C++14 features
48
DXX-Rebirth code may use C++11 or C++14 features not present in the minimum supported compiler if the feature can be emulated easily (C++11: [inheriting constructors][cppr:cpp/language/using_declaration], [Range-based for][cppr:cpp/language/range-for]) or if the feature can be removed by a macro and the removal does not change the correctness of the program (C++11: [rvalue-qualified member methods][scppr:rvalue method]).
49
 
50
## Optional C++11 features
51
### Emulated if absent
52
 
53
* [Inheriting constructors][cppr:cpp/language/using_declaration] are wrapped by the macro `DXX_INHERIT_CONSTRUCTORS`.
54
If inherited constructors are supported, then `DXX_INHERIT_CONSTRUCTORS` expands to a `using` declaration.
55
If inherited constructors are not supported, then `DXX_INHERIT_CONSTRUCTORS` defines a [variadic template][cppr:cpp/language/parameter_pack] constructor to forward arguments to the base class.
56
* [Range-based for][cppr:cpp/language/range-for] is wrapped by the macro `range_for`.
57
This feature is present in the current minimum supported compiler versions.
58
It was first used when >=gcc-4.5 was the minimum.
59
Use of the `range_for` macro continues because it improves readability.
60
 
61
### Preprocessed out if absent
62
 
63
* [Reference-qualified methods][scppr:rvalue method] check that an rvalue which may or may not hold a valid pointer is not used in a context where the caller assumes the rvalue holds a valid pointer.
64
When the rvalue may or may not hold a valid pointer, it must be saved to an lvalue, tested for a valid pointer, and used only if a valid pointer is found.
65
 
66
[cppr:cpp/language/reference]: https://en.cppreference.com/w/cpp/language/reference
67
[cppr:cpp/language/parameter_pack]: https://en.cppreference.com/w/cpp/language/parameter_pack
68
[cppr:cpp/language/auto]: https://en.cppreference.com/w/cpp/language/auto
69
[cppr:cpp/language/lambda]: https://en.cppreference.com/w/cpp/language/lambda
70
[cppr:cpp/language/decltype]: https://en.cppreference.com/w/cpp/language/decltype
71
[cppr:cpp/language/type_alias]: https://en.cppreference.com/w/cpp/language/type_alias
72
[cppr:cpp/language/nullptr]: https://en.cppreference.com/w/cpp/language/nullptr
73
[scppr:enum class]: https://en.cppreference.com/w/cpp/language/enum#Scoped_enumerations.28since_C.2B.2B11.29
74
[scppr:enum fwd]: https://en.cppreference.com/w/cpp/language/enum#Unscoped_enumeration
75
[cppr:cpp/language/constexpr]: https://en.cppreference.com/w/cpp/language/constexpr
76
[cppr:cpp/language/cast_operator]: https://en.cppreference.com/w/cpp/language/cast_operator
77
[cppr:cpp/language/function#Function_definition]: https://en.cppreference.com/w/cpp/language/function#Function_definition
78
[cppr:cpp/memory/unique_ptr]: https://en.cppreference.com/w/cpp/memory/unique_ptr
79
[cppr:cpp/utility/exchange]: https://en.cppreference.com/w/cpp/utility/exchange
80
[cppr:cpp/utility/integer_sequence]: https://en.cppreference.com/w/cpp/utility/integer_sequence
81
[cppr:cpp/memory/unique_ptr/make_unique]: https://en.cppreference.com/w/cpp/memory/unique_ptr/make_unique
82
[scppr:rvalue method]: https://en.cppreference.com/w/cpp/language/member_functions#const-.2C_volatile-.2C_and_ref-qualified_member_functions
83
[cppr:cpp/language/using_declaration]: https://en.cppreference.com/w/cpp/language/using_declaration
84
[cppr:cpp/language/range-for]: https://en.cppreference.com/w/cpp/language/range-for
85
[cppr:cpp/language/static_assert]: https://en.cppreference.com/w/cpp/language/static_assert