title | subtitle | document | date | audience | revises | author | toc | toc-depth | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Test document for mpark/wg21 |
Visual inspection of various features of the framework |
D0000R1 |
today |
|
D0000R0 |
|
true |
2 |
This framework provides support for various common elements for C++ papers.
This document is intended to test various features implemented in mpark/wg21
.
The title is specified by YAML metadata block.
---
title: Example Title
subtitle: Example Subtitle
document: DxxxxRn
date: 2019-06-13
audience:
- Library Evolution
- Library
author:
- name: Author One
email: <one@author.com>
- name: Author Two
email: <two@author.com>
toc: false # default: `true`
toc-depth: 4 # default: `3`
---
date: today
will generate today's date inYYYY-MM-DD
(ISO 8601) format.
Pandoc Markdown is the Markdown flavor used for this framework.
Inline formatting such as bold, italics, and verbatim
work as you would
expect. There are also useful extensions such as strikeout,
subscript, su^per^script, and highlighted code: constexpr
{.cpp}.
Various compositions in compact list:
A<B<T>>
{.cpp}compare_3way
{.cpp}3WAY
{.default}<R>
{.cpp}operator@
{.cpp}operator+
{.cpp}x @ y
{.cpp}x & y
{.cpp}- foo
constexpr
{.cpp} bar - foo
constexpr
{.cpp} bar fooconstexpr
{.cpp} bar- [
hello world
]{.add} hello world
hello world
namespace @_unspecified_@ { struct sender_base {}; }
namespace @_unspecified_@ { struct sender_base {}; }
{.cpp}
Loose list:
-
x@~_i_~@ <=> y@~_i_~@
{.cpp} -
[foo
hello world
bar]{.rm}
#include <iostream>
#include "foo.h"
__FILE__;
int x = 42'234'234;
const int x = 42ul;
const int x = 0B01011;
bool b = true;
struct process {
hello @[constexpr]{.rm}@ detail::foo::template @_foo_@;
[[using CC: opt(1), debug]] x;
template <typename I>
[[nodiscard]] auto operator()(I i) -> O<I> { /* ... */ };
};
@@[`namespace @_unspecified_@ { struct sender_base {}; }`]{.add}@@
@@[`using @_unspecified_@::sender_base;`]{.add}@@
@@[`template<class, class> struct @_as-receiver_@; @_// exposition only_@`]{.add}@@
@@[`template<class, class> struct @_as-invocable_@; @_// exposition only_@`]{.add}@@
#include <iostream>
#include "foo.h"
__FILE__;
int x = 42'234'234;
const int x = 42ul;
const int x = 0B01011;
bool b = true;
struct process {
hello @[`constexpr`]{.add}@ detail::foo::template foo;
[[using CC: opt(1), debug]] x;
template <typename I>
[[nodiscard]] auto operator()(I i) -> O<I> { /* ... */ };
x@~_i_~@ <=> y@~_i_~@;
};
if (x) {
return ""sv;
return 5ms;
}
std::printf("%d", x);
std::variant<I1, I2> input = 'h';
std::variant<I1, I2> input = "h";
std::variant<I1, I2> input = "hello";
// mapping from a `variant` of inputs to a `variant` of results:
auto output = std::visit<std::variant<O<I1>, O<I2>>>(process{}, input);
// coercing different results to a common type:
auto result = std::visit<std::common_type_t<O<I1>, O<I2>>>(process{}, input);
// visiting a `variant` for the side-effects, discarding results:
std::visit<void>(process{}, input);
@@[`namespace @_unspecified_@ { struct sender_base {}; }`]{.add}@@
@@[`using @_unspecified_@::sender_base;`]{.add}@@
some things just don't change.
// 20.3.4 tuple-like access to pair:
- constexpr typename tuple_element<I, std::pair<T1, T2> >::type&
+ constexpr tuple_element_t<I, pair<T1, T2> >&
- get(std::pair<T1, T2>&) noexcept;
+ get(pair<T1, T2>&) noexcept;
@_unspecified_@ detail::foo::template foo;
+ @_unspecified_@ detail::foo::template foo;
- @_unspecified_@ detail::foo::template foo;
::: cmptable
Put your caption here
switch (x) {
case 0: std::cout << "got zero"; break;
case 1: std::cout << "got one"; break;
default: std::cout << "don't care";
}
inspect (x) {
0: std::cout << "got zero";
1: std::cout << "got one";
_: std::cout << "don't care";
}
:::
::: cmptable
switch (x) {
case 0: std::cout << "got zero"; break;
case 1: std::cout << "got one"; break;
default: std::cout << "don't care";
}
inspect (x) {
0: std::cout << "got zero";
1: std::cout << "got one";
_: std::cout << "don't care";
}
if (s == "foo") {
std::cout << "got foo";
} else if (s == "bar") {
std::cout << "got bar";
} else {
std::cout << "don't care";
}
inspect (s) {
"foo": std::cout << "got foo";
"bar": std::cout << "got bar";
_: std::cout << "don't care";
}
:::
[2]{.pnum} An expression is potentially evaluated unless it is an unevaluated
operand (7.2) or a subexpression thereof. The set of potential results of
an expression e
is defined as follows:
-
[2.1]{.pnum} If
e
is an id-expression (7.5.4), the set contains onlye
. -
[2.2]{.pnum} If
e
is a subscripting operation (7.6.1.1) with an array operand, the set contains the potential results of that operand.
Large changes are ::: add
for additions, ::: rm
for removals.
Modify section [format.functions]{.sref}:
::: add
template<class... Args> string format(const locale& loc, string_view fmt, const Args&... args);
Returns:
vformat(loc, fmt, make_format_args(args...))
.:::
Small, inline changes are done with [new text]{.add}
or [old text]{.rm}
.
+-----------+--------------------------------------------------------------------+
| Specifier | Replacement |
+===========+====================================================================+
| %a
| The locale’s abbreviated weekday name. If the value does not |
| | contain a valid weekday, [setstate(ios::failbit)
is called]{.rm} |
| | [format_error
is thrown]{.add}. |
+-----------+--------------------------------------------------------------------+
| %A
| The locale’s full weekday name. If the value does not contain |
| | a valid weekday, [setstate(ios::failbit)
is called]{.rm} |
| | [format_error
is thrown]{.add}. |
+-----------+--------------------------------------------------------------------+
| selection-statement: |
if constexpr
opt(
init-statementoptcondition)
statement |if constexpr
opt(
init-statementoptcondition)
statementelse
statement |switch (
init-statementoptcondition)
statement | [inspect
constexpr
opt(
init-statementoptcondition)
{
inspect-case-seq}
]{.add}::: add | inspect-case-seq: | inspect-case | inspect-case-seq inspect-case
| inspect-case: | attribute-specifier-seq
optinspect-pattern inspect-guardopt:
statement| inspect-pattern: | wildcard-pattern | identifier-pattern | constant-pattern | structured-binding-pattern | alternative-pattern | binding-pattern | extractor-pattern
| inspect-guard: |
if (
expression)
:::
Stable names are written as [basic.life]{.sref}
, and renders as [basic.life]{.sref}.
You can also add a class -
or .unnumbered
to omit the section number.
It uses https://timsong-cpp.github.io/cppwp/annex-f as the underlying database.
Examples:
[basic.life]{.sref}
→ [basic.life]{.sref}[basic.life]{- .sref}
→ [basic.life]{- .sref}[basic.life]{.unnumbered .sref}
→ [basic.life]{.unnumbered .sref}
There are three supported styles of note:
-
Use the
note
class for notes that are expected to appear in the specification wording[Notes will look like this]{.note}
[Notes will look like this]{.note}
-
Use the
ednote
for editorial notes, these will be formatted as[Editorial notes are important]{.ednote}
[Editorial notes are important]{.ednote}
-
Use
draftnote
to include text that is intended as questions or information for reviews and working groups.[Drafting notes can be used to provide comments for reviewers that are explicitly not to be included in the specification.]{.draftnote} [It is also possible to indicate the a note is for a specific `audience` via this optional attribute.]{.draftnote audience="the reader"}
[Drafting notes can be used to provide comments for reviewers that are explicitly not to be included in the specification.]{.draftnote}
[It is also possible to indicate the a note is for a specific
audience
via this optional attribute.]{.draftnote audience="the reader"}
Automatic references are written as [@N4762]
and renders as [@N4762].
Anything in https://wg21.link/index.yaml are linked automatically.
N
Papers (e.g.,[@N3887]
[@N3887])P
Papers (e.g.,[@P1371R1]
[@P1371R1])- CWG Issues (e.g.,
[@CWG1234]
[@CWG1234]) - LWG Issues (e.g.,
[@LWG1234]
[@LWG1234]) - Github Edits (e.g,
[@EDIT1234]
[@EDIT1234]) - Standing Documents (e.g.,
[@SD6]
[@SD6])